摘要:本文总结了平时在开发中常用的git命令和使用过程中的注意事项,如设置忽略文件、git代码管理,冲突解决,如何保存工作区,分支管理等等,如有不足之处,请指正。
先用一张图来说明git的工作流程:
名词解释:
Workspace:工作区
Index / Stage:暂存区
Repository:仓库区(或本地仓库)
Remote:远程仓库
1.先在Git中仓库建立
可在github中或码云中搭建 或自己搭建服务器
# 新建一个目录,将其初始化为Git代码库
$ git init [project-name]# 下载一个项目和它的整个代码历史
$ git clone [url]
注意设置忽略上传的文件
过滤掉一些文件或文件夹,那么被过滤的内容就不会被git管理,比如:
build/: 过滤整个build文件夹;
*.class: 过滤所有.class后缀的文件;
path/to/local.properties: 过滤具体文件
.gitignore还可以指定哪些文件添加到版本管理中,添加规则:
!build/ : 添加整个文件夹;
!*.class: 添加所有.class后缀的文件;
!path/to/local.properties: 添加具体文件
在github用一个专门为各个平台提供的gitignore的写法
传送门:https://github.com/github/gitignore
Android.gitignore内容预览
# Built application files
*.apk
*.ap_
# Files for the ART/Dalvik VM
*.dex
# Java class files
*.class
# Generated files
bin/
gen/
out/
# Gradle files
.gradle/
build/
# Local configuration file (sdk path, etc)
local.properties
# Proguard folder generated by Eclipse
proguard/
# Log Files
*.log
# Android Studio Navigation editor temp files
.navigation/
# Android Studio captures folder
captures/
# IntelliJ
*.iml
.idea/workspace.xml
.idea/tasks.xml
.idea/gradle.xml
.idea/assetWizardSettings.xml
.idea/dictionaries
.idea/libraries
.idea/caches
# Keystore files
# Uncomment the following line if you do not want to check your keystore files in.
#*.jks
# External native build folder generated in Android Studio 2.2 and later
.externalNativeBuild
# Google Services (e.g. APIs or Firebase)
google-services.json
# Freeline
freeline.py
freeline/
freeline_project_description.json
# fastlane
fastlane/report.xml
fastlane/Preview.html
fastlane/screenshots
fastlane/test_output
fastlane/readme.md
但有时会出现.gitignore中增加了过滤规则但是不起作用的情况。多半是由于在创建.gitignore文件或添加一些过滤规则之前就track了相应的内容,那么即使在.gitignore文件中写入新的过滤规则,这些规则也不会起作用,Git仍然会对这些文件进行版本管理。简单来说出现这种问题的原因就是Git已经开始管理这些文件了,所以你无法再通过过滤规则过滤它们。
这个时候解决方法就是先把本地这些文件变成未track状态,具体来说就是在缓存里删除它们,然后提交:
git rm -r --cached .
git add .
git commit -m 'update .gitignore'
2.团队协作开发
先从服务中clone一个分支的代码,如master中 clone
- git clone xxx
代码提交 时先commit 后pull 此时如果有冲突,先解决冲突,合并最新代码后pull
注意协同开发时记得使用的顺序:commit—>pull–>push
说明:
commit 提交本地代码
pull:拉取服务器最新的代码,此时与commit提交的代码进合并操作merge,如果有冲突,必须先解决代码冲突
push:冲突解决后再代码上传到远程服务器
详细命令如下:
git stash
保存当前工作进度,会把暂存区和工作区的改动保存起来。执行完这个命令后,在运行git status命令,就会发现当前是一个干净的工作区,没有任何改动。使用git stash save ‘message…’可以添加一些注释
git stash list
显示保存进度的列表。也就意味着,git stash命令可以多次执行。
git stash pop [–index] [stash_id]
• git stash pop 恢复最新的进度到工作区。git默认会把工作区和暂存区的改动都恢复到工作区。
• git stash pop --index 恢复最新的进度到工作区和暂存区。(尝试将原来暂存区的改动还恢复到暂存区)
• git stash pop stash@{1}恢复指定的进度到工作区。stash_id是通过git stash list命令得到的
通过git stash pop命令恢复进度后,会删除当前进度。
git stash apply [–index] [stash_id]
git stash drop [stash_id]
删除一个存储的进度。如果不指定stash_id,则默认删除最新的存储进度。
git stash clear
删除所有存储的进度。
使用实例:
3. 分支管理
权限管理,代码合并,Git在Android Studio管理分支和合并分支的运用
- Android Studio中如何新建分支?
如图所示:VCS->Git->Branches->New Branch
点击New Branch,输入分支名,如“branch1”
点击OK后,就会切换到你新创建的分支里。
可用Git命令查看当前分支状态。 执行 git branch
另: git branch -l :查看本地分支
git branch -r :查看远程分支
git branch -a :查看全部分支,包括远程的和本地的( -a 其实就是 all 的意思)
也可以在AS中直接查看分支状态
# 列出所有本地分支
$ git branch
# 列出所有远程分支
$ git branch -r
# 列出所有本地分支和远程分支
$ git branch -a
# 新建一个分支,但依然停留在当前分支
$ git branch [branch-name]# 新建一个分支,并切换到该分支
$ git checkout -b [branch]# 新建一个分支,指向指定commit
$ git branch [branch] [commit]# 新建一个分支,与指定的远程分支建立追踪关系
$ git branch --track [branch] [remote-branch]# 切换到指定分支,并更新工作区
$ git checkout [branch-name]# 建立追踪关系,在现有分支与指定的远程分支之间
$ git branch --set-upstream [branch] [remote-branch]# 合并指定分支到当前分支
$ git merge [branch]# 选择一个commit,合并进当前分支
$ git cherry-pick [commit]# 删除分支
$ git branch -d [branch-name]# 删除远程分支
$ git push origin --delete [branch-name]
$ git branch -dr [remote/branch]
标签管理
# 列出所有tag
$ git tag
# 新建一个tag在当前commit
$ git tag [tag]# 新建一个tag在指定commit
$ git tag [tag] [commit]# 删除本地tag
$ git tag -d [tag]# 删除远程tag
$ git push origin :refs/tags/[tagName]# 查看tag信息
$ git show [tag]# 提交指定tag
$ git push [remote] [tag]# 提交所有tag
$ git push [remote] --tags
# 新建一个分支,指向某个tag
$ git checkout -b [branch] [tag]
撤销
恢复暂存区的指定文件到工作区
$ git checkout [file]# 恢复某个commit的指定文件到工作区
$ git checkout [commit] [file]# 恢复上一个commit的所有文件到工作区
$ git checkout .# 重置暂存区的指定文件,与上一次commit保持一致,但工作区不变
$ git reset [file]# 重置暂存区与工作区,与上一次commit保持一致
$ git reset --hard
# 重置当前分支的指针为指定commit,同时重置暂存区,但工作区不变
$ git reset [commit]# 重置当前分支的HEAD为指定commit,同时重置暂存区和工作区,与指定commit一致
$ git reset --hard [commit]# 重置当前HEAD为指定commit,但保持暂存区和工作区不变
$ git reset --keep [commit]# 新建一个commit,用来撤销指定commit
# 后者的所有变化都将被前者抵消,并且应用到当前分支
$ git revert [commit]
问题思考:
如何切换当前的代码是分支状态?比如:develop->master,或master->develop
问题收集:
后续再完善~~~
参考资料:
git常用命令
http://www.ruanyifeng.com/blog/2015/12/git-cheat-sheet.html
使用git stash命令保存和恢复进度
https://blog.csdn.net/daguanjia11/article/details/73810577
git注意事项
https://blog.csdn.net/a409051987/article/details/62228622