Git笔记

Git笔记

会持续更新,内容来自廖雪峰老师的网站,由自己学习整理记录下来

安装

Linux上安装
先输入git,看有没有看装

$ git
The program 'git' is currently not installed. You can install it by typing:
//安装
sudo apt-get install git

创建版本库

$ git init

添加文件到Git仓库,分两步:

  • 第一步,使用命令git add <file>,注意,可反复多次使用,添加多个文件;

  • 第二步,使用命令git commit -m “更新日志”,完成。

版本控制

版本状态

1.查看
//查看仓库当前状态
git status

//查看修改
git diff readme.txt

//提交
git add readme.txt

git status

git commit -m "修改日志"

git status 

在实际工作中,我们脑子里怎么可能记得一个几千行的文件每次都改了什么内容,不然要版本控制系统干什么。版本控制系统肯定有某个命令可以告诉我们历史记录,在Git中,我们用git log命令查看:

$ git log
commit 3628164fb26d48395383f8f31179f24e0882e1e0
Author: Michael Liao <askxuefeng@gmail.com>
Date:   Tue Aug 20 15:11:49 2013 +0800

    append GPL

commit ea34578d5496d7dd233c827ed32a8cd576c5ee85
Author: Michael Liao <askxuefeng@gmail.com>
Date:   Tue Aug 20 14:53:12 2013 +0800

    add distributed

commit cb926e7ea50ad11b8f9e909c05226233bf755030
Author: Michael Liao <askxuefeng@gmail.com>
Date:   Mon Aug 19 17:51:55 2013 +0800

    wrote a readme file

git log命令显示从最近到最远的提交日志,我们可以看到3次提交,最近的一次是append GPL,上一次是add distributed,最早的一次是wrote a readme file
如果嫌输出信息太多,看得眼花缭乱的,可以试试加上--pretty=oneline参数:

commit id(版本号)

2.版本回退

当知道版本号时(通过git log查看),HEAD表示当前版本,上版本就是HEAD^,上上版本是HEAD^^,上一百个版本就是HEAD~100

例如:

$ git reset --hard HEAD^
HEAD is now at ea34578 add distributed

//可以输入版本号来指定版本
$ git reset --hard 3628164
HEAD is now at 3628164 append GPL

如果回退版本后悔了,找不到commit id时,用git reflog用来记录你每一次命令

$ git reflog
ea34578 HEAD@{0}: reset: moving to HEAD^
3628164 HEAD@{1}: commit: append GPL
ea34578 HEAD@{2}: commit: add distributed
cb926e7 HEAD@{3}: commit (initial): wrote a readme file

撤销修改

撤销文件在工作区的全部修改
中的–很重要,没有就是切换分支

git checkout -- file

如果已经git add到缓存区,撤销用git reset

git reset HEAD file

删除文件

//删除文件
rm test.txt

//查看删除那些文件,
//这时工作区和版本库状态不一致
git status 

现在你有两个选择,一是确实要从版本库中删除该文件,那就用命令git rm删掉,并且git commit:

git rm test.txt
rm 'test.txt'
$ git commit -m "remove test.txt"

另一种情况是删错了,因为版本库里还有呢,所以可以很轻松地把误删的文件恢复到最新版本:

$ git checkout -- test.txt

远程仓库

远程仓库已经准备好,使用git clone克隆一个本地库

$ git clone git@github.com:michaelliao/gitskills.git

$ cd gitskills
$ ls

分支管理

当我们创建新的分支,例如dev时,Git新建了一个指针叫dev,指向master相同的提交,再把HEAD指向dev,就表示当前分支在dev上:

假如我们在dev上的工作完成了,就可以把dev合并到master上。Git怎么合并呢?最简单的方法,就是直接把master指向dev的当前提交,就完成了合并:

创建分支

创建dev分支,然后切换到dev分支

$ git checkout -b dev
//参数 -b 表示创建并切换,相当于如下两行

$ git branch dev
$ git checkout dev 

查看分支

查看分支,当前分之前有一个*号

$ git branch
* dev
master

合并分支

合并某分支到当前分支

git merge <name>

删除分支

git branch -d <name>

解决冲突

git merge featurel
Auto-merging readme.txt
CONFLICT (content): Merge conflict in readme.txt
Automatic merge failed; fix conflicts and then commit the result.

出现冲突用 git status

Git has a mutable index called stage.
Git tracks changes of files.
<<<<<<< HEAD
Creating a new branch is quick & simple.
=======
Creating a new branch is quick AND simple.
>>>>>>> feature1

Git用<<<<<<<=======>>>>>>>标记出不同分支的内容,我们修改如下后保存:

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值