git常用命令
开始的时候
git config --global user.name "Your Name"
git config --global user.email "email@example.com"
查看你的信息
git config --list
克隆仓库
git clone [url]
版本库
mkdir learngit
cd learngit
pwd
/Users/michael/learngit
初始化:
git init
文件添加到版本库
#创建文件
vim readme.txt
cat readme.txt
Git is a version control system.
Git is free software.
#文件添加到仓库
git add readme.txt
#把文件提交到仓库
git commit -m "wrote a readme file"
跳过使用暂存区(不适用git add)
git commit -a -m "说明的文字" 只需要加个-a选项
查看状态
git status #查看状态
git diff readme.txt #比较文件上次修改的东西,,比较当前工作目录中的文件和暂存区域快照之间的差异,只是显示尚未暂存的改动
git diff --cached #已经暂存的将要添加到下次提交里的内容
git status
[root@pup learngit]# git status
# On branch master
nothing to commit (working directory clean)
修改文件后在查看
[root@pup learngit]# vim readme.txt
[root@pup learngit]# git status
# On branch master
# Changed but not updated:
# (use "git add <file>..." to update what will be committed)
# (use "git checkout -- <file>..." to discard changes in working directory)
#
# modified: readme.txt
#
# Untracked files:
# (use "git add <file>..." to include in what will be committed)
#
# .readme.txt.swp
no changes added to commit (use "git add" and/or "git commit -a")
[root@pup learngit]# git diff readme.txt
diff --git a/readme.txt b/readme.txt
index 4dfbf00..a6cb86a
--- a/readme.txt
+++ b/readme.txt
@@ -, +, @@
Git is a distributed version control system.
Git is free software distributed under the GPL
-
+
移除文件(从暂存区中移除)
git rm 文件 #会连带从工作目录中删除指定的文件
git rm -f 文件 #删除之前修改过并且已经放到暂存区域的文件,不可恢复
git rm --cached 文件 #从暂存区域移除但是文件依然保留在当前工作目录中
移动文件(给文件改名字)
git mv README.md README
相当于
$ mv README.md README
$ git rm README.md
$ git add README
版本回退
git log #命令显示从最近到最远的提交日志
git log --pretty=oneline #简洁的显示
git log -p -2 #-p 每次提交的内容差异,-2最近两次提交
在Git中,用HEAD表示当前版本,上一个版本就是HEAD^,上上一个版本就是HEAD^^,一般写成HEAD~
git reset --hard HEAD^ #回退到上一个版本
git reflog查看命令历史,以便确定要回到未来的哪个版本
回退:
git reset --hard commit_id
回到未来
git reset --hard commit_id
定制要显示的记录格式
git log --pretty=format 格式 例如: git log --pretty=format:"%h - %an, %ar : %s"

工作区和暂存区概念理解
git add命令实际上就是把要提交的所有修改放到暂存区(Stage),然后,执行git commit就可以一次性把暂存区的所有修改提交到分支。
前面讲了我们把文件往Git版本库里添加的时候,是分两步执行的: 第一步是用git add把文件添加进去,实际上就是把文件修改添加到暂存区; 第二步是用git commit提交更改,实际上就是把暂存区的所有内容提交到当前分支。
从来没被添加过的文件状态是Untracked
具体过程如下:
刚开始:参考这里

文件修改提交

最后

撤销修改
1,当你改乱了工作区某个文件的内容,想直接丢弃工作区的修改时
git checkout -- file
git checkout -- readme.txt
2当你不但改乱了工作区某个文件的内容,还添加到了暂存区时,想丢弃修改,返回到以前的工作区的内容
git reset HEAD 文件 #从暂存区返回到工作区
3提交了(commit)了但是可能漏了几个文件没有(add)添加或者提交信息写错了,这是运行
git commit --amend #尝试重新提交
eg
$ git commit -m 'initial commit'
$ git add forgotten_file
$ git commit --amend
最终你只会有一个提交 - 第二次提交将代替第一次提交的结果。
git常用命令的更多相关文章
- git常用命令(持续更新中)
git常用命令(持续更新中) 本地仓库操作git int 初始化本地仓库git add . ...
- Git 常用命令详解
Git 是一个很强大的分布式版本管理工具,它不但适用于管理大型开源软件的源代码(如:linux kernel),管理私人的文档和源代码也有很多优势(如:wsi-lgame-pro) Git 的更多介绍 ...
- Git 常用命令大全
Git常用操作命令: 1) 远程仓库相关命令 检出仓库:$ git clone git://github.com/jquery/jquery.git 查看远程仓库:$ git remote -v 添加 ...
- Git常用命令总结
Git常用命令总结 git init 在本地新建一个repo,进入一个项目目录,执行git init,会初始化一个repo,并在当前文件夹下创建一个.git文件夹. git clone ...
- GIT常用命令备忘
Git配置 git config --global user.name "storm" git config --global user.email "stormzhan ...
- Git 常用命令2
Git 常用命令 Git 是一个很强大的分布式版本控制系统.它不但适用于管理大型开源软件的源代码,管理私人的文档和源代码也有很多优势. Git常用操作命令: 1) 远程仓库相关命令 检出仓库:$ gi ...
- git常用命令-基本操作
git常用命令-基本操作 1) 新增文件 新增了Test_1.java git add Test_1.java git commit –m “新增了Test_1.java” git push ...
- 转收藏:Git常用命令速查表
一. Git 常用命令速查 git branch 查看本地所有分支git status 查看当前状态 git commit 提交 git branch -a 查看所有的分支git branch -r ...
- git常用命令,git版本控制和Xcode结合使用,用Xcode提交到github,github客户端使用
1.git常用命令 查看命令: 1.git --help 查看git所有命令 2.git clone -help 查看git clone命令的细节 3.git config -l 查看当前所有配置 ...
- Git 常用命令详解(二)
Git 是一个很强大的分布式版本管理工具,它不但适用于管理大型开源软件的源代码(如:linux kernel),管理私人的文档和源代码也有很多优势(如:wsi-lgame-pro) Git 的更多介绍 ...
随机推荐
- 在公有云AZURE上部署私有云AZUREPACK以及WEBSITE CLOUD(四)
(四)搭建Website Cloud环境 1安装CONTROLLER主机 在开始安装Web site Cloud之前,读者应该对该服务的拓扑结构有个大概了解. 如图: Controller是非常重要的 ...
- Android开机动画
Android系统的开机动画可分为三个部分,kernel启动,init进程启动,android系统服务启动.这三个开机动画都是在一个叫做 帧缓冲区(frame buffer)的硬件设备上进行渲染绘制的 ...
- java环境搭建和写出一个Helloworld
一.安装环境和配置环境变量(必要环节) 安装java并配置环境变量 :在"系统变量"中设置3项属性,JAVA_HOME,PATH,CLASSPATH(大小写无所谓),若已存在则点击 ...
- 两种常用的C语言排序算法
1. 要求输入10个整数,从大到小排序输出 输入:2 0 3 -4 8 9 5 1 7 6 输出:9 8 7 6 5 3 2 1 0 -4 解决方法:选择排序法 实现代码如下: #include &l ...
- 企业级应用架构模式N-Tier多层架构
先来看经典的3层架构,看下图: 涉及到平台可以是: Ruby on Rails, Java EE, ASP.NET, PHP, ColdFusion, Perl, Python 层 ...
- hibernate -- HQL语句总结
1. 查询整个映射对象所有字段 //直接from查询出来的是一个映射对象,即:查询整个映射对象所有字段 String hql = "from Users"; Query query ...
- Entity Framework Code First Migrations--EF 的数据迁移
1. 为了演示方便,首先新建一个控制台项目,然后添加对entityframework的引用 使用nuget控制台执行: Install-Package EntityFramework 2.新建一个实体 ...
- ipython notebook 浏览器中编写数学公式和现实
Python Notebook简介1 http://www.cnblogs.com/cbscan/p/3545084.html $ python -m IPython http://pypi.pyth ...
- unable to boot the simulator,无法启动模拟器已解决
突然模拟器报错:unable to boot the simulator(无法启动模拟器) 试了好几种解决办法,删除所有的模拟器重启以后再添加,删除钥匙串登陆中的证书,重新安装Xcode都不行 最后通 ...
- Images.xcassets不能获取图片路径
原文地址:http://www.jianshu.com/p/5358f587af38 Images.xcassets在app打包后,以Assets.car文件的形式出现在bundle中.其作用在于: ...