Git介绍与常用命令的使用
一、Git简介
Git 是一个开源的分布式版本控制系统,是目前世界上最先进、最流行的版本控制系统。可以快速高效地处理从很小到非常大的项目版本管理。特点:项目越大越复杂,协同开发者越多,越能体现出 Git 的高性能和高可用性。
Git基本概念
分类介绍工作区仓库的目录。工作区是独立于各个分支的。暂存区数据暂时存放的区域,类似于工作区写入版本库前的缓存区。暂存区是独立于各个分支的。版本库存放所有已经提交到本地仓库的代码版本版本结构树结构,树中每个节点代表一个代码版本。
二、Git简单命令行入门
一键将本地文件推送到远程,使用命令+介绍
命令初始化一个新的 Git 仓库
git init
通过 git remote add 命令将远程仓库连接到您的本地仓库。
git remote add origin <远程仓库URL>
使用 git pull 命令拉取远程更新。
git pull origin master
将所有待加入暂存区的文件加入暂存区
gitadd.
“xxx给自己看的备注信息”:将暂存区的内容提交到当前分支
git commit -m"xxx"
推送到远程仓库(第一次提交加-u,标志用于与远程分支建立关联)
git push -u origin master
推送到远程仓库
git push
三、Git常用命令
编号命令解释1git config --global user.name xxx设置全局用户名,信息记录在/.gitconfig文件中2git config --global user.email xxx@xxx.com设置全局邮箱地址,信息记录在/.gitconfig文件中3git init将当前目录配置成git仓库,信息记录在隐藏的.git文件夹中4git add XX将XX文件添加到暂存区5git add .将所有待加入暂存区的文件加入暂存区6git rm --cached XX将文件从仓库索引目录中删掉7git commit -m “给自己看的备注信息”将暂存区的内容提交到当前分支8git status查看仓库状态9git diff XX查看XX文件相对于暂存区修改了哪些内容10git log查看当前分支的所有版本11git reflog查看HEAD指针的移动历史(包括被回滚的版本)12git reset --hard HEAD^ 或 git reset --hard HEAD将代码库回滚到上一个版本13git reset --hard HEAD^^往上回滚两次,以此类推14git reset --hard HEAD100往上回滚100个版本15git reset --hard 版本号回滚到某一特定版本16git checkout — XX或git restore XX将XX文件尚未加入暂存区的修改全部撤销17git remote add origin <远程Git仓库地址>将本地仓库关联到远程仓库18git push -u (第一次需要-u,以后不需要)将当前分支推送到远程仓库19git push origin branch_name将本地的某个分支推送到远程仓库20git clone <远程Git仓库地址>将远程仓库XXX下载到当前目录下21git checkout -b branch_name创建并切换到branch_name这个分支22git branch查看所有分支和当前所处分支23git checkout branch_name切换到branch_name这个分支24git merge branch_name将分支branch_name合并到当前分支上25git branch -d branch_name删除本地仓库的branch_name分支26git branch branch_name创建新分支27git push --set-upstream origin branch_name设置本地的branch_name分支对应远程仓库的branch_name分支28git push -d origin branch_name删除远程仓库的branch_name分支29git pull将远程仓库的当前分支与本地仓库的当前分支合并30git pull origin branch_name将远程仓库的branch_name分支与本地仓库的当前分支合并31git branch --set-upstream-to=origin/branch_name1 branch_name2将远程的branch_name1分支与本地的branch_name2分支对应32git checkout -t origin/branch_name将远程的branch_name分支拉取到本地33git stash将工作区和暂存区中尚未提交的修改存入栈中34git stash apply将栈顶存储的修改恢复到当前分支,但不删除栈顶元素35git stash drop删除栈顶存储的修改36git stash pop将栈顶存储的修改恢复到当前分支,同时删除栈顶元素37git stash list查看栈中所有元素
四、常见问题补充
1、缺乏Git练习?
来玩Git小游戏 Learn Git Branching
2、Git 与 SVN 共同点与区别?
共同点:
- 版本控制系统: SVN 和 Git 都是版本控制系统,允许开发人员跟踪文件的变化、回溯到不同的版本、合并多个开发者的工作等。
- 协作开发: 两者都允许多个开发者协同工作在同一个项目上,管理代码的更改和集成新功能。
区别:
- 分布式 vs. 集中式:- Git 是分布式版本控制系统,每个开发者都有一个完整的本地存储库副本,可以独立地工作、提交更改和合并。- SVN 是集中式版本控制系统,所有代码存储在一个中央服务器上,开发者需要与服务器进行交互来获取最新代码或提交更改。
- 工作方式:- Git 通过将每个版本作为文件系统快照来管理文件的变化。每次提交时,Git 会创建一个新的快照,包含项目当前状态的副本。- SVN 以文件为基础,跟踪每个文件的每个版本的变化。
- 分支和合并:- Git 的分支和合并非常快速和高效,因为它在本地存储库中保存了完整的历史记录,并且分支操作仅涉及指向不同提交的指针移动。- SVN 的分支和合并相对复杂,涉及创建复制版本,因为它是集中式系统,没有本地完整历史记录。
- 性能和效率:- Git 在处理大型项目和分支时通常更快、更高效,因为大部分操作都在本地完成。- SVN 在大型项目和分支方面可能会变慢,特别是在集中式存储库上。
3、官方等相关链接?
Git下载:https://git-scm.com/download
SVN 官网:https://subversion.apache.org
Github SVN 源码:https://github.com/apache/subversion
版权归原作者 叶域 所有, 如有侵权,请联系我们删除。