美文网首页
2018-03-22

2018-03-22

作者: mashen | 来源:发表于2018-03-26 16:10 被阅读0次
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

      本文链接:https://www.haomeiwen.com/subject/pqmoqftx.html