Git入门学习
1.Git的优势
Git是一个伟大的版本管理工具,比之svn,具有以下优势:
-
分布式版本控制:Git是一种分布式版本控制系统,每个开发者都拥有自己的完整代码库,不需要依赖网络连接就可以进行版本控制、合并和提交操作。这样可以提高开发效率,并降低了对网络的依赖。
-
速度快:Git的设计目标之一就是速度。相对于SVN,Git在提交、分支、合并和切换等操作上都有更快的响应速度。
-
强大的分支管理:Git的分支管理非常强大,支持轻松创建、合并和删除分支。这使得开发人员能够轻松地进行并行开发,同时保持代码库的稳定性。
然而,Git也没能全面占领svn的市场,因为研发团队的成员不一定都是技术出身,例如策划,测试同学,svn容易上手,换成git根本搞不定。
2.Git的基本概念
首先需要了解下Git的工作区、暂存区、仓库区(本地仓库)、远程仓库的概念
- 工作区:你在电脑里能看到的目录,比如我们的workspace 文件夹就是一个工作区。
- 暂存区:.git目录下的index文件,可以用
git add
命令将工作区的文件添加到暂存区。 - 仓库区(本地仓库):.git目录下的objects文件夹,可以用
git commit
命令将暂存区的内容提交到仓库区。 - 远程仓库:远程服务器上的仓库,可以用
git push
命令将本地仓库的内容推送到远程仓库。
3. Git常用命令
Git虽然也有自己的GUI工具,但除了文件比较比较方便之外,其他还是觉得命令行用得舒服。
3.1从github下载仓库
git clone [https://github.com/kingston-csj/jforgame]
3.2更新远程代码
git pull
3.3添加文件到本地暂存区
// 指定文件
git add pom.xml
// 匹配所有java文件
git add *.java
// 所有文件
git add .
3.4提交文件到本地仓库
git commit -m '牛逼的优化'
3.5推送本地代码到远程仓库
git push
3.6查看本地文件状态
git status
3.7代码回滚(彻底回退到某个版本,本地代码也会清除)
//返回到上一个版本代码
git reset --hard HEAD^
//返回到上上一个版本代码
git reset --hard HEAD^^
//返回到指定版本
git reset --hard commitid
3.8查看本地仓库提交日志
// 查看全部提交记录,按空格下一页
git log
// 查看前几条提交记录
git log -n
3.9查看所有分支
git branch
3.10创建分支
//创建分支不切换
git branch 分支名
//创建分支并切换
git checkout -b 分支名
3.11删除分支
git branch -d 分支名
3.12删除远程分支
git push origin --delete 分支名
3.13合并dev分支合并到master
分支
//切换到master分支
git checkout master
//拉取远程代码
git pull
//合并代码
git merge dev
//推送到master分支
git push origin master
3.14合并部分提交到master分支
git cherry-pick <commitid>
3.15比较文件
git diff xx.java
3.16保存当前的工作进度并清空工作区
git stash
3.17查看保存的工作进度列表
git stash list
3.18将保存的工作进度应用到当前分支
git stash pop
-------------未完待续
4.常见命令的区别
4.1git stash apply与 git stash pop
- git stash apply命令会将保存的工作进度应用到当前分支,但不会删除stash;
- git stash pop命令则会将保存的工作进度应用到当前分支,并且删除stash
4.2git fetch与git pull
-
git fetch:git fetch是将远程仓库的最新代码下载到本地,但并不会自动合并到当前分支。它将更新远程仓库的追踪分支(如origin/master),但不会影响当前分支。这个命令可以让你查看远程分支的更新情况,并进行比较和分析,然后决定是否将更新合并到当前分支。
-
git pull:git pull在执行时会先执行git fetch命令,然后自动将远程分支的更新合并到当前分支。相当于git fetch + git merge。如果当前分支有未提交的修改,git pull会尝试自动合并,如果出现冲突则需要手动解决冲突。因此,git pull更适合在需要快速获取远程更新并合并到当前分支的情况下使用。
-------------未完待续