Git 常用操作(入门级)
2017-08-12 20:17
176 查看
今天学习了git,做个小结吧。日后不定时添加、完善。
推荐教程:廖雪峰Git教程
关于git是什么,只能说一句,是Git是目前世界上最先进的分布式版本控制系统(没有之一)。只用在使用了之后才能体会分布式版本控制是什么样子,推荐看上面的教程,亲自动手敲一遍!
添加文件到Git仓库,分两步:
第一步,使用命令git add ,注意,可反复多次使用,添加多个文件;
第二步,使用命令git commit,完成。
如果git status告诉你有文件被修改过,用git diff可以查看修改内容。
HEAD指向的版本就是当前版本,因此,Git允许我们在版本的历史之间穿梭,使用命令git reset –hard commit_id。
穿梭前,用git log可以查看提交历史,以便确定要回退到哪个版本。
要重返未来,用git reflog查看命令历史,以便确定要回到未来的哪个版本。
撤回操作
场景1:当你改乱了工作区某个文件的内容,想直接丢弃工作区的修改时,用命令git checkout – file。
场景2:当你不但改乱了工作区某个文件的内容,还添加到了暂存区时,想丢弃修改,分两步,第一步用命令git reset HEAD file,就回到了场景1,第二步按场景1操作。
场景3:已经提交了不合适的修改到版本库时,想要撤销本次提交,参考版本回退一节,不过前提是没有推送到远程库。
命令git rm用于删除一个文件。如果一个文件已经被提交到版本库,那么你永远不用担心误删,但是要小心,你只能恢复文件到最新版本,你会丢失最近一次提交后你修改的内容。
1 添加SSH秘钥
2 要关联一个远程库,使用命令git remote add origin git@server-name:path/repo-name.git;
3 关联后,使用命令git push -u origin master第一次推送master分支的所有内容;
4 此后,每次本地提交后,只要有必要,就可以使用命令git push origin master推送最新修改;
5 要关联一个远程库,使用命令git remote add origin git@server-name:path/repo-name.git;
克隆操作
1 关联后,使用命令git push -u origin master第一次推送master分支的所有内容;
2 此后,每次本地提交后,只要有必要,就可以使用命令git push origin master推送最新修改;
查看分支:git branch
创建分支:git branch [name]
切换分支:git checkout [name]
创建+切换分支:git checkout -b [name]
合并某分支到当前分支:git merge [name]
删除分支:git branch -d [name]
$ git fetch origin master:temp
remote: Counting objects: 3, done.
remote: Compressing objects: 100% (3/3), done.
remote: Total 3 (delta 2), reused 0 (delta 0), pack-reused 0
展开对象中: 100% (3/3), 完成.
来自 github.com:pengxin99/javaDemo
[新分支] master -> temp
1ba0534..d8ad63f master -> origin/master
列表内容
9fb0
比较本地仓库与下载的temp分支:
$ git diff temp
@@ -14,7 +14,7 @@ public class disassemble {
// define register and memory
int[] GPR = new int[32];
int[] data = new int[24];
// define the initial PC num
// define the PC num
int PC = 256;
合并temp分支到本地的master分支:
$ git merge temp
更新 1ba0534..d8ad63f
Fast-forward
disassemble.java | 96 ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++———————————-
1 file changed, 62 insertions(+), 34 deletions(-)
查看当前branch
$ git branch
/* master
/ temp
删除temp分支
git branch -d temp
git banch
/*master
推荐教程:廖雪峰Git教程
关于git是什么,只能说一句,是Git是目前世界上最先进的分布式版本控制系统(没有之一)。只用在使用了之后才能体会分布式版本控制是什么样子,推荐看上面的教程,亲自动手敲一遍!
创建版本库
初始化一个Git仓库,使用git init命令。添加文件到Git仓库,分两步:
第一步,使用命令git add ,注意,可反复多次使用,添加多个文件;
第二步,使用命令git commit,完成。
时光机穿梭
要随时掌握工作区的状态,使用git status命令。如果git status告诉你有文件被修改过,用git diff可以查看修改内容。
HEAD指向的版本就是当前版本,因此,Git允许我们在版本的历史之间穿梭,使用命令git reset –hard commit_id。
穿梭前,用git log可以查看提交历史,以便确定要回退到哪个版本。
要重返未来,用git reflog查看命令历史,以便确定要回到未来的哪个版本。
撤回操作
场景1:当你改乱了工作区某个文件的内容,想直接丢弃工作区的修改时,用命令git checkout – file。
场景2:当你不但改乱了工作区某个文件的内容,还添加到了暂存区时,想丢弃修改,分两步,第一步用命令git reset HEAD file,就回到了场景1,第二步按场景1操作。
场景3:已经提交了不合适的修改到版本库时,想要撤销本次提交,参考版本回退一节,不过前提是没有推送到远程库。
命令git rm用于删除一个文件。如果一个文件已经被提交到版本库,那么你永远不用担心误删,但是要小心,你只能恢复文件到最新版本,你会丢失最近一次提交后你修改的内容。
远程仓库(github)
关联操作1 添加SSH秘钥
2 要关联一个远程库,使用命令git remote add origin git@server-name:path/repo-name.git;
3 关联后,使用命令git push -u origin master第一次推送master分支的所有内容;
4 此后,每次本地提交后,只要有必要,就可以使用命令git push origin master推送最新修改;
5 要关联一个远程库,使用命令git remote add origin git@server-name:path/repo-name.git;
克隆操作
1 关联后,使用命令git push -u origin master第一次推送master分支的所有内容;
2 此后,每次本地提交后,只要有必要,就可以使用命令git push origin master推送最新修改;
分支管理
Git鼓励大量使用分支:查看分支:git branch
创建分支:git branch [name]
切换分支:git checkout [name]
创建+切换分支:git checkout -b [name]
合并某分支到当前分支:git merge [name]
删除分支:git branch -d [name]
从远程拉取更新后的代码
使用如下命令可以在本地新建一个temp分支,并将远程origin仓库的master分支代码下载到本地temp分支:$ git fetch origin master:temp
remote: Counting objects: 3, done.
remote: Compressing objects: 100% (3/3), done.
remote: Total 3 (delta 2), reused 0 (delta 0), pack-reused 0
展开对象中: 100% (3/3), 完成.
来自 github.com:pengxin99/javaDemo
[新分支] master -> temp
1ba0534..d8ad63f master -> origin/master
列表内容
9fb0
比较本地仓库与下载的temp分支:
$ git diff temp
@@ -14,7 +14,7 @@ public class disassemble {
// define register and memory
int[] GPR = new int[32];
int[] data = new int[24];
// define the initial PC num
// define the PC num
int PC = 256;
合并temp分支到本地的master分支:
$ git merge temp
更新 1ba0534..d8ad63f
Fast-forward
disassemble.java | 96 ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++———————————-
1 file changed, 62 insertions(+), 34 deletions(-)
查看当前branch
$ git branch
/* master
/ temp
删除temp分支
git branch -d temp
git banch
/*master
相关文章推荐