git常用命令

git安装后-指定名称和邮箱

$ git config --global user.name “Your Name”
$ git config --global user.email “email@example.com”

本地初始化GIT 仓库:
#基于远程仓库克隆至本地
git clone <remote_url>

#当前目录初始化为git 本地仓库
git init “directory”

把文件添加add和提交commit到版本库

本地添加
#添加指定文件至暂存区
git add “fileName”
#添加指定目录至暂存区
git add “directory”
#添加所有
git add -A
#将指定目录及子目录移除出暂存区
git rm --cached target -r
#添加勿略配置文件 .gitignore
本地提交
#提交至本地仓库
git commit file -m ‘提交评论’
#快捷提交至本地仓库
git commit -am ‘快添加与提交’

分支管理

#查看当前分支
git branch [-avv]
#基于当前分支新建分支
git branch “branch name”
#基于提交新建分支
git branch “branch name” “commit id”
$ git branch -d {dev}
#切换分支
git checkout “branch name”
#查看当前分支
$ git branch
#合并分支
git merge “merge target”
#注:解决冲突,如果因冲突导致自动合并失败,此时 status 为mergeing 状态.需要手动修改后重新提交(commit) (创建临时目标分支并切换到临时目标分支上,merge 原分支,再status查看冲突位置并解决,最后push提交)
#删除dev分支
$ git branch -d dev //

$ git push origin master(dev) //推送分支
$ git checkout -b dev origin/dev //创建远程origin的dev分支到本地
$ git pull //抓取分支(解决冲突)
$ git branch --set-upstream-to=origin/dev dev//指定本地与远程dev的链接
$ git rebase //把本地未push的分叉提交历史整理成直线

版本控制

$ git log //查看提交历史记录,从最近到最远,可以看到3次
$ git log --pretty=oneline //加参,简洁查看
$ git reflog //查看每一次修改历史
$ cat test.txt //查看文件内容
$ git status //查看工作区中文件当前状态
$ git reset --hard HEAD^(HEAD~100)(commit id) //回退版本
$ git checkout – test.txt //丢弃工作区的修改,即撤销修改
$ git reset HEAD test.txt //丢弃暂存区的修改(若已提交,则回退)

版本回退
回退已经提交的版本
git reset --hard
如果已经向仓库提交了代码,并且想要回退提交的版本,可以使用 --hard 参数。(使用后要push提交)
在这里插入图片描述

回退执行结果
回退项目版本时,可以运行 git revert 命令,该命令会回退指定版本的修改,并创建一个新的提交来存储这些被撤销的更改。(再当前版本的基础上新增一个版本,不影响以前的代码;revert回退是使用cherry-pick)

例如,执行以下命令将会撤销提交和修改,将代码回退到特定提交:
git revert --no-commit <commit>..HEAD
这个命令将撤销到HEAD期间的所有更改,并创建一个新的提交来存储这些变更。
在这里插入图片描述

回退到某个特定的版本
如要回退版本到某个特定的提交点时,可以使用下面的命令:
git reset <commit>

其中,是你要回退到的版本的 SHA 校验和或版本号。
也可以使用HEAD来代替。HEAD指向当前版本,仅仅修改 HEAD 的指向,不改变工作区的内容。
$ git reset --hard 1094a #回退到特定版本号,并删除工作区和缓存区的修改

如果要回退到上一个版本,可以使用以下 Git 命令:
git reset HEAD^
$ git reset --soft HEAD^ #恢复上一个版本,保留工作区,缓存区准备再次提交commit
如果想回退更多个版本,用 HEAD~n 即可,比如回退到前5个版本:
git reset HEAD~5

参数功能场景
–hard清空工作区与缓存区放弃目标版本后所有的修改
–soft保留工作区与缓存区,但是把版本之间的差异存放在缓存区(不撤销git add的操作)合并多个commit
–mixed(或缺省)保留工作区清空缓存区,把版本之间的差异存放在工作区1、有错误的commit需要修改;2、git reset HEAD清空缓存区

$ git reset --hard HEAD #恢复当前版本,删除工作区和缓存区的修改
$ git reset --mixed HEAD #恢复当前版本,保留工作区,清空缓存区

案例说明
比如commit提交最新到最旧为: D C B A
(1)回退到B,CD不要了,====>版本回退:git reset --hard B
(2)撤销B的提交,其余保留, ====>版本撤销:git revert B
(3)取消对b提交的撤销,B重新回来, ====>git cherry-pick B

Git rebase回退
git reflog 先查看本地提交操作编号。
找到提交前的项目编号,例如4c173eb HEAD@{3}: commit: scan ,执行:git reset --hard 4c173eb

Git cherry-pick回退
git cherry-pick --abort.

远程仓库

$ ssh-keygen -t rsa -C “youremail@example.com” //创建SSH Key
$ git remote add origin git@github.com:Daisy/AKgit.git //关联
$ git push -u origin master //将本地内容推送到远程仓库(第一次)
$ git push origin master //将本地内容推送到远程仓库(之后)
$ git remote -v //查看远程仓库信息
$ git remote rm origin //删除远程仓库(解绑)
$ git clone git@github.com: Daisy/AKgit.git //克隆远程仓库
//克隆之后使用和查看
$ cd gitskills
$ ls
$ git remote //查看远程库的信息
$ git remote -v //查看远程库的详细信息

在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/7085.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

JVM-类加载器

主要分为4大步&#xff1a; #mermaid-svg-XlM6AyiZ7c3enqnX {font-family:"trebuchet ms",verdana,arial,sans-serif;font-size:16px;fill:#333;}#mermaid-svg-XlM6AyiZ7c3enqnX .error-icon{fill:#552222;}#mermaid-svg-XlM6AyiZ7c3enqnX .error-text{fill:#552222;…

Linux:多进程和多线程回环socket服务器和客户端

多进程socket服务器代码&#xff1a; #include <stdio.h> #include <unistd.h> #include <sys/types.h> #include <sys/socket.h> #include <arpa/inet.h> #include <string.h> #include <ctype.h> #include <sys/wait.h> #i…

Facebook Messenger市场营销,跨境电商不可忽略的营销手段

营销始于广告。广告仍然是不可或缺的&#xff0c;但广告的方式正在发生变化。以前商家会使用广告邮件或者直接转到网站上的产品页面&#xff0c;但是这两种方法都存在很大问题。虽然企业可以通过电子邮件与潜在客户保持联系&#xff0c;但不能保证这些潜在客户会真正看广告邮件…

Gitee 上传项目到仓库(上传文件夹)

一、将仓库下载到本地 1.首先打开仓库&#xff0c;点击下载压缩包 2.将下载的压缩包解压&#xff0c;并打开&#xff0c;在当前目录下打开 二、git操作 1.在文件当前目录打开git bash 2.初始化git git init 该命令会生成一个隐藏的.git文件夹 如果不是第一次使用&#…

try catch不能捕获promise的错误

参考链接 try catch不是万能的&#xff0c;不能捕获promise的错误。但可以promise接catch来捕获错误&#xff0c;如果有多层的promise&#xff0c;每层都要加catch。 代码示例 // 捕获失败 try {new Promise((resolve,reject)>{throw Error(1)}) } catch (e) {console.erro…

精通正则表达式 - 打造高效正则表达式

目录 一、典型示例 1. 稍加修改——先迈最好使的腿 2. 效率 vs 准确性 3. 继续前进——限制匹配优先的作用范围 4. “指数级”匹配 二、全面考察回溯 1. 传统 NFA 的匹配过程 2. POSIX NFA 需要更多处理 3. 无法匹配时必须进行的工作 4. 看清楚一点 5. 多选结构的代…

测试用例实战

测试用例实战 三角形判断 三角形测试用例设计 测试用例编写 先做正向数据&#xff0c;再做反向数据。 只要有一条边长为0&#xff0c;那就是不符合要求&#xff0c;不需要再进行判断&#xff0c;重复。 四边形 四边形测试用例

安装交叉编译工具链aarch64-linux-gnu-g++ 以及cmake测试

&#xff08;一&#xff09;交叉编译工具链安装 # 查看可以安装的版本 apt-cache search aarch64 # 选择可以安装的版本进行安装 # 此处选择gcc-5-aarch64-linux-gnu以及g-5-aarch64-linux-gnu进行安装 sudo apt-get install gcc-5-aarch64-linux-gnu  sudo apt-get install …

HDFS的文件块大小(重点)

HDFS 中的文件在物理上是分块存储 &#xff08;Block &#xff09; &#xff0c; 块的大小可以通过配置参数( dfs.blocksize&#xff09;来规定&#xff0c;默认大小在Hadoop2.x/3.x版本中是128M&#xff0c;1.x版本中是64M。 如果一个文件文件小于128M&#xff0c;该文件会占…

Python实战案例:轻松采集微博评论,揭示网络舆论热点!

前言 大家早好、午好、晚好吖 ❤ ~欢迎光临本文章 开发环境: python 3.8: 解释器 pycharm: 代码编辑器 模块使用: requests: 发送请求 parsel: 解析数据 jieba pandas stylecloud 第三方模块安装&#xff1a; win R 输入cmd 输入安装命令 pip install 模块名 (如果你…

uniapp 条件编译失败,跑不起来

因为这行代码整个uniapp都跑不起来&#xff0c;谁懂救命。再说uniapp的异常提示也太反人类了<!-- <image :src"require(/ baseListItem.url)" /> -->

没有accept还能建立tcp连接吗?

首先什么是accept&#xff1f;以下是常见的接收网络请求的伪代码 int main() {/*Step 1: 创建服务器端监听socket描述符listen_fd*/ listen_fd socket(AF_INET, SOCK_STREAM, 0);/*Step 2: bind绑定服务器端的IP和端口&#xff0c;所有客户端都向这个IP和端口发送和请求数…

[工具|软件使用] VSCode查看正在运行查询插件

在VSCode中&#xff0c;你可以使用"Developer: Show Running Extensions"命令来查看当前运行的所有插件。 以下是在VSCode中查看插件CPU占用的步骤&#xff1a; 打开VSCode&#xff0c;确保你的编辑器正常运行。 按下Ctrl Shift P&#xff08;在Mac上是Cmd Shif…

高精度地图服务引擎项目

技术栈&#xff1a;使用vue3TypeScriptElement PlusPiniaaxios 项目描述&#xff1a;高精度地图服务引擎项目&#xff0c;提供轻量化处理3D瓦片切片分布式处理分发服务的一站式解决方案 工作内容&#xff1a;1、项目60%已上的页面开发 2、部分模块的功能实现&#xff0c; 3、封…

LT6911C 是一款HDMI 1.4到双端口MIPIDSI/CSI或者LVDS加音频的一款高性能芯片

LT6911C 1.描述&#xff1a; LT6911C是一款高性能的HDMI1.4到MIPIDSI/CSI/LVDS芯片&#xff0c;用于VR/智能手机/显示器应用程序。对于MIPIDSI/CSI输出&#xff0c;LT6911C具有可配置的单端口或双端口MIPIDSI/CSI&#xff0c;具有1个高速时钟通道和1个~4个高速数据通道&#…

Flask 笔记

Flask 笔记 一、Flask介绍 1、学习Flask框架的原因 2020 Python 开发者调查结果显示Flask和Django是Python Web开发使用的最主要的两个框架。 2、Flask介绍 ​ Flask诞生于2010年&#xff0c;是Armin ronacher用Python 语言基于Werkzeug工具箱编写的轻量级Web开发框架。 ​…

24 ==比较的是地址在.equals比较的是内容

public class Demo1 {public static void main(String[] args) {byte[] arr {97,98,99};String s1 new String(arr);String s2 new String(arr);System.out.println(s1s2);System.out.println(s1.equals(s2));} }

【云原生】Kubernetes之ConfigMap

ConfigMap ConfigMap 是一种 API 对象&#xff0c;用来将非机密性的数据保存到键值对中。使用时&#xff0c; Pods 可以将其用作环境变量、命令行参数或者存储卷中的配置文件 ConfigMap 将你的环境配置信息和 容器镜像 解耦&#xff0c;便于应用配置的修改 说明&#xff1a;…

Ubuntu16.04LTS安装ROS测试小海龟样例

一、参考资料 在Ubuntu中安装ROS Kinetic ROS安装ubuntu16.04 无需科学上网解决sudo rosdep init初始化问题 二、安装ROS关键步骤 1. 选择ROS版本 ROS安装选择 Ubuntu版本不同&#xff0c;对应安装的ROS版本也不同&#xff0c;务必版本对齐。 本文以Ubuntu16.04LTS系统为例…

工作不要当老黄牛

1&#xff0c;员工需要帮上级分忧&#xff0c;不论上级是不是老板。很多时候上级就是经理、总监&#xff0c;本质上他也只是一个卑微普通的打工人&#xff1b; 2&#xff0c;对上级的态度不能是掏心掏肺&#xff0c;应该是尽心尽力。掏心掏肺和尽心尽力的区别是&#xff1a;全身…