git使用总结

Posted amcle

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了git使用总结相关的知识,希望对你有一定的参考价值。

下面内容总结于菜鸟教程:https://www.runoob.com/git/git-workflow.html

补充:1) cat 文件名:显示文件内容

touch 文件:生成新的文件

vim 文件:查看文件,修改文件

1.git一般工作流程:

  • 克隆 Git 资源作为工作目录。
  • 在克隆的资源上添加或修改文件。
  • 如果其他人修改了,你可以更新资源。
  • 在提交前查看修改。
  • 提交修改。
  • 在修改完成后,如果发现错误,可以撤回提交并再次修改并提交。

2.Git 工作区、暂存区和版本库

  • 图中左侧为工作区,右侧为版本库。在版本库中标记为 "index" 的区域是暂存区(stage/index),标记为 "master" 的是 master 分支所代表的目录树。

  • 图中我们可以看出此时 "HEAD" 实际是指向 master 分支的一个"游标"。所以图示的命令中出现 HEAD 的地方可以用 master 来替换。

  • 图中的 objects 标识的区域为 Git 的对象库,实际位于 ".git/objects" 目录下,里面包含了创建的各种对象及内容。

  • 当对工作区修改(或新增)的文件执行 git add 命令时,暂存区的目录树被更新,同时工作区修改(或新增)的文件内容被写入到对象库中的一个新的对象中,而该对象的ID被记录在暂存区的文件索引中。

  • 当执行提交操作(git commit)时,暂存区的目录树写到版本库(对象库)中,master 分支会做相应的更新。即 master 指向的目录树就是提交时暂存区的目录树。

  • 当执行 git reset HEAD 命令时,暂存区的目录树会被重写,被 master 分支指向的目录树所替换,但是工作区不受影响。

  • 当执行 git rm --cached <file> 命令时,会直接从暂存区删除文件,工作区则不做出改变。

  • 当执行 git checkout . 或者 git checkout -- <file> 命令时,会用暂存区全部或指定的文件替换工作区的文件。这个操作很危险,会清除暂存区中未添加到工作区中的改动。

  • 当执行 git checkout HEAD . 或者 git checkout HEAD <file> 命令时,会用 HEAD 指向的 master 分支中的全部或者部分文件替换暂存区和以及工作区中的文件。这个命令也是极具危险性的,因为不但会清除工作区中未提交的改动,也会清除暂存区中未提交的改动。

3.常用操作

 

1)git clone 

拉代码,格式一:git clone <repo>   ex.:   git clone git://github.com/schacon/grit.git

格式二(克隆到指定目录):git clone <repo> <directory>  ex.:   git clone git://github.com/schacon/grit.git mygrit

  • git init - 初始化仓库。
  • git add . - 添加文件到暂存区。
  • git commit - 将暂存区内容添加到仓库中。

2)git add

添加文件到暂存区,格式一(添加一个或多个文件到暂存区):git add [file1] [file2] ...

格式二(添加指定目录到暂存区,包括子目录):git add [dir]

格式三(添加当前目录下的所有文件到暂存区):git add .

3)git status

查看在你上次提交之后是否有对文件进行再次修改 格式:git status -s

4)git diff

比较文件的不同,即比较文件在暂存区和工作区的差异。

格式: git diff [file]

显示暂存区和上一次提交(commit)的差异: git diff --cached [file]

5)git commit

将暂存区内容添加到本地仓库中 格式(message为备注信息):git commit -m [message]

格式(跳过git add,直接将修改提交到本地仓库):git commit -a 

6)git reset

命令用于回退版本,可以指定退回某一次提交的版本 格式:git reset [--soft | --mixed | --hard] [HEAD]

$ git reset HEAD^            # 回退所有内容到上一个版本  
$ git reset HEAD^ hello.php  # 回退 hello.php 文件的版本到上一个版本  
$ git  reset  052e           # 回退到指定版本

--hard 参数撤销工作区中所有未提交的修改内容,将暂存区与工作区都回到上一次版本,并删除之前的所有信息提交:

git reset --hard HEAD

HEAD 说明:

  • HEAD 表示当前版本

  • HEAD^ 上一个版本

  • HEAD^^ 上上一个版本

  • HEAD^^^ 上上上一个版本

7)git rm

用于删除文件。

将文件从暂存区和工作区中删除:git rm <file>                      ex:git rm runoob.txt

如果删除之前修改过并且已经放到暂存区域的话,则必须要用强制删除选项 -f     ex:git rm -f runoob.txt

从暂存区中删除  文件:git rm --cached runoob.txt

8) git mv

用于移动或重命名一个文件、目录或软连接.

格式:git mv [file] [newfile]

9)git log

查看历史提交记录

git reflog:查看历史版本号,可用命令git reset --hard 版本号恢复 

10)远程操作

git remote远程仓库操作
git fetch从远程获取代码库
git pull下载远程代码并合并
git push上传远程代码并合并
显示所有远程仓库:git remote -v

11) git branch 

查看分支,

git branch -d 分支:把分支删除

git branch 分支:创建分支

12) git checkout 

git checkout 分支名:切换分支

git checkout -b 分支名:新建并切换分支

git checkout -- 文件名:丢弃工作区的修改,与git restore -- 文件名作用一致,只要没有commit之前,如果我想在版本库中恢复此文件也是用该命令

13) git merge

git merge 分支:合并指定分支到当前分支上

git merge --no-ff -m "说明" 分支名:禁用fast forward模式,删除分支后,分支信息也不会丢失。

14)git remote add origin github仓库地址

把本地仓库与之关联,若要把本地仓库的内容推送到github仓库,使用git push origin 分支名,如git push origin master.(若第一次推送,需要在push 后加-u)

15)git clone 

git clone 远程分支地址:把远程仓库克隆到本机库,如 git clone https://github.com/tugenhua0707/testgit2

16) git stash

代码开发到一般时,要修复bug,需要把当前开发的状态保留下来,那么需要用git stash

开发完回到分支时,用git stash 查看分支,然后用git stash pop,恢复的同时把stash内容也删除了。

 

 

 

 

 

 

 

 

 

 

 

 

 

以上是关于git使用总结的主要内容,如果未能解决你的问题,请参考以下文章

Git 使用命令总结

Git 使用总结

工作后——Git的使用总结

Git使用经验总结1

Git 使用总结

git命令使用总结