Git常规使用笔记及注意事项了解一下

摘要:本文总结了平时在开发中常用的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管理分支和合并分支的运用

  1. 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

猜你喜欢

转载自blog.csdn.net/jun5753/article/details/80898260