1、git config --global user.name "test" 设置名字
2、git config --global user.email "test@163.cn" 设置邮箱
3、git init 创建版本库
4、git add file 把文件添加到仓库
5、git commit -m "一些提交的备注信息" 把文件提交到仓库
6、git status 查看仓库的状态
7、git diff file 查看文件的改动
8、git log 显示从最近到最远的提交的日记
9、git reset --head HEAD^ 返回上一个版本
10、git reflog 参看所有的操作日记
11、把文件往Git版本库里添加的时候,是分两步执行的: 第一步是用git add把文件添加进去,实际上就是把文件修改添加到暂存区; 第二步是用git commit提交更改,实际上就是把暂存区的所有内容提交到当前分支。
12、git diff HEAD -- file 查看工作区和版本库里最新版本的区别
13、git checkout -- file 丢弃对file在工作区的修改 git checkout -- readme.txt意思就是,把readme.txt文件在工作区的修改全部撤销,这里有两种情况: 一种是readme.txt自修改后还没有被放到暂存区,现在,撤销修改就回到和版本库一模一样的状态; 一种是readme.txt已经添加到暂存区后,又作了修改,现在,撤销修改就回到添加到暂存区后的状态。
14、git reset HEAD file 把暂存区的修改撤销掉(unstage),重新放回工作区
15、git rm file 删除一个文件 1 1).从工作目录,提交到stage。 2).从stage提交到master。 从工作目录提交到stage,需要用add或者rm命令,只提交到stage,而没有提交到master,是不会自动同步到master的。 从stage提交到master用commit命令。 退回也是要分两步,一个是从master退回到stage,然后再从stage退回到工作目录。 对于还没有提交到stage的,可以从stage用checkout命令退回,这一步会取stage中的文件状态,覆盖掉工作目录中文件的状态,跟master完全没关系。 对于已经到达stage的,想把state中的文件状态用master中的覆盖掉,就用reset命令,这样就把stage中修改用master的状态覆盖掉了,完全跟工作目录没关系
16、ssh-keygen -t rsa -C "youremail@example.com" ssh的公钥生成
17、git remote add origin git@github.com:michaelliao/learngit.git 把一个已有的本地仓库与远程库关联
18、git remote add origin git@github.com:michaelliao/learngit.git 把本地仓库的内容推送到GitHub仓库
19、git checkout -b dev 创建新的分支,并且转到新的分支上,该语句可以拆分为量句话 git branch dev 创建新的分支。git checkout dev 切换到dev分支上
20、在分支的操作并且提交到仓库里,然后切回到master,会发现在分支的改变没有显示在master上 git merge dev 合并dev分支的成果到master上。
21、git branch -d dev 合并完分支后,可以删除分支
22、git merge --no-ff -m "merge with no-ff" dev 通过--no-ff 来指定合并的日记
23、git stash 可以把当前工作现场“储藏”起来,等以后恢复现场后继续工作
24、git stash list 把之前存储的工作现场显示出来
25、git stash apply 恢复现场,stash内容并不删除,需要运行git stash drop来删除
26、git stash pop 恢复现场,并把stash删除
27、git branch -D dev 强制删除分支,删除后会导致该分支的数据丢失
28、多人协作的工作模式通常是这样: 首先,可以试图用git push origin branch-name推送自己的修改; 如果推送失败,则因为远程分支比你的本地更新,需要先用git pull试图合并; 如果合并有冲突,则解决冲突,并在本地提交; 没有冲突或者解决掉冲突后,再用git push origin branch-name推送就能成功!
29、git tag v1.0 打版本,默认是当前最新提交的commit。还可以创建带有说明的标签,用-a指定标签名,-m指定说明文字 git tag v0.9 6224937 指定版本的commit
30、git tag -d v0.1 删除指定的版本
31、git push origin v1.0 推送指定版本到远程 命令git push origin可以推送一个本地标签; 命令git push origin --tags可以推送全部未推送过的本地标签; 命令git tag -d可以删除一个本地标签; 命令git push origin :refs/tags/可以删除一个远程标签。
32、远程库已经准备好了,下一步是用命令git clone克隆一个本地库:$ git clone git@github.com:michaelliao/gitskills.git
你也许还注意到,GitHub给出的地址不止一个,还可以用https://github.com/michaelliao/gitskills.git这样的地址。