repository仓库也就是一个项目
star:收藏
fork:克隆 将别人的仓库复制到自己账户下 该fork项目独立存在 是一个分支
pull request :发起请求
自己所在的更改发送到原作者。原作者查看后 如果满意可以合并到原仓库
watch:关注 只要这个项目有更新 你都会收到提醒。
issue:评论 别人给你提bug
创建仓库:
新建仓库文件:create new file
编辑文件
点击commit 可看每次具体修改内容:
点击此图标
上传文件 :Upload file
搜索文件:find file (快捷键T)
下载项目:
任何人可以对于开源项目作出贡献:
git status:查看文件状况
git add 从工作区提交到暂存区
git commit 从暂存提交到git 仓库
1.创建文件夹
2.在文件内初始化git(创建git仓库)
$cd justtest
$git init
向仓库添加文件:
1.创建文件
2.git add 文件名 添加到暂存区域
3.将文件从暂存提交到仓库
1.vim 修改文件
2.git add
3.git commit
删除仓库文件
以上都是本地操作 对git远程仓库不用有影响
git管理远程仓库
先克隆到本地
代码:
1. git clone 仓库地址
git add
git commit
git push
命令:
git diff
git log
版本回退:
首先,Git必须知道当前版本是哪个版本,在Git中,用HEAD表示当前版本,也就是最新的提交1094adb...(注意我的提交ID和你的肯定不一样),上一个版本就是HEAD^,上上一个版本就是HEAD^^,当然往上100个版本写100个^比较容易数不过来,所以写成HEAD~100。
现在,我们要把当前版本append GPL回退到上一个版本add distributed,就可以使用git reset命令:
$ git reset --hard HEAD^ HEAD is now at e475afc add distributed暂存区:
撤销修改:
命令git checkout -- readme.txt意思就是,把readme.txt文件在工作区的修改全部撤销,这里有两种情况:
一种是readme.txt自修改后还没有被放到暂存区,现在,撤销修改就回到和版本库一模一样的状态;
一种是readme.txt已经添加到暂存区后,又作了修改,现在,撤销修改就回到添加到暂存区后的状态。
用命令git reset HEAD <file>可以把暂存区的修改撤销掉(unstage),重新放回工作区:
删除文件:
命令git rm用于删除一个文件。如果一个文件已经被提交到版本库,那么你永远不用担心误删,但是要小心,你只能恢复文件到最新版本,你会丢失最近一次提交后你修改的内容。
git checkout其实是用版本库里的版本替换工作区的版本,无论工作区是修改还是删除,都可以“一键还原”。
提交到远端:
git push origin master创建分支:
$ git checkout -b dev Switched to a new branch 'dev'git checkout命令加上-b参数表示创建并切换,相当于以下两条命令:
$ git branch dev $ git checkout dev Switched to branch 'dev'然后,用git branch命令查看当前分支:
$ git branch * dev master现在,dev分支的工作完成,我们就可以切换回master分支:
$ git checkout master Switched to branch 'master'git merge命令用于合并指定分支到当前分支。合并后,再查看readme.txt的内容,就可以看到,和dev分支的最新提交是完全一样的。
$ git merge dev
合并完成后,就可以放心地删除dev分支了:
$ git branch -d dev Deleted branch dev (was b17d20e).小结:
查看分支:git branch
创建分支:git branch <name>
切换分支:git checkout <name>
创建+切换分支:git checkout -b <name>
合并某分支到当前分支:git merge <name>
删除分支:git branch -d <name>
当Git无法自动合并分支时,就必须首先解决冲突。解决冲突后,再提交,合并完成。
解决冲突就是把Git合并失败的文件手动编辑为我们希望的内容,再提交。
用git log --graph命令可以看到分支合并图。
推送分支,就是把该分支上的所有本地提交推送到远程库。推送时,要指定本地分支,这样,Git就会把该分支推送到远程库对应的远程分支上:
$ git push origin master如果要推送其他分支,比如dev,就改成:
$ git push origin dev推送失败,因为你的小伙伴的最新提交和你试图推送的提交有冲突,解决办法也很简单,Git已经提示我们,先用git pull把最新的提交从origin/dev抓下来,然后,在本地合并,解决冲突,再推送:
因此,多人协作的工作模式通常是这样:
首先,可以试图用git push origin <branch-name>推送自己的修改;
如果推送失败,则因为远程分支比你的本地更新,需要先用git pull试图合并;
如果合并有冲突,则解决冲突,并在本地提交;
没有冲突或者解决掉冲突后,再用git push origin <branch-name>推送就能成功!
如果git pull提示no tracking information,则说明本地分支和远程分支的链接关系没有创建,用命令git branch --set-upstream-to <branch-name> origin/<branch-name>。
这就是多人协作的工作模式,一旦熟悉了,就非常简单。
查看远程库信息,使用git remote -v;
本地新建的分支如果不推送到远程,对其他人就是不可见的;
从本地推送分支,使用git push origin branch-name,如果推送失败,先用git pull抓取远程的新提交;
在本地创建和远程分支对应的分支,使用git checkout -b branch-name origin/branch-name,本地和远程分支的名称最好一致;
建立本地分支和远程分支的关联,使用git branch --set-upstream branch-name origin/branch-name;
从远程抓取分支,使用git pull,如果有冲突,要先处理冲突。
命令git push origin <tagname>可以推送一个本地标签;
命令git push origin --tags可以推送全部未推送过的本地标签;
命令git tag -d <tagname>可以删除一个本地标签;
命令git push origin :refs/tags/<tagname>可以删除一个远程标签。
