码迷,mamicode.com
首页 > 其他好文 > 详细

git基础命令

时间:2019-09-09 22:53:18      阅读:106      评论:0      收藏:0      [点我收藏+]

标签:spl   end   for   one   git push   mit   mamicode   拉取   lis   

1、如何取得项目的git仓库

取得项目的git仓库具有两种方法:

(1)在工作目录中初始化仓库

在项目的所在的目录下:

$ git init

然后使用git add命令对文件进行跟踪:

$ git add *.c

将修改进行提交:

$ git commit -m "initial project"

(2)从现有的仓库克隆

使用git clone url进行项目克隆:

$ git clone https://github.com/Cqlismy/C.git

 

2、记录每次更新到仓库

(1)项目中文件的变化周期

在一个项目当中,文件的变化周期如下图所示:

技术图片 

(2)检查当前文件的状态

如果想查看当前文件处于什么状态,可以使用git status命令:

$ git status

(3)跟踪新文件

使用git add开始跟踪新的文件:

$ git add README

使用git status查看文件状态,能看到文件被跟踪,并处于暂存状态。

(4)忽略某些文件

创建名为.gitignore的文件,并且列出要忽略文件的模式

文件.gitignore的规范格式如下所示:

1)所有的空行或#开头的行都被git忽略

2)可以使用标准的glob模式进行匹配

3)匹配模式最后以/结尾说明要忽略的是目录

4)要忽略指定模式以外的文件或目录,可以在模式前加!取反

例子:.gitignore文件如下

# 此为注释,将被git忽略

# 忽略以.a结尾的文件
*.a

# 除了lib.a
!lib.a

# 仅仅忽略项目根目录下的TODO文件,不包括dir/TODO
/TODO

# 忽略doc/*.txt,但不包括doc/dir/*.txt
doc/*.txt

# 忽略doc/dir下的所有*.txt文件
doc/**/*.txt

(5)查看已暂存和未暂存的更新

由git status查看文件的情况是比较简单的,要看具体修改了哪些地方,可以使用git diff命令:

$ git diff

(6)提交更新

当暂存区域已经准备好,就可以进行提交了,提交前要使用git status检查所有修改的文件是否已经暂存起来,然后使用git commit命令进行提交:

$ git commit

使用-m参数可以跟提交说明的方式。

(7)跳过使用暂存区域

给git commit添加-a参数,会自动将所有已跟踪过的文件暂存起来一并提 交,从而跳过git add步骤:

$ git commit -a -m "commit files"

(8)移除文件

从暂存区域中移除文件,然后提交文件,可以使用git rm命令:

$ git rm log/\*.log

(9)移动文件

当需要移动文件或者文件改名,可以使用git mv命令:

$ git mv file_from file_to

 

3、查看提交历史

提交了更新之后,可以使用git log查看提交的日志:

$ git log

 

4、撤销操作

有时候在项目中,我们可能需要撤销某些操作。

(1)修改最后一次提交

可以使用下面的命令进行重新提交:

$ git commit --amend

例如,提交时忘记了暂存某些修改,修改最后一次提交:

$ git commit -m "initial commit"
$ git add forgotten_file
$ git commit --amend

(2)取消已经暂存的文件

使用下面命令,文件将会到未暂存状态:

$ git reset HEAD <file>

(3)恢复已经修改的文件

当项目文件被修改了,但是感觉没必要时,可以使用下面命令恢复之前状态:

$ git restore <file>

 

5、远程仓库的使用

 远程仓库是指托管在网络上的项目仓库,同他人协作开发某个项目时,需要管理远程仓库,以便推送或拉取数据,分享各自的工作进展。

(1)查看当前的远程仓库

下面的命令可以查看远程仓库,-v选项显示对应的克隆地址:

$ git remote -v

(2)添加远程仓库

添加一个新的远程仓库,可以指定一个简单的名字,以便将来引用,使用下面命令:

$ git remote add [shortname] [url]

例如下面的例子,创建新的远程仓库,并修改文件,提交并推送:

$ git remote add pb git@github.com:Cqlismy/myGitTest.git
$ git remote -v
$ vim hello.c
$ git commit -a -m "modified hello.c"
$ git push pb

(3)远程库抓取数据

下面的命令将从远程仓库上抓取数据:

$ git fetch [remote-name]

(4)远程库推送数据

下面的命令将数据推送到远程仓库:

$ git push [remote-name] [branch-name]

例如,把本地的master分支推送到origin服务器上:

$ git push origin master

(5)查看远程库

查看某个远程仓库的详细信息:

$ git remote show [remote-name]

(6)远程库名重新命名和修改

使用下面命令修改某个远程仓库在本地的简称,如把pb修改为paul:

$ git remote rename pb paul

要删除某个远程仓库:

$ git remote rm [remote-name]

 

6、小节

本文主要简单介绍了一些常用的git基础命令。

 

参考:

http://iissnan.com/progit/

git基础命令

标签:spl   end   for   one   git push   mit   mamicode   拉取   lis   

原文地址:https://www.cnblogs.com/Cqlismy/p/11494415.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!