当前位置: 首页 > 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 log
// 查看前几条提交记录
git log -n

3.8查看所有分支

git branch

3.9创建分支

//创建分支不切换
git branch 分支名
//创建分支并切换
git checkout -b 分支名

3.10删除分支

git branch -d 分支名

3.11删除远程分支

git push origin --delete 分支名

3.12合并dev分支合并到master分支

//切换到master分支
git checkout master
//拉取远程代码
git pull 
//合并代码
git merge dev
//推送到master分支
git push origin master

3.13合并部分提交到master分支

git cherry-pick <commitid>

3.14比较文件

git diff xx.java

3.15保存当前的工作进度并清空工作区

git stash

3.16查看保存的工作进度列表

git stash list

3.17将保存的工作进度应用到当前分支

git stash pop

3.18代码还原(从工作区区还原)

// 单个文件
git checkout -- jforgame-demo/src/main/java/jforgame/demo/socket/GameServer.
java
// 模糊匹配
git checkout -- *.java

3.19代码还原(从暂存区还原)

git restore --stage  jforgame-demo/src/main/java/jforgame/demo/socket/GameServer.java

3.20代码还原(从仓库还原,本地代码也会清除)

//返回到上一个版本代码
git reset --hard HEAD^
//返回到上上一个版本代码
git reset --hard HEAD^^
//返回到指定版本
git reset --hard commitid

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

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更适合在需要快速获取远程更新并合并到当前分支的情况下使用。

4.3git reset --hard与git reset --soft

git reset --hard回退到某个commit,不保留任何修改。这意味着所有未提交的更改和未跟踪的文件都将被永久删除。

git reset --soft回退到某个commit,保留修改。这意味着之前已经添加到暂存区的更改还会保留下来,你可以重新提交这些更改。未跟踪的文件仍然保留在工作目录中。

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

5.常见错误操作

在使用 Git 过程中,有一些常见的错误操作可能会导致代码丢失或者历史记录被修改。以下是一些常见的错误操作

  • git commit --amend:如果你在提交代码后发现需要修改提交信息或添加遗漏的文件,可以使用 git commit --amend 命令。然而,如果在执行此命令之前已经进行过推送(push)操作,那么推送会失败,并且需要执行强制推送(force push)操作来修改远程仓库中的历史记录。
  • git reset --hard:git reset --hard 命令可以用来重置当前分支的 HEAD 和索引(index)到指定的提交版本,并且会丢弃所有未提交的更改。如果你在工作目录中有未保存的更改,执行此命令将会永久删除这些更改,无法恢复。
  • git push --force:正常情况下,Git 会拒绝非快进式的推送操作,以避免覆盖其他人的更改。然而,如果你执行 git push --force 命令,将会强制推送本地分支到远程仓库,即使这可能会覆盖其他人的更改。因此,在执行强制推送操作之前,需要确保与团队成员协商一致。
  • git checkout -b:当你在一个分支上使用 git checkout -b <branch> 命令创建新分支时,如果已经有一个同名的分支存在,Git 会自动切换到该分支,而不是创建新分支。这可能会导致你在错误的分支上进行开发。
  • git clean -f:git clean -f 命令用于删除工作目录中未跟踪的文件。但是如果你执行此命令时未注意,可能会误删一些重要的文件。因此,在执行此命令之前,需要确保你真的要删除这些文件。
  • git checkout <branch>,当你准备切换分支,务必要将工作区的代码先提交。否则,切换之后本地代码将会丢失。或者,先把工作区的代码通过git stash命令缓存起来。

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


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

相关文章:

  • 初学stm32 --- CAN
  • HBASE学习(一)
  • 【PyCharm】连接Jupyter Notebook
  • 【Linux系统编程】—— 深入理解Linux中的环境变量与程序地址空间
  • LabVIEW时域近场天线测试
  • 贪心算法(题1)区间选点
  • lua profile 性能分析工具都有哪些
  • ISIS多区域实验简述
  • Vue工程化基础
  • Debug追踪
  • LeetCode 热题100专题解析:哈希与双指针
  • 【力扣白嫖日记】262.行程和用户
  • 《深入解析 C#》—— C# 2 部分
  • SAP ABAP read table 时关键字TRANSPORTING NO FIELDS的用法
  • 如何用shell脚本构建Android模块
  • 整型溢出问题及解决之道
  • 一直出现问题,发现服务器磁盘空间已满导致,腾出服务器磁盘空间命令
  • 【Linux下qt软件安装打包附带问题: dpkg: error processing package xxxx +解决方式+自我尝试+记录】
  • 深度学习pytorch——Tensor维度变换(持续更新)
  • Linux怎么查看当前进程?怎么执行退出?怎么查看当前路径?
  • 【Kubernetes】k8s删除master节点后重新加入集群
  • AI换脸软件rope最新更新的蓝宝石中文版下载
  • npm、nodejs和vue之间关系和区别介绍
  • 借助 mydumper 实现定期 MySQL 全量备份、恢复方案
  • C语言经典面试题目(十七)
  • 【总结 干货】Cadence allegro导出光绘 装配丝印