1. 开始git
1.1
开始一个新的项目,初始化新的代码仓库
要对现有的某个项目开始用 Git 管理,只需到此项目所在的目录,执行:
<code>git init</code>
会在当前目录下生成一个.git目录,包含了所有git需要的数据和资源
1.2
把服务端的项目拷贝到本地
git支持许多传输协议,如http、https、git、ssh等,下面例子使用git协议
<code>git clone github.com/TheKey-only/ThekeyAndroid</code>
2.跟踪文件
跟踪某个文件或者某个目录下所有文件,就是把需要跟踪的文件加入暂存区(stage),下面把当前目录下的所有文件加入到暂存区
<code>git add ./</code>
3. 查看当前文件状态
<code>git status</code>或者<code>git status xx</code>(指定目录或者文件的状态)
执行
可以看到,执行git add ./后,当前目录下这些文件已经被跟踪了,被添加到暂存区,同时 (use “git rm –cached…” to unstage)提示你可以使用该命令取消跟踪。
注:如果你git add xx后又修改了xx文件,此时应该重新执行git add xx,把最新的xx文件添加到暂存区
4.取消跟踪文件
与跟踪文件相反,取消跟踪就是把该文件或目录从暂存区(stage)移除
<code>git rm --cached c/file_operator/.file_cp.c.swp</code>
此时 c/file_operatorrator/.file_cp.c.swp 已经不在stage区了。可以通过git add重新添加到stage区
5.忽略某些文件
附上我的部分忽略,在gitignore中加入:
<code> # Built application files.apk.ap_# Files for the Dalvik VM.dex# Java class files.class# Generated filesbin/gen/out/# Gradle files.gradle/gradle/build/gradlewgradle.properties# Local configuration file (sdk path, etc)local.properties# Proguard folder generated by Eclipseproguard/# Log Files.log# Eclipse project files.classpath.projectproject.properties# IDEA project files.iml.idea/# OS generated files.DS_Store.DS_Store?._.Spotlight-V100.Trashesehthumbs.dbThumbs.db# othersbuild.xml</code>
之后目录tree中会将忽略的内容显示成灰色(AS为暗色主题时为棕色)
6.提交更新
现在把暂存区域中的文件提交到仓库,每次准备提交之前,运行git status看看需要提交的文件是不是都已经暂存了。
<code>git commit -m “注释”</code>
提交后它会告诉你,当前是在哪个分支(master)提交的,本次提交的完整 SHA-1 校验和是什么( 264c7c4),以及在本次提交中,有多少文件修订过,多少行添改和删改过.
ps:在提交的时候,给 git commit 加上-a 选项,Git 就会自动把所有已经跟踪过的文件暂存起来一并提交,从而跳过 git add 步骤:git commit -a -m ‘xxxx’
7. 移动文件
<code>git mv test1.c test2.c</code>
相当于执行了
mv test1.c test2.c
git rm test1.c
git add test2.c
8.修改最后一次提交
有些时候我们执行git commit -m “cc” 执行后,发现还有文件没有添加到暂存区,想撤销刚才的提交操作,可以使用git commit –amend修改最后一次提交,重新提交,否则就需要多一次提交。
如:
<code>
git commit -m 'cc'
git add forgotten_file
git commit --amend
</code>
上面的三条命令最终只是产生一个提交,第二个提交命令修正了第一个的提交内容。
9.浏览更新历史
<code>git log</code>
git log可以指定输出格式,具体可以参考网上其它资料
查看具体的某次改动
git show 哈希值
10. 恢复单个文件历史版本
查看文件历史记录:git log test.py
得到历史版本号,恢复该文件:
git reset 2e17053b4f5da3b378d6155a174523588d104338 test.py
11. 从服务端接收数据
<code>git pull</code>
12. 推送数据到服务端
执行git commit后,只是把更新提交到本地仓库,执行git push后才把本地修改更新到服务端