1. 下载 安装 git ( 按默认选项安装即可 )
https://git-scm.com/downloads
2. 设置名字和邮箱
git config --global user.name "mashen"
git config --global user.email "mashenvip@gmail.com"
3. 创建git仓库
git init 当前目录就变成了Git仓库 目录下会多了一个.git文件
------------------------------------------------------------------------------
开始使用git来管理你的文件
4. 添加文件
git add 1.txt
如果提示错误:
warning: LF will be replaced by CRLF in 1.txt.
The file will have its original line endings in your working directory.
原因: windows下换行符的问题
解决:
rm -rf .git // 先删掉当前仓库的git的配置信息
git config --global core.autocrlf false // 禁用自动转换
git init // 重新初始化仓库
5. 提交到版本库
git commit -m "1.txt"
将添加好的文件提交到版本库
-m 是注释说明
6. 查看提交记录
git log
记录中 HEAD 表示的是当前版本 -> 指向的则为分支名 ( mastre 是主分支 )
7. 如果想退回到上一个版本
git reset --hard HEAD^ // HEAD^ 就表示为上一个版本 ( HEAD^^^ 则为上3个版本 也可以上100个 )
8. 也可以通过log中的commit码来回退版本
git reset --hard 3595c6fd7
9. 如果回退后又后悔想返回那么就使用 git reflog 查看更全面的记录日志找到之前的commit码来恢复
------------------------------------------------------------------------------
工作区和暂存区
工作区: 你存放文件的目录 你git init时所在的目录
暂存区: 你git add后暂时存放文件的一个区域
10 .分支 和 HEAD
当你创建一个新的文件时 此文件是无版本控制的 此时文件所在你的项目目录 也就是工作区
当执行git add后文件就被添加到了暂存区
当执行git commit后就是把暂存区的所有内容提交到当前分支也就是版本库里
创建Git版本库 Git会自动创建一个master分支也就是主分支
所以 git commit 就是往master分支上提交更改
可以理解为 需要提交的文件修改通通放到暂存区 然后一次性提交暂存区的所有修改到分支上
11. git status
通过 git status 查看工作区和暂存区文件的状态
git status -s // 查看简明信息
12. 撤销修改
git checkout -- file
git checkout -- 1.txt 就是把1.txt文件在工作区的修改全部撤销 这里有两种情况:
一种是1.txt修改后还没有被放到暂存区 现在撤销修改就回到和版本库一模一样的状态
一种是1.txt已经添加到暂存区后 又作了修改 现在撤销修改就回到刚添加到暂存区时的状态
13. 如果想撤回暂存区的文件
git reset HEAD 1.txt // 则暂存区内的1.txt将被撤回
然后可以在继续使用git checkout -- 1.txt撤回所有对1.txt的修改恢复和版本库一样
14. 删除文件
如果本地文件和版本库不一致
如本地删除了 但版本库没有删除
现在可以做两种操作
一个是恢复删除的文件使用: git checkout -- file
一个是彻底删除就是删除版本库内的文件: 将删除的文件正常add在commit删除
或者直接 git rm 1.txt 删除版本库中的文件
------------------------------------------------------------------------------
分支管理
当初始化仓库时git就会自动创建一个master分支 也就是主分支 所有代码都会被提交到此分支上
HEAD 默认指向master 也就是主分支
HEAD 代表当前分支 一开始只有一条线master分支 HEAD指向的是肯定就是是master
HEAD 指向 master ,master 指向 最新提交点
当我们创建新的分支,例如dev分支时
dev指向和master相同的提交点 ( 也就是最新的版本库 )
这时将HEAD 指向 dev,就表示当前分支在dev上了 因为HEAD表示当前分支
这是提交代码则会被提交到dev分支上
可以理解为分支只是一个标记点 HEAD指向哪个标记点 哪个标记点就是当前分支
15. 查看当前分支
git branch
16. 创建分支
git branch dev
17. 切换分支
git checkout dev
也可以直接创建并切换分支 : git checkout -b dev
18. 合并分支
先回到master分支 将dev分支合并到master
git merge dev
19. 删除分支 ( 合并到主分支后就可以删除多余分支了 )
git branch -d dev
20. git默认使用Fast forward模式来合并分支
这样不会留下分支合并记录 删除分支后,会丢掉分支信息
使用 --no-ff 方式的 git merge 来合并分支
git merge --no-ff -m "merge with no-ff" dev
这样就会生成合并的commit记录
查看分支合并记录
git log --graph --pretty=oneline --abbrev-commit
21. 存储功能
当开发到一半时代码无法commit时 这是需要临时切换分支
此时代码未commit 无法直接切换分支 强制切换可能导致代码丢失
这时可以使用 git stash 将当前状态存储
存储后通过 git stash list 查看存储记录
存储后在进行分支切换就不会报错了
恢复stash
git stash apply stash@{0}
git stash apply 恢复,但是恢复后,stash内容并不删除
你需要用 git stash drop来删除
------------------------------------------------------------------------------
码云远程仓库
22. Git 全局设置
git config --global user.name "mashen"
git config --global user.email "6@ktvll.com"
23. 初始化本地仓库
git init
24. 关联远程仓库
git remote add origin https://gitee.com/thinkxmg/nongfa.git
25. 查看已经关联的远程仓库
git remote -v
26. 删除已经关联的远程仓库
git remote rm origin
27. 提交远程仓库
git push origin master
意思是把当前本地master分支提交到远程的origin分支上
28. 创建远程分支
在本地创建本地分支提交到远程仓库则自动创建一个远程分支
git push origin dev
将本地的dev分支提交到远程的 origin 上 则自动创建远程分支dev
29. 查看全部分支
git branch -a // 包括远程分支
30. 克隆远程版本到本地
git clone 版本库的网址
会在本地主机生成一个目录,与远程主机的版本库同名
如果要指定不同的目录名,可以将目录名作为git clone命令的第二个参数
git clone <版本库的网址> <本地目录名>
31. git fetch : 将远程分支取回到本地
git fetch <远程主机名> // 所有分支
git fetch origin master // 指定分支
32. git pull
git pull命令的作用是,取回远程主机某个分支的更新,再与本地的指定分支合并
git pull <远程主机名> <远程分支名>:<本地分支名>
取回origin主机的next分支,与本地的master分支合并
git pull origin next:master
如果远程分支是与当前分支合并,则冒号后面的部分可以省略
git pull origin next
相当于
git fetch origin
git merge origin/next
无版本控制时 红??
首次添加后 绿 A
有版本控制了 修改未添加 红M
有版本控制了 修改添加后 绿M
2018-03-22
©著作权归作者所有,转载或内容合作请联系作者
- 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
- 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
- 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
推荐阅读更多精彩内容
- 科幻小说写作资料 汇总 http://www.jianshu.com/nb/8692577 2018科幻稿、科幻小...
- 马云说:2018不再打工,投资这个行业人生逆袭,再忙也要看下 我爱我的家园 今天 2018.3.22 马云: 我相...