git多人协作--分支

分支:

创建分支:

git checkout -b 新分支

切换分支:

git checkout 目标分支

删除分支:

git branch -d 待删除分支

 

 

推送到远程分支:

git checkout -b dev
// git pull 提示 (如果gitlab没有dev)
git branch --set-upstream-to=origin/dev dev

git push --set-upstream origin dev  // git push (如果gitlab有dev)

 

 

===

git checkout -b dev origin/dev
git push

 

===

在原来项目基础上进行开发的时候,首先从gitLib拉取代码,合并的当地分支,然后才进行开发 

git pull origin master    
git merge dev  (当前分支合并dev分支)

 ====

如果提交远程仓库后,发现需要回滚远程仓库版本:

git reset --hard HEAD^  // 回滚最后一次提交
git push -f origin dev  // 强制提交

https://blog.csdn.net/jackyzheng/article/details/76672921

https://www.cnblogs.com/iloveyou-sky/p/6534409.html

删除.idea目录:

// 将.idea目录加入ignore清单:
echo '.idea' >> .gitignore
// 从git中删除idea:
git rm --cached -r .idea
// 将.gitignore文件加入git:
git add .gitignore
// Commit gitignore文件,将.idea从源代码仓库中删除:
git commit -m '(gitignore commit and remove .idea)'
// Push到服务器:
git push

同理:.DS_Store

使用 Mac 的用户可能会注意到,系统经常会自动在每个目录生成一个隐藏的 .DS_Store 文件。.DS_Store(英文全称 Desktop Services Store)是一种由苹果公司的Mac OS X操作系统所创造的隐藏文件,目的在于存贮目录的自定义属性,例如文件们的图标位置或者是背景色的选择。相当于 Windows 下的 desktop.ini。

删除 .DS_Store

如果你的项目中还没有自动生成的 .DS_Store 文件,那么直接将 .DS_Store 加入到 .gitignore 文件就可以了。如果你的项目中已经存在 .DS_Store 文件,那就需要先从项目中将其删除,再将它加入到 .gitignore。如下:

// 删除项目中的所有.DS_Store。这会跳过不在项目中的 .DS_Store
1.find . -name .DS_Store -print0 | xargs -0 git rm -f --ignore-unmatch
// 将 .DS_Store 加入到 .gitignore
2.echo .DS_Store >> ~/.gitignore
// 更新项目
3.git add --all
4.git commit -m '.DS_Store banished!'

如果你只需要删除磁盘上的 .DS_Store,可以使用下面的命令来删除当前目录及其子目录下的所有.DS_Store 文件:

find . -name '*.DS_Store' -type f -delete

禁用或启用自动生成

禁止.DS_store生成:

defaults write com.apple.desktopservices DSDontWriteNetworkStores -bool TRUE

恢复.DS_store生成:

defaults delete com.apple.desktopservices DSDontWriteNetworkStores

 

 

忽略被提交过的.idea文件夹

可能你发现即使你设置了ignore也没起作用,那怎么办呢,跟着我实现下去就可以让忽略起作用了,我用的是idea。

第一步:点开下面的Terminal

第二步:敲入 git rm -r --cached .idea (要是报错,就试一下git rm  --cached .idea -r)

第三步:敲入 git commit -m"删除不需要的文件夹"

第四步:push你的项目,是push。

第五步:这个时候验证你的忽略是否已经起作用了呢^_^

也在网上找了好多解决方案,但是毫无疑问,全是不管用,还得说自己动手。

单独合并某一个提交到master:

cherry-pick某一个分支代码

切换到master分支: git cherry-pick commit_id

 

撤销此次add,且未commit[常用]

git reset HEAD~
git reset HEAD filename ``// 撤销某个文件

撤销此次commit ,保留add[常用]

git reset --soft HEAD~

撤销此次commit 和 add【常用】(不删除工作空间改动代码

git reset HEAD~
or
git reset --mixed HEAD~

 

git stash 临时存储与恢复

参考:https://www.jianshu.com/p/16adec527aed

如果有新文件:https://www.cnblogs.com/jintaostudy/p/6136741.html

 

 
posted @ 2018-08-08 11:59  静静别跑  阅读(564)  评论(0编辑  收藏  举报