github使用总结

    xiaoxiao2022-07-07  206

    repository仓库也就是一个项目

    star:收藏

    fork:克隆   将别人的仓库复制到自己账户下  该fork项目独立存在 是一个分支

    pull request :发起请求

    自己所在的更改发送到原作者。原作者查看后 如果满意可以合并到原仓库

    watch:关注  只要这个项目有更新 你都会收到提醒。

    issue:评论  别人给你提bug

    创建仓库:

    仓库管理:

    新建仓库文件:create new file

     

    编辑文件

    点击commit 可看每次具体修改内容:

    删除文件:

    点击此图标

    上传文件 :Upload file

    搜索文件:find file (快捷键T)

    下载项目:

    issues:

    任何人可以对于开源项目作出贡献:

    Git工作流程:

    git status:查看文件状况

    git add 从工作区提交到暂存区

    git commit 从暂存提交到git 仓库

    git初始化仓库:

    git config --global user.name 'Iorizy2' git config --global user.email'374545365@qq.com'

    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>可以删除一个远程标签。

    最新回复(0)