【职前培训】之一:系统的学习git版本控制工具

纵向对比无版本控制工具时代,无论是使用word传递文件、使用QQ等IM工具传递文件等,都少不了手工归并代码的痛苦,使用版本控制工具毫无疑问的能够极大提升多点协作开发的效率;

再横向对比SVN等其他的版本控制工具,Git拥有更简洁、更高效、更友好的特点,Git采用分布式架构模式,每个开发人员从中心版本库/服务器上chect out代码后会在自己的机器上克隆一个自己的版本库,这意味着,当开发者处于飞机等无网络状态的环境下时,仍然可以提交到本地的版本库,待到恢复网络环境时再提交到中央版本库中。Git的内容存储使用的是SHA-1哈希算法。这能确保代码内容的完整性,确保在遇到磁盘故障和网络问题时降低对版本库的破坏。Git还有许多目前看来优于其他版本控制工具的特性,的确是开发者多点协同办公的不二之选。

下面介绍几个开发中常用的命令

git init

将当前目录初始化为git工作区,目录下会生成一个.git的隐藏目录,即git版本库,会记录一些诸如远程仓库地址、分支等信息。

git add

把要提交的文件的信息添加到暂存区中。当使用 git commit 时,将依据暂存区中的内容来进行文件的提交。git add .代表将目录下所有.gitignore忽略以外的文件添加到暂存区。

git add后面可以通过添加参数达到不同的效果:

# 添加所有修改、已删除的文件到暂存区中
git add -u [<文件路径>]
git add --update [<文件路径>]
​
# 添加所有修改、已删除、新增的文件到暂存区中,省略 <文件路径> 即为当前目录
git add -A [<文件路径>]
git add --all [<文件路径>]
​
# 查看所有修改、已删除但没有提交的文件,进入一个子命令系统
git add -i [<文件路径>]
git add --interactive [<文件路径>]

git commit

与SVN不同,git要求每次提交必须有commit,该指令将暂存区中的文件提交到本地仓库中

# 把暂存区中的文件提交到本地仓库,调用文本编辑器输入该次提交的描述信息
git commit
​
# 把暂存区中的文件提交到本地仓库中并添加描述信息
git commit -m "<提交的描述信息>"
​
# 把所有修改、已删除的文件提交到本地仓库中
# 不包括未被版本库跟踪的文件,等同于先调用了 "git add -u"
git commit -a -m "<提交的描述信息>"
​
# 修改上次提交的描述信息
git commit --amend

git fetch

该指令会从远程仓库获取最新的版本到本地的tmp分支

# 将远程仓库所有分支的最新版本全部取回到本地
git fetch <远程仓库的别名>
​
# 将远程仓库指定分支的最新版本取回到本地
git fetch <远程主机名> <分支名>

git merge

将指定的分支合并到到当前分支下

# 把指定的分支合并到当前所在的分支下
git merge <分支名称>

git pull

从远程仓库获取最新版本,同时合并到本地。该指令相当于git fetchgit merge,把获取的分支的 HEAD 合并到当前分支。

git push

把本地仓库的提交推送到远程仓库,一般是要添加远程仓库别名以及本地分支的,但若采用git clone之后,本地仓库.git中会储存远程仓库以及分支信息,只需键入命令git push即可完成推送

# 把本地仓库的分支推送到远程仓库的指定分支
git push <远程仓库的别名> <本地分支名>:<远程分支名>
​
# 删除指定的远程仓库的分支
git push <远程仓库的别名> :<远程分支名>
git push <远程仓库的别名> --delete <远程分支名>

 

git status

查看本地仓库的状态。

# 以简短模式查看本地仓库的状态
# 会显示两列,第一列是文件的状态,第二列是对应的文件
# 文件状态:A 新增,M 修改,D 删除,?? 未添加到Git中
git status -s

git remote

 

操作远程仓库的命令,一般用于添加远程仓库、修改远程仓库别名等

# 列出已经存在的远程仓库
git remote
​
# 列出远程仓库的详细信息,在别名后面列出URL地址
git remote -v
git remote --verbose
​
# 添加远程仓库
git remote add <远程仓库的别名> <远程仓库的URL地址>
​
# 修改远程仓库的别名
git remote rename <原远程仓库的别名> <新的别名>
​
# 删除指定名称的远程仓库
git remote remove <远程仓库的别名>
​
# 修改远程仓库的 URL 地址
git remote set-url <远程仓库的别名> <新的远程仓库URL地址>

git branch

操作分支的指令,可以查看本地的分支、修改分支名等等,注意该命令不能够切换分支(git checkout用于切换分支)

# 列出本地的所有分支,当前所在分支以 "*" 标出
git branch
​
# 列出本地的所有分支并显示最后一次提交,当前所在分支以 "*" 标出
git branch -v
​
# 创建新分支,新的分支基于上一次提交建立
git branch <分支名>
​
# 修改分支名称
# 如果不指定原分支名称则为当前所在分支
git branch -m [<原分支名称>] <新的分支名称>
# 强制修改分支名称
git branch -M [<原分支名称>] <新的分支名称>
​
# 删除指定的本地分支
git branch -d <分支名称>
​
# 强制删除指定的本地分支
git branch -D <分支名称>

git checkout

用于创建、切换分支的命令

# 切换到已存在的指定分支
git checkout <分支名称>
​
# 创建并切换到指定的分支,保留所有的提交记录
# 等同于 "git branch" 和 "git checkout" 两个命令合并
git checkout -b <分支名称>
​
# 创建并切换到指定的分支,删除所有的提交记录
git checkout --orphan <分支名称>
​
# 替换掉本地的改动,新增的文件和已经添加到暂存区的内容不受影响
git checkout <文件路径>

git diff

用于比较不同版本之间的差异

# 比较当前文件和暂存区中文件的差异,显示没有暂存起来的更改
git diff
​
# 比较暂存区中的文件和上次提交时的差异
git diff --cached
git diff --staged
​
# 比较当前文件和上次提交时的差异
git diff HEAD
​
# 查看从指定的版本之后改动的内容
git diff <commit ID>
​
# 比较两个分支之间的差异
git diff <分支名称> <分支名称>
​
# 查看两个分支分开后各自的改动内容
git diff <分支名称>...<分支名称>

 

第一次从远程仓库拉取项目时,使用git clone xxxxxx.git

协同工作时,日常的工作流程就是:先用git pull拉取最新的分支状态,然后再进行开发,开发好某个功能点或者自认为可以进行一次提交时,使用git add .+git commit -m "xxxxxx"进行本地提交,再使用git pull拉取最新状态,最后使用git push推送到远程仓库,完成代码的合并与推送。

git还有许多进阶的内容。比如撤销提交、回滚版本、添加标签等等操作,转天会进行学习与实践。

 

(由于git命令部分借鉴了其他博客中的内容,故标为“转载”而非原创)

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
提供的源码资源涵盖了Java应用等多个领域,每个领域都包含了丰富的实例和项目。这些源码都是基于各自平台的最新技术和标准编写,确保了在对应环境下能够无缝运行。同时,源码中配备了详细的注释和文档,帮助用户快速理解代码结构和实现逻辑。 适用人群: 适合毕业设计、课程设计作业。这些源码资源特别适合大学生群体。无论你是计算机相关专业的学生,还是对其他领域编程感兴趣的学生,这些资源都能为你提供宝贵的学习和实践机会。通过学习和运行这些源码,你可以掌握各平台开发的基础知识,提升编程能力和项目实战经验。 使用场景及目标: 在学习阶段,你可以利用这些源码资源进行课程实践、课外项目或毕业设计。通过分析和运行源码,你将深入了解各平台开发的技术细节和最佳实践,逐步培养起自己的项目开发和问题解决能力。此外,在求职或创业过程中,具备跨平台开发能力的大学生将更具竞争力。 其他说明: 为了确保源码资源的可运行性和易用性,特别注意了以下几点:首先,每份源码都提供了详细的运行环境和依赖说明,确保用户能够轻松搭建起开发环境;其次,源码中的注释和文档都非常完善,方便用户快速上手和理解代码;最后,我会定期更新这些源码资源,以适应各平台技术的最新发展和市场需求。 所有源码均经过严格测试,可以直接运行,可以放心下载使用。有任何使用问题欢迎随时与博主沟通,第一时间进行解答!
提供的源码资源涵盖了小程序应用等多个领域,每个领域都包含了丰富的实例和项目。这些源码都是基于各自平台的最新技术和标准编写,确保了在对应环境下能够无缝运行。同时,源码中配备了详细的注释和文档,帮助用户快速理解代码结构和实现逻辑。 适用人群: 适合毕业设计、课程设计作业。这些源码资源特别适合大学生群体。无论你是计算机相关专业的学生,还是对其他领域编程感兴趣的学生,这些资源都能为你提供宝贵的学习和实践机会。通过学习和运行这些源码,你可以掌握各平台开发的基础知识,提升编程能力和项目实战经验。 使用场景及目标: 在学习阶段,你可以利用这些源码资源进行课程实践、课外项目或毕业设计。通过分析和运行源码,你将深入了解各平台开发的技术细节和最佳实践,逐步培养起自己的项目开发和问题解决能力。此外,在求职或创业过程中,具备跨平台开发能力的大学生将更具竞争力。 其他说明: 为了确保源码资源的可运行性和易用性,特别注意了以下几点:首先,每份源码都提供了详细的运行环境和依赖说明,确保用户能够轻松搭建起开发环境;其次,源码中的注释和文档都非常完善,方便用户快速上手和理解代码;最后,我会定期更新这些源码资源,以适应各平台技术的最新发展和市场需求。 所有源码均经过严格测试,可以直接运行,可以放心下载使用。有任何使用问题欢迎随时与博主沟通,第一时间进行解答!
提供的源码资源涵盖了Java应用等多个领域,每个领域都包含了丰富的实例和项目。这些源码都是基于各自平台的最新技术和标准编写,确保了在对应环境下能够无缝运行。同时,源码中配备了详细的注释和文档,帮助用户快速理解代码结构和实现逻辑。 适用人群: 适合毕业设计、课程设计作业。这些源码资源特别适合大学生群体。无论你是计算机相关专业的学生,还是对其他领域编程感兴趣的学生,这些资源都能为你提供宝贵的学习和实践机会。通过学习和运行这些源码,你可以掌握各平台开发的基础知识,提升编程能力和项目实战经验。 使用场景及目标: 在学习阶段,你可以利用这些源码资源进行课程实践、课外项目或毕业设计。通过分析和运行源码,你将深入了解各平台开发的技术细节和最佳实践,逐步培养起自己的项目开发和问题解决能力。此外,在求职或创业过程中,具备跨平台开发能力的大学生将更具竞争力。 其他说明: 为了确保源码资源的可运行性和易用性,特别注意了以下几点:首先,每份源码都提供了详细的运行环境和依赖说明,确保用户能够轻松搭建起开发环境;其次,源码中的注释和文档都非常完善,方便用户快速上手和理解代码;最后,我会定期更新这些源码资源,以适应各平台技术的最新发展和市场需求。 所有源码均经过严格测试,可以直接运行,可以放心下载使用。有任何使用问题欢迎随时与博主沟通,第一时间进行解答!

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值