当前位置: 首页 > article >正文

Git入门学习

1.Git的优势

Git是一个伟大的版本管理工具,比之svn,具有以下优势:

  • 分布式版本控制:Git是一种分布式版本控制系统,每个开发者都拥有自己的完整代码库,不需要依赖网络连接就可以进行版本控制、合并和提交操作。这样可以提高开发效率,并降低了对网络的依赖。

  • 速度快:Git的设计目标之一就是速度。相对于SVN,Git在提交、分支、合并和切换等操作上都有更快的响应速度。

  • 强大的分支管理:Git的分支管理非常强大,支持轻松创建、合并和删除分支。这使得开发人员能够轻松地进行并行开发,同时保持代码库的稳定性。

然而,Git也没能全面占领svn的市场,因为研发团队的成员不一定都是技术出身,例如策划,测试同学,svn容易上手,换成git根本搞不定。

2.Git的基本概念

首先需要了解下Git的工作区、暂存区、仓库区(本地仓库)、远程仓库的概念

  1. 工作区:你在电脑里能看到的目录,比如我们的workspace 文件夹就是一个工作区。
  2. 暂存区:.git目录下的index文件,可以用 git add 命令将工作区的文件添加到暂存区。
  3. 仓库区(本地仓库):.git目录下的objects文件夹,可以用 git commit 命令将暂存区的内容提交到仓库区。
  4. 远程仓库:远程服务器上的仓库,可以用 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更适合在需要快速获取远程更新并合并到当前分支的情况下使用。

-------------未完待续


http://www.kler.cn/a/272235.html

相关文章:

  • 【Java数据结构】排序
  • 可以自己部署的微博 Mastodon
  • 媒体新闻发稿价格怎么算?移动端发稿价格低的原因有哪些?
  • 玉米植物结构受乙烯生物合成基因 ZmACS7 的调控
  • 【银河麒麟高级服务器操作系统】业务访问慢网卡丢包现象分析及处理过程
  • Chrome 132 版本新特性
  • 最后的挣扎 - Qt For Android on HuaWei Mate 60Pro (v4.0.0)
  • 【AI】Ubuntu系统深度学习框架的神经网络图绘制
  • Etcd 介绍与使用(入门篇)
  • shallowReactive浅层式响应对象
  • wireshark解析https数据包
  • 每周一算法:双向深搜
  • Sqlserver 模糊查询中文及在mybatis xml【非中文不匹配查询】N@P2问题
  • 在Ubuntu系统中使用Systemctl添加启动项的详细指南
  • sqlite 常见命令 表结构
  • go rabbitmq 操作
  • 体系结构安全第二次作业:调研整理编译器优化引入的安全问题,形成调研报告提交
  • Docker学习之数据管理(超详解析)
  • 鸿蒙内核系统
  • IDEA : 已经有一个永久破解版的IDEA2019版本,现在又想安装最新版本的,俩版本共存,发现新版本打不开的解决方案
  • html5cssjs代码 022 表单输入类型示例
  • 高等代数复习:应试经验:求行列式
  • NFT数字藏品推广途径有哪些?CloudNEO免费个性定制方案,推广您的NFT
  • Selenium笔记
  • C语言 数据在内存中的存储
  • elasticsearch(RestHighLevelClient API操作)(黑马)