git init 创建仓库
git status 查看仓库的状态
git add 添加到暂存区
也可以使用通配符,例如:git add *.txt 把后缀是.txt的文件添加到暂存区
也可以使用目录,例如:git add. 把当前目录添加到暂存区
git commit 提交
只提交暂存区中的内容,不会提交工作区中的内容
git commit -m 提交的注释信息,如果不使用-m则会出现vim编辑器界面
esc
vim中i是编辑,:wq保存退出
reset or clear清屏
ls -a 查看工作区中所有文件
git ls-files 查看暂存区中所有文件
git回退版本
git reset --soft 版本号
git reset --hard 版本号
git reset --mixed 版本号
git查看差异
git diff 工作区和暂存区的差异
git diff HEAD 工作区+暂存区 vs 本地仓库
git diff cached 暂存区 vs 本地仓库
git diff <commit_hash><commit_hash> 比较提交之间的差异
git diff HEAD~ HEAD 比较上个提交版本跟现在版本的差异
git diff HEAD~2HEAD 比较前两个版本跟现在版本的差异
git diff <branch_name><branch_name> 比较分支之间的差异
从版本库中删除文件
git rm <file> 这只是把文件从工作区和暂存区删除,要在版本库删除还得commit
git rm --cached <file> 把文件从暂存区中删除,但保留在当前工作区
git commit 删除后不要忘记提交
.gitignore文件 忽略掉一些不应该加入到版本库中的文件
应该忽略的文件
1.系统或者软件自动生成的文件
2.编译产生的中间文件和结果文件
3.运行时产生的日志文件/缓存文件/临时文件
4.涉及身份/密码/口令/密钥等敏感信息文件
忽略所有的.a文件 *.a
跟踪所有的lib.a,即便前面忽略了.a文件 !lab.a
只忽略当前目录下的T0D0文件,而不忽略subdir/T0D0 /T0D0
忽略任何目录下名为build的文件夹 build/
忽略doc/notes.txt,但不忽略doc/server/arch.txt doc/*.txt
密钥和私钥的作用:保证本地计算机能够与github进行安全通信,私钥不可以给别人。私钥用来加密,公钥是用来解码的。
生成SSH Key ssh-keygen-t rsa -b 4096
私钥文件:id_rsa
公钥文件:id_rsa.pub
把远程仓库更新到本地仓库
克隆仓库 git clone repo-address
推送更新内容 git push <remote><branch>
拉取更新内容 git pull <remote>
把本地的仓库上传到github
首先要在github上创建一个远程仓库
step1 本地添加远程仓库 git remote add <远程仓库别名><远程仓库地址>
例 :git remote add origin [email protected]:tsuihawk/remote-repo.git
step2 git push -u<远程仓库别名> <分支名>
例:git push -u origin main:main u是understream 意思是把两个分支合在一起
注意这里,有可能本地的分支不是main是master,那么要将master重命名为main
git branch -m old_branch_name new_branch_name
git branch -m master main
查看远程仓库 git remote -v
拉取远程仓库内容:git pull <远程仓库名><远程分支名>:<本地分支名> 相同可省略冒号及后面内容
查看分支列表 git branch
创建分支 git branch branch-name
切换分支 git switch branch-name
合并分支 git merge branch-name (要在主分支下进行)
删除分支(已合并) git branch -d branch-name
删除分支(强制删除) git branch -D branch-name
分支合并
两个分支未修改同一个文件的同一处位置:git 自动合并
两个分支修改了同一个文件同一处位置:产生冲突
解决办法:
step1 - 手动修改冲突文件,合并冲突内容
step2 - 把修改的文件添加暂存区 git add
step3 - 提交修改 git commit -m
终止合并:当不想继续执行合并操作时可以使用下面的命令来终止合并过程 git abort
rebase对于开发来讲不如merge