Git学习笔记(1)
一、Git特点
1.直接快照,而非比较差异
Git只关心文件数据的整体是否发生变化,而不关心具体文件及其内容发生了那些变化。也就是说Git在保存文件时,每次只会在上一次版本基础上保存那些变化的文件,为为变化的文件不会再次被保存。
2.几乎所有的操作都可本地执行
这些操作包括查看历史记录,回滚,对比差异都是直接操作本地数据库,而无须联网。代码提交,更新也无需连接远程库,直接提交到本地仓库,等到有网时才同步到远程库。
二、Git三种状态
已修改(modified):工作区的文件被修改后,为该状态,表明只是修改了工作区的文件。
已暂存(staged):将工作区已修改的文件添加到暂存区(add),这时Git中的文件并没有变化。
已提交(committed):将暂存区文件提交到Git库(commit),为该状态,这时Git库中的文件才被更改。
三、安装Git
windows:直接去git官网上下载客户端安装
Linux,如Ubuntu
apt-get install git
四、初次运行配置
git config --global user.name "jack"
git config --global user.email "123@163.com"
五,创建本地仓库
1.去到一个目录下,执行git init,当前目录下会出现一个.git目录,这里就是git本地仓库
2.从远程git仓库克隆一个到本地
git clone git://github.com/greit.git
本地目录会新建一个"greit"的目录,其中内含一个.git目录,说明已经把远程一个名为greit的git仓库克隆到本地,如果想自定义本地仓库名,在上面的url后加上自定义名称
3.查看当前文件状态,会显示有哪些文件未跟踪,未提交或者工作目录很干净,没有任何变化
git status
六、工作区操作
4.跟踪新文件,也就是将文件纳入git管理
git add [file or dir]
5.暂存已修改的文件,也是用add,git会根据文件状态选择使用add的那个功能
git add [file]
注意:处于暂存状态的文件,如果更改了,需要再次add
6.忽略某些文件
某些文件不想git管理,又不想git老提示未跟踪该文件,就可以选择创建一个.gitignore文件来忽略指定的文件,如
cat .gitignore
*.[oa] #忽略所有以.o或.a结尾的文件
*~ #忽略所有以~结尾的文件
!lib.a #lib.a除外
/TODO #仅忽略项目根目录下的TODO文件,不包括子目录的TODO文件
build/ #忽略build/目录下的所有文件
doc/*.txt #忽略doc目录下所有txt文件,但不包括doc目录的子目录
7.当前文件(已修改未暂存)与暂存区快照之间的差异
git diff
已暂存的文件与上次提交时快照的差异
git diff --cached 或 -- staged
8.提交更新
git commit
9.移除文件,
从暂存区移除并从工作区删除
git rm [file]
从暂存区移除但不从工作区删除
git rm --cached [file]
10.撤销操作
修改最后一次提交,其实就是再次提交的意思
git commit --amend
取消已暂存的文件,让他回到未暂存的状态
git reset HEAD [file]
取消对文件的修改,注意该命令会不会保留刚才的修改,一般建议回退
git checkout -- [file]
记住:任何已经提交到Git的都可以被恢复,包括已删除的分支,只有未提交的才可能找不回来
七.远程仓库
1.更新操作
不合并到当前工作分支:git fetch [远程仓库名]
自动合并到当前工作分支:git pull [远程仓库名]
2.推送操作
git push [远程仓库名] [分支名] #远程仓库名默认origin 分支名默认master
Git学习笔记(1)的更多相关文章
- Git学习笔记与IntelliJ IDEA整合
Git学习笔记与IntelliJ IDEA整合 一.Git学习笔记(基于Github) 1.安装和配置Git 下载地址:http://git-scm.com/downloads Git简要使用说明:h ...
- Git学习笔记(10)——搭建Git服务器
本文主要记录了Git服务器的搭建,以及一些其他的配置,和最后的小总结. Git远程仓库服务器 其实远程仓库和本地仓库没啥不同,远程仓库只是每天24小时开机为大家服务,所以叫做服务器.我们完全可以把自己 ...
- Git学习笔记(四)
一.忽略特殊文件 在Git工作区的根目录下创建一个特殊的.gitignore文件,然后把要忽略的文件名填进去,Git就会自动忽略这些文件. 不需要从头写.gitignore文件,GitHub已经为我们 ...
- git 学习笔记6--remote & log
git 学习笔记6--remote & log 创建SSH Keys ssh-keygen -t rsa -C "1050244110@qq.com" 本地关联远程 git ...
- Git学习笔记---协作的一般流程
一般的操作流程 1.pull 王小坤与另一个同事张大炮一起开发一个项目,张大炮昨天修改了数据库读写的api,优化了执行速度,并把read()函数改名成了Read(),下午下班之前把这些代码push到服 ...
- 【转帖】Git学习笔记 记录一下
本文内容参考了廖雪峰老师的博文,并做了适当整理,方便大家查阅. 原帖地址 https://wangfanggang.com/Git/git/ 常用命令 仓库初始化 - git init 1 git i ...
- [转]Git学习笔记与IntelliJ IDEA整合
Git学习笔记与IntelliJ IDEA整合 一.Git学习笔记(基于Github) 1.安装和配置Git 下载地址:http://git-scm.com/downloads Git简要使用说明:h ...
- GIT学习笔记(1):创建版本库
GIT学习笔记(1):创建版本库 创建版本库 1.创建合适目录并初始化为仓库 版本库即需要交由Git进行版本控制的目录,其下所有文件的修改.删除,Git都能跟踪还原. 说明:初始化后,当前目录下会多出 ...
- GIT学习笔记(5):变基
GIT学习笔记(5):变基rebase 变基 引入变基 在Git中整合来自不同分支的修改主要有两种方法:merge以及rebase. 整合分支最容易的方法是merge,他会把两个分支的最新快照以及两者 ...
- GIT学习笔记(4):远程分支
GIT学习笔记(4):远程分支 远程分支 远程分支是什么 远程分支是对远程仓库中的分支的索引.它们是一些无法移动的本地分支:只有在GIT进行网络交互时才会更新.远程分支就是书签,提醒着你上次连接远程仓 ...
随机推荐
- 刚开始使用idea的朋友,可以看一下下面这篇文章
刚开始使用idea的朋友,可以点击本链接看一下这篇文章 以及这些文章 http://www.jetbrains.com/help/idea/getting-help.html------ Gettin ...
- Mac 配置flutter
1. vim ~/.base_profile 2. 如下 export PATH=/Users/korea/Desktop/development/flutter/bin:$PATH export P ...
- docker清理
# 删除退出的容器docker rm $(docker ps -qa --no-trunc --filter "status=exited") # 删除悬挂镜像docker rmi ...
- 【图像处理与医学图像处理】YUV与RGB格式转换速度几种方法对比
[视频处理]YUV与RGB格式转换 YUV格式具有亮度信息和色彩信息分离的特点,但大多数图像处理操作都是基于RGB格式. 因此当要对图像进行后期处理显示时,需要把YUV格式转换成RGB格式. RGB与 ...
- Go语言中切片的内部实现和基础功能
切片是一种数据结构,这种数据结构便于使用和管理数据集合.切片是围绕动态数组的概念构建的,可以按需自动增长和缩小.切片的动态增长是通过内置函数append来实现的.这个函数可以快速且高效的增长切片.还可 ...
- ZOJ Problem Set - 1008
1.翻译及思路 http://blog.csdn.net/dapengbusi/article/details/7313785 http://acm.sdut.edu.cn/bbs/read.php? ...
- Go语言实例化结构体——为结构体分配内存并初始化
转自: http://c.biancheng.net/view/66.html 结构体的定义只是一种内存布局的描述,只有当结构体实例化时,才会真正地分配内存.因此必须在定义结构体并实例化后才能使用结构 ...
- Gym - 100989 L / M 【dfs / dp】
题目链接:http://codeforces.com/gym/100989/problem/L / http://codeforces.com/gym/100989/problem/M 题目大意:给定 ...
- 设置gridView 行号 行号宽
gridView1.IndicatorWidth=30; //设置行号宽度 //对gridView1的CustomDrawRowIndicator事件进行操作 进行行号显示 private stati ...
- C语言基础练习——最大值及其位置(二维数组)
C语言基础练习——最大值及其位置(二维数组) 时间限制: 1 Sec 内存限制: 10 MB 题目描述 有一个n×m的矩阵,要求编程序求出: 每行元素的最大值,以及其所在的行号和列号.求出所有元素的 ...