1、常见的代码提交 更新

git status 查看代码状态 如果有爆红 则add
git add . 添加
git commit -m"更新内容备注" 提交
git pull 拉取
git push 提交

git branch 获取所在分支名
git branch -a 获取所有分支名
git branch -all 获取所有分支名
git config --list 获取当前登录的账号信息
git remote -v 获取项目所连仓库链接

2、从git上拉取整个项目到本地

(1)新建文件夹
(2)在文件夹中右键 Git Bash Here
(3)输入命令
git initgit clone 项目地址

  • 项目过大时候会clone失败
$ git clone http://git.qidianzhuyun.cn/nwf/nwf-android.git
Cloning into 'nwf-android'...
remote: Enumerating objects: 6106, done.
remote: Counting objects: 100% (6106/6106), done.
error: 
fatal: the remote end hung up unexpectedly
fatal: protocol error: bad pack header

尝试网上说的增大缓存区:
可扩大postBuffer值
git config --global http.postBuffer 524288000 524288000代表B,524288000B也就是500MB。这个值得大小,可以根据项目酌情设置。
查看是否设置成功
git config --list

增大缓存区后我这里依旧无法clone

于是采用了先克隆最新版本的下来 即浅克隆:
step 1: 浅克隆
git clone --depth 1 项目地址 浅克隆存在的问题:
浅克隆只会把默认分支clone下来,其他远程分支并不在本地,所以需要如下操作:
使用studio打开浅克隆下来的项目,在Terminal中使用命令:
step2: cd 到新下载的项目根目录
cd xxxxxxx

step3: 设置远程要拉取的地址
git remote set-branches origin 分支名称

step4: 浅克隆下载此分支
git fetch --depth 1 origin 分支名称

step5:切换到分支
git checkout 分支名称

3、git将某个分支的代码完全覆盖另一个分支

(1) 假设每个人有个开发分支,想隔一段时间就把自己的开发分支上的代码保持和测试分支一致,则需要如下操作:

1.我想将develop分支上的代码完全覆盖release分支,首先切换到release分支
git checkout release 2.然后直接设置代码给远程的develop分支上的代码
git reset --hard origin/develop

3.执行上面的命令后release分支上的代码就完全被develop分支上的代码覆盖了,注意只是本地分支,这时候还需要将本地分支强行推到远程分支。
git push -f

(2)方法二:
首先拉取代码到本地:git pull origin release 合并develop代码到release:git merge develop

git status
git add .
git commit -m"合并分支"

4、查询两个分支代码的区别

git diff release develop --stat //显示出所有有差异的文件列表

5、开发过程中需要保留某个版本的代码

git tag -a v2.0.6 -m"版本2.0.6" 保存该版本代码并设置名称
git tag 查看版本名
git push origin v2.0.6 提交该版本
然后再git后台查看该版本:

java 获取gitlab代码分支相较于master增量代码行数 git 获取最新代码_缓存

6、创建新的分支

1.创建本地分支
git branch develop 2.切换到新创建的分支
git checkout develop 3.将新分支push到github
git push origin develop

7、更换账号

在原来已连接git的基础上更换账号

8、git回滚到之前某次commit

查看所有commits记录: git log 回退到某次commit : git reset --hard 目标版本号 强制重新提交到远程: git push -f