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

git基础

git-note

Github Manual | GitHub Cheat Sheet | Visual Git Cheat Sheet

  • 安装
  • 配置工具
  • 分支
  • 创建仓库
  • .gitignore文件
  • 同步更改
  • 进行更改
  • 重做提交
  • 术语表

安装

desktop.github.com | git-scm.com

配置工具

对所有本地仓库的用户信息进行配置

对你的commit操作设置关联的用户名

git config --global user.name "[name]"

对你的commit操作设置关联的邮箱地址

git config --global user.email "[email address]"

启用有帮助的彩色命令行输出

$ git config --global color.ui auto

分支

分支是使用 Git 工作的一个重要部分。你做的任何提交都会发生在当前“checked out”到的分支上。使用 git status 查看那是哪个分支。

创建一个新分支

git branch [branch-name]

切换到指定分支并更新工作目录(working directory)

git switch -c [branch-name]

将指定分支的历史合并到当前分支。这通常在拉取请求(PR)中完成,但也是一个重要的 Git 操作。

git merge [branch]

删除指定分支

git branch -d [branch-name]

创建仓库

当着手于一个新的仓库时,你只需创建一次。要么在本地创建,然后推送到 GitHub;要么通过 clone 一个现有仓库。

将现有目录转换为一个 Git 仓库

git init

在使用过 git init 命令后,使用以下命令将本地仓库与一个 GitHub 上的空仓库连接起来:

git remote add origin [url]

Clone(下载)一个已存在于 GitHub 上的仓库,包括所有的文件、分支和提交(commits)

git clone [url]

.gitignore文件

有时一些文件最好不要用 Git 跟踪。这通常在名为 .gitignore 的特殊文件中完成。你可以在 github.com/github/gitignore 找到有用的 .gitignore 文件模板。

同步更改

将你本地仓库与 GitHub.com 上的远端仓库同步

下载远端跟踪分支的所有历史

git fetch

将远端跟踪分支合并到当前本地分支

git merge

将所有本地分支提交上传到 GitHub

git push

使用来自 GitHub 的对应远端分支的所有新提交更新你当前的本地工作分支。git pullgit fetchgit merge 的结合

git pull

进行更改

浏览并检查项目文件的发展

列出当前分支的版本历史

git log

列出文件的版本历史,包括重命名

git log --follow [file]

展示两个分支之间的内容差异

git diff [first-branch]...[second-branch]

输出指定commit的元数据和内容变化

git show [commit]

将文件进行快照处理用于版本控制

git add [file]

将文件快照永久地记录在版本历史中

git commit -m "[descriptive message]"

重做提交

清除错误和构建用于替换的历史

撤销所有 [commit] 后的的提交,在本地保存更改

$ git reset [commit]

放弃所有历史,改回指定提交。

$ git reset --hard [commit]

小心!更改历史可能带来不良后果。如果你需要更改 GitHub(远端)已有的提交,请谨慎操作。如果你需要帮助,可访问 github.community 或联系支持(support)。

术语表

  • git: 一个开源的分布式版本控制系统
  • GitHub: 一个托管和协作管理 Git 仓库的平台
  • commit 提交: 一个 Git 对象,是你整个仓库的快照的哈希值
  • branch 分支: 一个轻型可移动的 commit 指针
  • clone: 一个仓库的本地版本,包含所有提交和分支
  • remote 远端: 一个 GitHub 上的公共仓库,所有小组成员通过它来交换修改
  • fork: 一个属于另一用户的 GitHub 上的仓库的副本
  • pull request 拉取请求: 一处用于比较和讨论分支上引入的差异,且具有评审、评论、集成测试等功能的地方
  • HEAD: 代表你当前的工作目录。使用git checkout 可移动 HEAD 指针到不同的分支、标记(tags)或提交
http://www.lryc.cn/news/16389.html

相关文章:

  • postgres 源码解析50 LWLock轻量锁--1
  • JVM优化常用命令
  • 按键中断实验
  • kubernetes入门介绍,从0到1搭建并使用
  • 【C语言进阶】字符串函数与内存函数的学习与模拟实现
  • 【JavaEE初阶】第一节.多线程(进阶篇 ) 常见的锁策略、CAS及它的ABA问题
  • Linux基础命令-pstree树状显示进程信息
  • keepalived+LVS配置详解
  • Unity之C#端使用protobuf
  • C++设计模式(18)——模板方法模式
  • SQLserver 索引碎片
  • 【Storm】【二】安装
  • Android ConditionVariable
  • Action Segmentation数据集介绍——Breakfast
  • 横道图时间标尺在P6软件中的设置
  • 空间复杂度(超详解+例题)
  • Document-Level event Extraction via human-like reading process 论文解读
  • H5盲盒抽奖系统源码
  • 低代码平台和无代码平台哪个更适合开发企业管理系统?
  • 75岁彪马再发NFT 复活美洲狮IP
  • 大学生成人插画培训机构盘点
  • 【算法基础】一维差分 + 二维差分
  • 游戏服务器框架 技能buff篇
  • 网友说socket通信讲的不彻底,原来这才是Socket
  • Nginx第二讲
  • redis(win版)
  • 【Linux】编辑器——vim(最小集+指令集+自动化配置)
  • Centos7+Xshell+Jenkins堆装
  • Android system实战 — Android R(11) 进程保活白名单
  • oracle表 分组,并查每组第一条