Git的一些常用命令,及.gitignore的配置

要很好的掌握Git,先要明白四个名词概念:

  1. Workspace(工作区):新添加的,和修改的未add操作的。
  2. Stage(暂存区):add操作过后,会进入暂存区。
  3. Repository(本地仓库):commit操作后,会进入本地仓库。
  4. Remote(远程仓库):push操作后,会提交到远程仓库。

Git的配置:

# 显示当前的Git配置
$ git config --list

#设置用户名和邮箱,即提交代码时的用户信息
$ git config [--global] user.name "[name]"
$ git config [--global] user.email "[email address]"

添加/删除文件(到暂存区,即add操作)

#可以添加一个或多个
$ git add <file1> <file2>...

#添加所有修改的和新添加的
$ git add .
#另一种写法
$ git add -A

#添加指定目录
$ git add <dirname>

#由暂存区恢复到工作区(发现提交错了,退回一步)
$ git reset HEAD <file> 

#恢复上一次add提交的所有file
$ git reset HEAD

#撤销修改操作,恢复到修改之前的,撤销add后位于工作区下进行的
$ git checkout -- <file>

#删除文件,并将文件放入暂存区
$ git rm <file1> <file2>
#改文件名,并将修改后的文件放入暂存区
$ git mv <file-original> <file-rename>

提交到本地仓库(commit操作)

#提交暂存区的所有文件(后面的message不可缺少)
$ git commit -m <message>
#提交暂存区的指定文件
$ git commit <file1> <file2> -m <message>

分支操作(branch)

# 列出所有本地分支
$ git branch

# 列出所有远程分支
$ git branch -r

# 列出所有本地分支和远程分支
$ git branch -a

# 新建一个分支,并切换到该分支
$ git checkout -b [branch]

# 切换到指定分支,并更新工作区
$ git checkout [branch-name]

#从远程分支检出指定分支
$ git clone -b <branchname> <master>

# 合并指定分支到当前分支(主分支合并自定义分支)
$ git merge [branch]

# 删除分支
$ git branch -d [branch-name]

# 删除远程分支
$ git push origin --delete [branch-name]
$ git branch -dr [remote/branch]

查看信息:

# 显示有变更的文件
$ git status

# 显示当前分支的版本历史
$ git log

.gitignore的配置:

缘由:当我们导入一个git项目时,开发环境会改变里面的一些配置,当我们修改完代码后,add,commit操作后,系统更改的配置信息,并不想去提交,这个时候就会用到这个配置,配置完成后,才更好的去add .和commit -m去操作。

#要在Git BashHere这里面操作
user@amelon MINGW64 ~/Desktop/git (master)
$ touch .gitignore

user@amelon MINGW64 ~/Desktop/git (master)
$

常用的配置:
eg1:

/build
/.idea
/.gradle
/local.properties
.gitignore

eg2:

# Java class files
*.class

# Generated files
bin/
gen/

# Gradle files
.gradle/
build/

# Local configuration file (sdk path, etc)
local.properties

# Proguard folder generated by Eclipse
proguard/

#Android Studio
build/

# Intellij project files
*.iml
*.ipr
*.iws
.idea/

#gradle
.gradle/

用法规则和语义:

# 此为注释 – 将被 Git 忽略

*.a       # 忽略所有 .a 结尾的文件
!lib.a    # 但 lib.a 除外
/TODO     # 仅仅忽略项目根目录下的 TODO 文件,不包括 subdir/TODO
build/    # 忽略 build/ 目录下的所有文件
doc/*.txt # 会忽略 doc/notes.txt 但不包括 doc/server/arch.txt

注意:如果你是新加的,这里需要注意的是.gitignore只能作用于没有被track的文件,也就是工作区的文件,对于add,commit操作后的文件是没有作用的,这个时候需要先把本地的缓存删除,在去提交,就可以实现忽略整个仓库文件了。

git rm -r --cached .
git add .
git commit -m 'update .gitignore'

结论:还有不少git命令这里就不添加了,这些是比较常用到的,遇到常用的再补充,有问题可以留言,会及时改正,欢迎拍砖,多多指教….

转载请标明:http://blog.csdn.net/zxyudia/article/details/67633321

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值