参考网站:https://www.liaoxuefeng.com/wiki/896043488029600 基础概念
1.自定义名字和邮箱号 git config --global user.name “your name” git config --global user.email “your email” 2.创建默认仓库 mkdir filename 创建文件 cd filename 进入文件夹 Pwd 当前文件路径 git init 将当前目录作为初始化的仓库 3.文件基础操作 git add filename.exname 文件添加,可多次添加,一并提交 git commit -m “description” 提交文件并填写描述 git status 查看文件当前状态(例如:被修改的文件) git diff HEAD -- filename.exname 查看某个文件详细被修改的地方 git log 查看操作日志
git log --pretty=oneline 查看简介的操作日志 ls 查看文件列表 4.版本回退 git reset --hard HEAD^ 回退到上一个版本 “^”的个数代表要回退的版本数,前两个版本用^^代表,以此类推 git reset --hard conmmitid 回退到任意指定commitid版本 git reflog 查看所有的文件操作指令,前面的随机码即commitid 5.撤销修改 git checkout -- filename.exname 已修改(删除)文件但未add时,使用该命令会撤销修改(删除)的地方(文件) git reset HEAD filename.exname 已经add但未commit时,使用该命令会把暂存区回退到工作区,相当于只是本地修改(删除),未add 6.删除文件 rm filename.exname 仅在工作区删除 git rm filename.exname 不仅再工作区删除,同时还删除暂存区(完事之后记得 git commit),若要恢复,则需要用到前面的撤销修改指令 7.连接github
出现红框内英文即代表链接成功 8.添加到远程库 在github创建一个空的git仓库之后
在本地仓库输入 git remote add origin git@github.com:(github仓库地址).git 若报remote origin already exists的错误 说明本地已经关联了一个远程库,需要先删除再关联 git remote -v 查看远程库信息 git remote rm origin 删除远程库 再重新关联 若要关联多个远程库比如(github和码云) git remote add github git@github.com:(github仓库地址).git 先关联github git remote add gitee git@github.com:(github仓库地址).git 再关联码云 注意后面的origin需要改为对应的红标内容(代表着远程库名字) 接着 git push -u origin master 把本地库master所有内容推送到远程库上, 第一次提交需要加上参数(-u),后面可简化 出现此内容属于正常,再输入一次上面的push指令即可
出现以下内容时,说明已经推送到github仓库了,以后只需要push一次就够了 **如果从别的文件库上传到一个github仓库** 需要先pull下来 git pull origin master 会自动合并 如果是两个不相关的项目需要加上参数 改为 git pull origin master --allow-unrelated-histories 之后会自动打开vim编辑器 先按 i 切换到插入模式,写完后 Esc→:→wq 回车即可保存退出编辑器 然后再重新 git push -u origin master 即可推送到github 9.从远程库克隆 在github新建一个仓库的时候勾选
然后再本地找到一个合适的地方 git clone git@github.com:(github仓库位置).git 将项目克隆到本地仓库 10创建与合并分支 git branch 查看分支 git branch name 创建分支 git checkout name 或者 git switch name 切换分支 git checkout -b name 或者 git switch -c name 创建并且切换到该分支 git merge name 合并某分支到当前分支 git branch -d name 删除分支 git log --graph --prety=oneline --abbrev-commit 查看所有分支合并信息 11.隐藏当前工作区,提交之前工作修改 例如需要修改分支名字为issue-101的bug 11.1 git stash 隐藏工作区 11.2 git checkout master 切换回需要修改的分支 11.3 git checkout -b issue-101 在改分支下创建临时分支 11.4 修改bug后提交文件 提交时的commitid后面会用到 11.5 git checkout master 切换回master分支 11.6 git merge --no-ff -m ”描述内容” issue-101 完成合并并且删除该分支 11.7 git checkout dev 完成修改切换回之前的分支继续开发 11.8 git stash list 查看之前隐藏的分支 11.9 git stash pop 恢复到之前的工作区并且删除stash的该条信息 11.10 因为dev是从master分支分过来的,所以在dev上同样存在该bug的问题 11.11 git cherry-pick commitid 复制一个特定的提交到当前分支,同时也提交了 12.强制删除某个分支 git branch -D branchName 强制删除某个分支 13.多人协作问题 git remote 或者 git remote -v 查看所有分支信息 git push origin master(改成你要推送的分支) 提交到远程库 13.1 git pull 合并 13.2 如果git pull 提示no tracking information 则说明本地和远程的分支链接关系没有建立 13.3 git branch --set-upstream-to= (分支名字) origin/(分支名字) 13.4 git pull 再更新一遍 13.5 pull成功,但可能会出现冲突,手动解决一下再commit提交,然后再push一遍即可 14标签管理(首先要切换到要创建标签的分支上)标签和commit是挂钩的,如果提交到其他分支则其他分支也是有该标签 git tag v1.0 创建1.0的标签 git tag 查看所有标签 git log --graph --pretty=oneline --abbrev-commit 查看所有commitid git tag v1.0 commitid 给指定commitid打标签 git show v标签 查看对应标签的详细提交信息 git tag -d v标签 删除某个标签 git push origin v标签 推送某个标签到远程库 git push origin --tags 一次性推送本地所有未推送的标签到远程库 git push origin :refs/tags v标签 删除远程库的标签(要先删除本地的标签)