Git基本配置
Git配置使用git config分三种,存放在不同位置
文件 | 作用 |
---|---|
/etc/gitconfig | 系统中对所有的用户都适用的配置。git config --system ... |
~/.gitconfig | 用户目录下的配置文件只适用该用户。git config --global ... |
当前项目下的.git/config | 配置只对当前项目有效。git config ... |
首先要配置用户名和邮箱。每次git提交都会使用这里配置的默认信息
git config --global user.name "yourname"
git config --global user.email ...@example.com
配置默认文本编辑器,例如emacs
git config --global core.editor emacs
配置解决差异冲突时使用哪种分析工具,例如vimdiff
git config --global merge.tool vimdiff
检查已有配置
git config --list
data:image/s3,"s3://crabby-images/b8b8d/b8b8d43fab9cb84a1e93348b1ccd57e8d0e2ac7b" alt=""
高亮显示一些配置
git config --global color.status auto #查看状态时高亮
git config --global color.branch auto #分支名高亮
git config --global color.ui auto #自动高亮
配置别名来简化一些命令,例如checkout 简化为co,status简化为st
git config --global alias.co checkout
git config --global alias.st status
之后使用命令git checkout 时就可以简化为 git co
Git基本命令
环境配置好了后就可以使用了,常用的git命令就几个不用担心
创建git仓库--git inite
在项目根目录下执行git inite命令(在跟目录下右键Git Bash),会在根目录下创建隐藏.Git目录,包含相关配置和信息
data:image/s3,"s3://crabby-images/fad3f/fad3f6177c81ee77f5c5f88b92b7248e80eee65d" alt=""
查看本地仓库的状态--git status
使用git status或之前简化的git st,状态有三种已修改,已暂存,已修改。已修改是在工作目录也就是项目里修改还有提交保存;已暂存是指用git add命令提交到要保存的清单(暂存区域);已提交是暂存区的文件通过git commit提交到本地git仓库;
由于我们新建的仓库,所有文件都没保存提交,都是已修改状态
data:image/s3,"s3://crabby-images/e38c3/e38c3c16f3ccf0d6c5270f92c10836d07bfae0e6" alt=""
提交修改到暂存区域--git add
通过上面提示可以知道用git add提交,它完整命令参数复杂,只说最常见的两种。一种是添加某个文件,例如app文件
git add app
data:image/s3,"s3://crabby-images/c3503/c3503417edeb951146e280592824eb09ac412695" alt=""
提交目录下所有文件
git add .
在看看现在状态
data:image/s3,"s3://crabby-images/7936c/7936c2d2dcd093f5abd3fea90063a9fd1024cc16" alt=""
已变成暂存状态,并且提示可以使用git rm --cached命令将文件从追踪列表移除
提交到本地仓库--git commit
使用git commit将追踪列表中文件提交
git commit -m "提交说明" #形式1:通过-m提交简短信息
git commit #形式2:会跳转编辑器,在提交信息有一定格式或文字较多时用
data:image/s3,"s3://crabby-images/832f8/832f853d8d3c37fd5d4876968bf880a7ed232e88" alt=""
现在工作区是干净的
data:image/s3,"s3://crabby-images/9c91d/9c91dec84727d1271652a2e63e7e93419a662be4" alt=""
查看项目历史记录--git log
git log
data:image/s3,"s3://crabby-images/7bb78/7bb78976c06b3b2803309a325a0bf9f2b785bdc9" alt=""
下载远程项目--git clone
当想下载网络上别人的仓库时,可使用git clone "地址",例如下载我github上一个EmptyHand项目
git clone https://github.com/biloba123/EmptyHand.git
data:image/s3,"s3://crabby-images/adebe/adebed783ae4731db045118c5d4797ea9e4845cb" alt=""
会在当前目录下新建一个EmptyHand文件存放
不同分支--git branch
在上面的操作都显示master,因为默认创建一个master的主分支,不同分支互不影响,当我们开发新功能时一般会新建一个分支在上面操作,因为新加功能可能会有问题最后砍掉这个功能,只有测试通过没有问题再把它合并到master分支上。
例如现在开发热点功能,新建一个hotspot分支
git branch hotspot
data:image/s3,"s3://crabby-images/5849c/5849c4671320c9631b437d35b9337e30f0f8e862" alt=""
看到现在一共两个分支,当前处于master
切换分支--git checkout
checkout命令用于签出一个分支或者一个路径。常用于分支切换和恢复文件。列入切换到hotspot分支
git checkout hotspot
data:image/s3,"s3://crabby-images/e200b/e200b818f48a9c6275518862be373951877ffb96" alt=""
现在已经在hotspot分支,我们开发啊开发(几天过去了...),功能差不多实现了将代码保存提交
data:image/s3,"s3://crabby-images/1e8ce/1e8ce19b6c651b2808329fb1180a588affab11bc" alt=""
然而,hotspot出现严重bug,只放弃它
git checkout master #切换回master
git branch -D hotspot #删除hotspot分支
data:image/s3,"s3://crabby-images/d7033/d7033745bd96994b3c79e35075d32c8ed688bdd8" alt=""
checkout的另一个常用功能是将文件恢复到修改之前状态。比如今天去在ConnectHotspotFragment.java文件里加了好多好多代码,然而写完发现完全不能用...,而且由于太乱之前代码也不能用了。。。
别担心通过下面命令可以恢复
git checkout -- ConnectHotspotFragment.java
合并分支--git merge
如果hotspot开发完成没bug,要将它合并到master分支上。首先提交hotspot代码,切换到主分支,再执行git merge hotspot命令,如果没冲突就能直接合并
data:image/s3,"s3://crabby-images/93ff7/93ff72d1f6cf9919b463ba66ba889c61c2839163" alt=""
解决冲突
合并并不能经常一帆风顺,比如我现在主要负责这个项目,然后有另一个人协助我,我就把hotspot丢给他做,我也继续在主分支上做,但如果我们同时改了MainActivity,那在合并时
data:image/s3,"s3://crabby-images/7bb52/7bb52c70d57cd5efb17ef74b5f9ea52d9892eb57" alt=""
看到代码里
data:image/s3,"s3://crabby-images/954a5/954a5c9d469d0e81c883546989625ec55058dc7d" alt=""
两个分支同时改了这里,所以git不知道该用谁的,这时就要手动合并
data:image/s3,"s3://crabby-images/ac087/ac087dc5239d48745333cc1e50d6d30613079ad0" alt=""
然后再git add和commit提交代码即可
为版本打个标签--git tag
当完成所有功能并通过测试时,通常会为这个版本打个标签
git tag -a v1.0 -m "相关信息"
data:image/s3,"s3://crabby-images/15b5e/15b5ec33741530b5de19e9cb9dd05568a5d69f12" alt=""
也可以通过" git tag -d 标签名 "来删除tag,通过" git show 标签名"查看版本具体信息
data:image/s3,"s3://crabby-images/f489d/f489db5e2fa2a331a4e4e9efcc833ea4a65b4ec4" alt=""
帮助文档--git help
当你不知道某个命令怎么用时,可以通过 git help 来获取其完整说明。例如查看tag命令说明
git help tag
data:image/s3,"s3://crabby-images/fd5c3/fd5c32937445d91f3f997f0c3ffea2c680e2f40d" alt=""
网友评论