git入门笔记一
2015-08-11 22:18
232 查看
注:本文是学习git的笔记,内容归纳、摘自 廖雪峰的官方网站 上的这篇文章。这篇文章写得非常不错!
地址: http://www.liaoxuefeng.com/wiki/0013739516305929606dd18361248578c67b8067c8c017b000/
注意
$mkdir learngit
$cd learngit
第二步,通过 git init 命令把这个目录变成git可以管理的仓库:
$git init
当前目录下就会多出一个 .git 目录,这个目录是git 来跟踪管理版本库的。另外,这个目录是隐藏的,用 ls -ah 命令就可以看到。
(2)用命令 git add 告诉git ,把文件添加到仓库:
$git add readme.txt
(3)用命令 git commit 告诉git, 把文件提交到仓库:
$git commit -m "wrote a readme file"
add 可以一次性添加多个文件。
git diff 命令可以查看当前目录和版本库差异。
如果嫌输出信息太多,看得眼花缭乱的,可以试试加上
比如:
前面一大串的字符是 commit id(版本号),是一个sha1 计算出来的一个非常大的数字,用十六进制表示。
在Git中,用
现在,我们要把当前版本“append GPL”回退到上一个版本“add distributed”,就可以使用
穿梭前,用
要重返未来,用
Git的版本库里存了很多东西,其中最重要的就是称为stage(或者叫index)的暂存区,还有Git为我们自动创建的第一个分支
前面讲了我们把文件往Git版本库里添加的时候,是分两步执行的:
第一步是用
第二步是用
因为我们创建Git版本库时,Git自动为我们创建了唯一一个
你可以简单理解为,需要提交的文件修改通通放到暂存区,然后,一次性提交暂存区的所有修改。
地址: http://www.liaoxuefeng.com/wiki/0013739516305929606dd18361248578c67b8067c8c017b000/
一、git 安装后的配置
$ git config --global user.name "Your Name"
$ git config --global user.email "email@example.com"
注意
git config命令的
--global参数,用了这个参数,表示你这台机器上所有的Git仓库都会使用这个配置,当然也可以对某个仓库指定不同的用户名和Email地址。
二、创建版本库
创建一个版本库非常简单,首先,选择一个合适的地方,创建一个空目录:$mkdir learngit
$cd learngit
第二步,通过 git init 命令把这个目录变成git可以管理的仓库:
$git init
当前目录下就会多出一个 .git 目录,这个目录是git 来跟踪管理版本库的。另外,这个目录是隐藏的,用 ls -ah 命令就可以看到。
三、把文件加入版本库
(1)进入 learngit 目录,创建一个文件,比如 readme.txt(2)用命令 git add 告诉git ,把文件添加到仓库:
$git add readme.txt
(3)用命令 git commit 告诉git, 把文件提交到仓库:
$git commit -m "wrote a readme file"
-m后面输入的是本次提交的说明,可以输入任意内容,当然最好是有意义的,这样你就能从历史记录里方便地找到改动记录。
add 可以一次性添加多个文件。
四、查看版本状态
git status 命令可以查看仓库当前的状态。git diff 命令可以查看当前目录和版本库差异。
五、查看版本提交记录及回退版本
git log 命令可以用于查看版本提交历史记录。如果嫌输出信息太多,看得眼花缭乱的,可以试试加上
--pretty=oneline参数:
比如:
$ git log --pretty=oneline 3628164fb26d48395383f8f31179f24e0882e1e0 append GPL ea34578d5496d7dd233c827ed32a8cd576c5ee85 add distributed cb926e7ea50ad11b8f9e909c05226233bf755030 wrote a readme file
前面一大串的字符是 commit id(版本号),是一个sha1 计算出来的一个非常大的数字,用十六进制表示。
在Git中,用
HEAD表示当前版本,也就是最新的提交
3628164...882e1e0,上一个版本就是
HEAD^,上上一个版本就是
HEAD^^,当然往上100个版本写100个
^比较容易数不过来,所以写成
HEAD~100。
现在,我们要把当前版本“append GPL”回退到上一个版本“add distributed”,就可以使用
git reset命令:
$ git reset --hard HEAD^ HEAD is now at ea34578 add distributed
HEAD指向的版本就是当前版本,因此,Git允许我们在版本的历史之间穿梭,使用命令
git reset --hard commit_id。
穿梭前,用
git log可以查看提交历史,以便确定要回退到哪个版本。
要重返未来,用
git reflog查看命令历史,以便确定要回到未来的哪个版本。
六、工作区和暂存区的概念
我们的gitlearn 文件夹就是一个工作区。工作区有一个隐藏目录.git,这个不算工作区,而是Git的版本库
Git的版本库里存了很多东西,其中最重要的就是称为stage(或者叫index)的暂存区,还有Git为我们自动创建的第一个分支
master,以及指向
master的一个指针叫
HEAD。
前面讲了我们把文件往Git版本库里添加的时候,是分两步执行的:
第一步是用
git add把文件添加进去,实际上就是把文件修改添加到暂存区;
第二步是用
git commit提交更改,实际上就是把暂存区的所有内容提交到当前分支。
因为我们创建Git版本库时,Git自动为我们创建了唯一一个
master分支,所以,现在,
git commit就是往
master分支上提交更改。
你可以简单理解为,需要提交的文件修改通通放到暂存区,然后,一次性提交暂存区的所有修改。
相关文章推荐
- JSP调用存储过程
- EasyDarwin开源流媒体服务器提供的TS切片/HLS直播打包库
- 使用Wiz为博客园写博客
- STM32窗口看门狗_原子战舰WWDG例程学习笔记
- iOS Segment带滑动条切换效果
- bash环境
- UINavigationBar & UINavigationItem
- Win7环境下JDK的安装与配置
- 剑指offer第31题 连续子数组最大和
- java学习阶段三:运算符和结构学习
- 分布式中使用Redis实现Session共享(一)
- 视图UIView的frame、bounds与center属性
- ubuntu10.04 使用apt-get 安装LAMP环境
- (一一七)基本文件操作 -SDWebImage清除缓存 -文件夹的大小计算
- gst-omax编译
- 浅析error LNK2001: unresolved external symbol
- 大文件的切割与合并
- ACM比赛注意事项
- 蓝牙4.0/BLE协议栈学习笔记(一)
- 正则表达式简单语法使用总结一