使用分支进行开发
以当前代码为基础创建并切换分支,推送分支到资源库
git checkout -b report
git push --set-upstream origin report
git clone submodule项目
git clone 主项目
git submodule init
git submodule update
创建新的分支
git checkout -b formview
切换到主分支:
首先
git checkout -b temp
其次
git checkout master
解决window换行符提示出错问题:
git config --global core.autocrlf input
git迁移仓库
把原来仓库内容获取出来
git clone --bare https://gitee.com/zhy6599/cc-admin-api.git
git clone --bare https://gitee.com/zhy6599/cc-admin-web.git
推送到新仓库
cd cc-admin-api.git
git push --mirror http://gitee.com/zhy6599/platform/quasar-api.git
cd cc-admin-web.git
git push --mirror http://gitee.com/zhy6599/platform/quasar-web.git
window下迁出代码后提示:Expected linebreaks to be 'LF' but found 'CRLF'
管理员身份运行cmd
git config --global core.autocrlf input
放弃本地更改,将文件强制更新到服务器最新版本
git fetch --all
git reset --hard origin/master
说明:git fetch 只是下载远程的库的内容,不做任何的合并 git reset 把HEAD指向刚刚下载的最新的版本
git clean -df
删除当前目录下没有被track过的文件和文件夹
git clean -xf
删除当前目录下所有没有track过的文件. 不管他是否是.gitignore文件里面指定的文件夹和文件
git reset --hard
git clean -f
结合使用他们能让你的工作目录完全回退到最近一次commit的时候
查看历史提交信息,并将代码回滚到指定版本
git log -3
git reset --hard 832fbe05c333c47bd1c2a766946103791f10c4ed
git push -f
在.git 文件夹同级目录建立文件 .gitignore 用来忽略掉不应该提交的代码
# maven ignore
target/
!.mvn/wrapper/*
*.war
*.zip
*.tar
*.tar.gz
# eclipse ignore
.settings/
.project
.classpath
# idea ignore
.idea/
*.ipr
*.iml
*.iws
.iml
# temp ignore
logs/
*.log
*.log*
*.log.*
*.cache
*.diff
*.patch
*.tmp
# system ignore
.DS_Store
Thumbs.db
git 分支操作命令
查看服务器端所有分支
git branch -a
查看本地分支
git branch
创建本地分支
git branch 分支名称
把本地分支和远程分支之间建立关联,然后才能push
git push --set-upstream origin 分支名称
强制推送:如果之前已经推送过一次,但是推送失败了,可以使用 git push --force origin dev 强制推送。
git push --force origin dev
将指定分支合并到当前分支
git merge [branch-name]
删除本地分支
git branch -d
从远程仓库拉取更新到本地分支。
git pull origin [branch-name]
撤销指定提交
git revert [commit-hash]
重置指定分支到上一个提交状态
git reset [branch-name]
创建并切换到新分支
git checkout -b [new-branch-name]
把服务器端分支拉回来
git pull
本地切换到另外一个分支
git checkout 分支名
git 记住账号和密码
git config --global credential.helper store
CR、LF、CR/LF为不同操作系统上使用的换行符:
- Windows/DOS系统:采用CR/LF表示下一行;
- Unix/Linux系统:采用LF表示下一行;
- Mac OS系统:采用CR表示下一行;
- Mac OS X系统:采用LF表示下一行(Mac OS X已经改成和Unix/Linx一样使用LF)。
-
Git默认在提交时将Windows换行符(CRLF)转换为LF,在拉取时将UNIX换行符(LF)替换成CRLF。
-
为了保持代码一致,政务项目统一使用
LF
作为唯一换行符。
git 配置
-
关闭换行符自动转换功能
// 提交检出均不转换 git config --global core.autocrlf false
-
开启换行符检查功能
// 拒绝提交包含混合换行符的文件 git config --global core.safecrlf true // 允许提交包含混合换行符的文件 git config --global core.safecrlf false // 提交包含混合换行符的文件时给出警告 git config --global core.safecrlf warn
以下内容出自:https://www.jianshu.com/p/f79ae362ef9e
Git 可以大概分为三个区
Git 本地数据管理,大概可以分为三个区,工作区,暂存区和版本库。
- 工作区(Working Directory)
是我们直接编辑的地方,例如 Android Studio 打开的项目,记事本打开的文本等,肉眼可见,直接操作。 - 暂存区(Stage 或 Index)
数据暂时存放的区域,可在工作区和版本库之间进行数据的友好交流。 - 版本库(commit History)
存放已经提交的数据,push 的时候,就是把这个区的数据 push 到远程仓库了。
下面是,当开发者通过 git 修改数据时,各区之间的数据传递流程示意图。
为了验证以上流程的正确性,我们可以自己动手实验一下,为了对比三个区之间的数据差别,过程中,可以借助神奇的 diff 命令。
命令 | 作用 |
---|---|
git diff | 工作区 vs 暂存区 |
git diff head | 工作区 vs 版本库 |
git diff --cached | 暂存区 vs 版本库 |
命令 | 作用 |
---|---|
git reset --soft | 暂存区->工作区 |
git reset --mixed | 版本库->暂存区 |
git reset --hard | 版本库->暂存区->工作区 |
原文链接:https://blog.youkuaiyun.com/stone_yw/article/details/80795669
1 git stash
能够将所有未提交的修改(工作区和暂存区)保存至堆栈中,用于后续恢复当前工作目录。
2 git stash save
作用等同于git stash,区别是可以加一些注释
3 git stash list
查看当前stash中的内容
4 git stash pop
将当前stash中的内容弹出,并应用到当前分支对应的工作目录上。
注:该命令将堆栈中最近保存的内容删除(栈是先进后出)
5 git stash apply
将堆栈中的内容应用到当前目录,不同于git stash pop,该命令不会将内容从堆栈中删除,也就说该命令能够将堆栈的内容多次应用到工作目录中,适应于多个分支的情况。
6 git stash drop + 名称
从堆栈中移除某个指定的stash
7 git stash clear
清除堆栈中的所有 内容
8 git stash show
查看堆栈中最新保存的stash和当前目录的差异。
通过 git stash show -p 查看详细的不同
9 git stash branch
从最新的stash创建分支。
应用场景:当储藏了部分工作,暂时不去理会,继续在当前分支进行开发,后续想将stash中的内容恢复到当前工作目录时,如果是针对同一个文件的修改(即便不是同行数据),那么可能会发生冲突,恢复失败,这里通过创建新的分支来解决。可以用于解决stash中的内容和当前目录的内容发生冲突的情景。
发生冲突时,需手动解决冲突。
vscode git 总提示输入账号密码,在仓库根目录输入命令然后拉取下,输入账号密码,重启vscode
git config --global credential.helper store