您的位置:首页 > 其它

Git 常用操作(入门级)

2017-08-12 20:17 176 查看
今天学习了git,做个小结吧。日后不定时添加、完善。

推荐教程:廖雪峰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
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: