2018-03-22

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









©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 205,033评论 6 478
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 87,725评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 151,473评论 0 338
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,846评论 1 277
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,848评论 5 368
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,691评论 1 282
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,053评论 3 399
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,700评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 42,856评论 1 300
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,676评论 2 323
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,787评论 1 333
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,430评论 4 321
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,034评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,990评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,218评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,174评论 2 352
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,526评论 2 343

推荐阅读更多精彩内容