清华大佬教你用一篇文章完全学会Git,GitHub,Git Server

先自我介绍一下,小编浙江大学毕业,去过华为、字节跳动等大厂,目前阿里P7

深知大多数程序员,想要提升技能,往往是自己摸索成长,但自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!

因此收集整理了一份《2024年最新Java开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友。
img
img
img
img
img
img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,涵盖了95%以上Java开发知识点,真正体系化!

由于文件比较多,这里只是将部分目录截图出来,全套包含大厂面经、学习笔记、源码讲义、实战项目、大纲路线、讲解视频,并且后续会持续更新

如果你需要这些资料,可以添加V获取:vip1024b (备注Java)
img

正文

image

merge命令把不同的分支合并起来。如上图,在实际开放中,我们可能从master分支中切出一个分支,然后进行开发完成需求,中间经过R3,R4,R5的commit记录,最后开发完成需要合入master中,这便用到了merge。

git fetch [remote] merge之前先拉一下远程仓库最新代码 git merge [branch] 合并指定分支到当前分支

一般在merge之后,会出现conflict,需要针对冲突情况,手动解除冲突。主要是因为两个用户修改了同一文件的同一块区域。如下图所示,需要手动解除。

清华大佬教你用一篇文章完全学会Git,GitHub,Git Server

image

rebase

清华大佬教你用一篇文章完全学会Git,GitHub,Git Server

image

rebase又称为衍合,是合并的另外一种选择。

在开始阶段,我们处于new分支上,执行git rebase dev,那么new分支上新的commit都在master分支上重演一遍,最后checkout切换回到new分支。这一点与merge是一样的,合并前后所处的分支并没有改变。git rebase dev,通俗的解释就是new分支想站在dev的肩膀上继续下去。rebase也需要手动解决冲突。

rebase与merge的区别

现在我们有这样的两个分支,test和master,提交如下:

D—E test

/

A—B—C—F master复制代码

在master执行git merge test,然后会得到如下结果:

D--------E

/ \

A—B—C—F----G test, master复制代码

在master执行git rebase test,然后得到如下结果:

A—B—D—E—C’—F’ test, master复制代码

可以看到,merge操作会生成一个新的节点,之前的提交分开显示。而rebase操作不会生成新的节点,是将两个分支融合成一个线性的提交。

如果你想要一个干净的,没有merge commit的线性历史树,那么你应该选择git rebase 如果你想保留完整的历史记录,并且想要避免重写commit history的风险,你应该选择使用git merge

reset

清华大佬教你用一篇文章完全学会Git,GitHub,Git Server

image

reset命令把当前分支指向另一个位置,并且相应的变动工作区和暂存区。

git reset —soft [commit] 只改变提交点,暂存区和工作目录的内容都不改变 git reset —mixed [commit] 改变提交点,同时改变暂存区的内容 git reset —hard [commit] 暂存区、工作区的内容都会被修改到与提交点完全一致的状态 git reset --hard HEAD 让工作区回到上次提交时的状态

revert

清华大佬教你用一篇文章完全学会Git,GitHub,Git Server

image

git revert用一个新提交来消除一个历史提交所做的任何修改。

revert与reset的区别

清华大佬教你用一篇文章完全学会Git,GitHub,Git Server

image

  • git revert是用一次新的commit来回滚之前的commit,git reset是直接删除指定的commit。

  • 在回滚这一操作上看,效果差不多。但是在日后继续merge以前的老版本时有区别。因为git revert是用一次逆向的commit“中和”之前的提交,因此日后合并老的branch时,导致这部分改变不会再次出现,减少冲突。但是git reset是之间把某些commit在某个branch上删除,因而和老的branch再次merge时,这些被回滚的commit应该还会被引入,产生很多冲突。关于这一点,不太理解的可以看这篇文章。

  • git reset 是把HEAD向后移动了一下,而git revert是HEAD继续前进,只是新的commit的内容和要revert的内容正好相反,能够抵消要被revert的内容。

push

上传本地仓库分支到远程仓库分支,实现同步。

git push [remote][branch] 上传本地指定分支到远程仓库 git push [remote] --force 强行推送当前分支到远程仓库,即使有冲突 git push [remote] --all 推送所有分支到远程仓库

其他命令

git status 显示有变更的文件 git log 显示当前分支的版本历史 git diff 显示暂存区和工作区的差异 git diff HEAD 显示工作区与当前分支最新commit之间的差异 git cherry-pick [commit] 选择一个commit,合并进当前分支

以上就是关于Git的一些常用命令及详细阐述,相信能对Git有一个初步的认识。

前言

==

本书以教科书的方式,循序渐进地向软件开发人员或软件开发的项目管理人员,讲述如何快速掌握分布式版本控制系统Git的应用方法,让繁琐复杂的项目开发的版本控制变得高效且轻松自如。书中细致入微地介绍了如何使用设置文件和操作Git文档库,以及建立项目开发的分支、合并分支和解决冲突的操作:在具备扎实的基础之后,介绍了GitGUl 程序用法,以及Git在团队开发模式中应用的问题:讲述如何与全球的项目开发人员进行交流,提升程序开发的经验和能力:介绍了GitHub、 Bitbucket、 GitLab等提供Git服务的网站:本书最后的重点为介绍架设Git Server 的几种方法,让每一个项目开发团队,可以按照自己的软硬件环境,选择适合的方式来控管项目开发。

内容简介

====

本书以循序渐进的方式,先从单机操作模式开始,让读者熟悉Git的基本用法,接着学习Git在团队开发模式中的实际运用,并通过介绍GitHub、Bitbucket、 GitL ab等提供Git服务的网站,让读者可以和全世界的项目开发人员交流,提升程序开发的经验和能力。

本书的最后介绍了架设Git Server的几种方法,让每个项目开发团队 ,可以按照自己的软硬件环境,选择适合的方式来有效管控自己开发的项目。

第一部分Git的基本概念和操作

===============

  • 第1课Git、 谁与争锋

  • 第2课Git 配置文件的妙用

  • 第3课把文件存入 Git文档库

  • 第4课比较文件的差异和从Git文档库取回文件

  • 第5课Git程序项 目管理的实践演练

  • 第6课获取 Git文档库统计数据和绘制统计图表

清华大佬教你用一篇文章完全学会Git,GitHub,Git Server

清华大佬教你用一篇文章完全学会Git,GitHub,Git Server

第二部分建立分支、合并和解决冲突

================

  • 第7课程序项目的分支 ( Branch)

  • 第8课合并程序项 目的分支和解决冲突

  • 第9课使用Rebase指令更新分支的起始点

  • 第10课程序项目的分支和合并的实践演练

清华大佬教你用一篇文章完全学会Git,GitHub,Git Server

清华大佬教你用一篇文章完全学会Git,GitHub,Git Server

第三部分Git程序的图形操作介面

================

  • 第11课Git GUi程序的基本功能

  • 第12课使用Git GUI程序创建分支和合并

  • 第13课SmartGit程序操作介绍

  • 第14课SourceTree程序操作介绍

  • 第15课TortoiseGit程序操作介绍

清华大佬教你用一篇文章完全学会Git,GitHub,Git Server

清华大佬教你用一篇文章完全学会Git,GitHub,Git Server

第四部分远程 Git文档库和团队开关模式

====================

  • 第16课远程Git文档库”的基础操作

  • 第17课远程Git文档库”的高级操作

  • 第18课GitHub让程序项目飞上云端

  • 第19课Fork让Git文档库分家后再合并

  • 第20课Bitbucket比GitHub更好用

  • 第21课GitLab完全免费再加送整个系统

清华大佬教你用一篇文章完全学会Git,GitHub,Git Server

清华大佬教你用一篇文章完全学会Git,GitHub,Git Server

第五部分架设 Git Server

=================

  • 第22课使用Windows共享文件夹或是

  • Git Daemon作为Git Server

  • 第23课使用HTTP/HTTPS访问Git Server

  • 第24课使用SSH认证和加密的Git Server

清华大佬教你用一篇文章完全学会Git,GitHub,Git Server

总结

一般像这样的大企业都有好几轮面试,所以自己一定要花点时间去收集整理一下公司的背景,公司的企业文化,俗话说「知己知彼百战不殆」,不要盲目的去面试,还有很多人关心怎么去跟HR谈薪资。

这边给大家一个建议,如果你的理想薪资是30K,你完全可以跟HR谈33~35K,而不是一下子就把自己的底牌暴露了出来,不过肯定不能说的这么直接,比如原来你的公司是25K,你可以跟HR讲原来的薪资是多少,你们这边能给到我的是多少?你说我这边希望可以有一个20%涨薪。

最后再说几句关于招聘平台的,总之,简历投递给公司之前,请确认下这家公司到底咋样,先去百度了解下,别被坑了,每个平台都有一些居心不良的广告党等着你上钩,千万别上当!!!

Java架构学习资料,学习技术内容包含有:Spring,Dubbo,MyBatis, RPC, 源码分析,高并发、高性能、分布式,性能优化,微服务 高级架构开发等等。

还有Java核心知识点+全套架构师学习资料和视频+一线大厂面试宝典+面试简历模板可以领取+阿里美团网易腾讯小米爱奇艺快手哔哩哔哩面试题+Spring源码合集+Java架构实战电子书。
在这里插入图片描述

网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。

需要这份系统化的资料的朋友,可以添加V获取:vip1024b (备注Java)
img

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!
学习资料和视频+一线大厂面试宝典+面试简历模板可以领取+阿里美团网易腾讯小米爱奇艺快手哔哩哔哩面试题+Spring源码合集+Java架构实战电子书。
[外链图片转存中…(img-KBQ4CuMm-1713476762952)]

网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。

需要这份系统化的资料的朋友,可以添加V获取:vip1024b (备注Java)
[外链图片转存中…(img-AynsU0EY-1713476762953)]

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!

  • 12
    点赞
  • 24
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值