Git 指令笔记

$ git status

查看当前目录是否有文件变动。

$ git add 文件名1 文件名2 ...

将文件添加到缓存区(若要将当前目录下全部文件添加到缓存区,使用命令 $ git add .,末尾是英文标点符号".")

$ git commit -m "描述内容"

将缓存区的文件提交到仓库,并根据描述使HEAD指针指向新创建的仓库的节点("描述内容"可以不填写,表述描述为空)

$ git log

查看节点编码,用SHA1计算而得

$ git reset --hard 节点编码

返回当前仓库到已知的某一节点,节点编码不用写完全,前7位即可(HEAD∧表示上一节点,HEAD∧∧表示上上节点)

$ git remote add origin git@github.com:用户名/仓库名.git

建立本地仓库与GitHub服务器上仓库的关联

$ git push -u origin master

首次推送本地仓库内容到GitHub服务器,推送master分支的内容

$ git push origin master

第二次及以后推送内容到GitHub服务器

$ git clone git@github.com:用户名/仓库名.git

克隆GitHub上的仓库,在本地以仓库(reponsitory)名建立一个文件夹,并下载仓库全部内容

$ git checkout -b dev

创建分支dev,并切换到分支dev,效果相当于 $ git branch dev 加上 $ git checkout dev

$ git branch

查看当前分支,列出当前所有分支,而正在使用的分支前有"*"符号

$ git merge dev

将dev分支上的工作成果合并到master主分支上

$ git branch -d dev

删除分支dev,$ git branch -D dev,强制删除分支

$ git log --graph --pretty=oneline --abbrev-commit --

显示日志,并呈现为线性关系

(更美观,方便的显示日志)

$ git log --graph --pretty=format:'%Cred%h%Creset -%C(yellow)%d%Creset %s %Cgreen (%cr) %C(bold blue)<%an>%Creset'--abbrev-commit --

这样有点长了,我们可以这样:

$  git config --global alias.lg "log --color --graph --pretty=format:'%Cred%h%Creset -%C(yellow)%d%Creset %s %Cgreen (%cr) %C(bold blue)<%an>%Creset' --abbrev-commit --"

然后,我们就可以使用这样的短命令了:

$  git lg

(查看日志方法,结束)

$ git merge --no-ff -m "描述内容" dev

默认合并分支的方式为 Fast forward 方式,即将 HEAD 指针指向分支dev的当前位置,而调用--no-ff将产生一个新指针,所以需要加入-m并附上描述内容

$ git stash

将当前分支的工作内容保存进stash队列

$ gti stash list

显示stash(储藏处)队列的内容,按“stash@{0}” 诸如此类数字变化的顺序排列

$ git stash apply stash@{0}

恢复stash@{0}的内容,但不删除stash@{0},若不写stash@{0},表示恢复上一条记录

$ git stash drop stash@{0}

删除stash@{0},若不写stash@{0},表示删除上一条记录

$ git stash pop

恢复并删除上一条储藏,若在pop后跟上stash的队列序号:stash@{0},则为制定队列

$ git remote -v

显示github主机上的详细分支,(fetch)抓取,(push)推送,如果没有推送权限,就看不到(push)地址

$ git push origin 分支名

origin为远程主机的默认名,推送不同分支,填写不同分支名,需要实时与远程主机同步,master是主分支,dev是开发分支,所有团队成员都在dev上面工作,

所以也需要与远程服务器同步

$ git checkout -b dev origin/dev

主机建立一个完全克隆远程主机分支dev内容的本地分支dev

$ git branch --set-upstream dev origin/dev

指定本地dev与远程主机上的dev连接,之后可以使用 $ git pull 抓取内容

$ git pull

把最新的提交从origin/分支名上抓下来

$ git tag 标签名 -m "描述内容" commit 指针编码

给指定commit指针编码添加“标签名“的tag,若没有描述内容可省略 -m "描述内容"

$ git push origin 标签名

将本地”标签名“的内容推送到远程主机

$ git tag -d 标签名

删除指定标签名内容

$ git push origin :refs/tags/标签名

删除远程主机上的标签名内容

* 标签名一般为v1.0,并以此类推

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容