面试资料快速复习 Git常用命令(简单实用)

news2024/12/24 21:27:47

Git-command

Git常用命令、面试复习、简单实用命令

一、概念理解

(一)工作区、暂存区、本地仓库、远程仓库

  • workspace:工作区
  • staging area:暂存区/缓存区
  • local repository:本地仓库
  • remote repository:远程仓库

(二)远程分支、当前本地分支

(三)常用命令

1.git init

新项目执行Git初始化,并进行第一次提交

git init
git add .
git commit -m "first commit"
git remote add origin https://github.com/liyinchigithub/Git-commands.git
git push origin master

2.git clone

对github、gitlab远程仓库,已有项目进行克隆

git clone https://github.com/liyinchigithub/Git-commands.git

3.git pull、git fetch

(1)将远程主机 origin 的 master 分支拉取过来,与本地的 brantest 分支合并。

git pull origin
git pull https://github.com/liyinchigithub/Git-commands.git

远程分支是与当前分支合并

git pull origin master

(2)拉取代码,但不合并到本地

git fetch --all
git fetch --tags
git reset --hard origin/master

(3)git pull 与git fetch区别:

  • 远端跟踪分支不同

git fetch能够直接更改远端跟踪分支。

git pull无法直接对远程跟踪分支操作,我们必须先切回本地分支然后创建一个新的commit提交。

  • 拉取不同

git fetch会将数据拉取到本地仓库,它并不会自动合并或修改当前的工作。

git pull是从远程获取最新版本并merge到本地,会自动合并或修改当前的工作。

  • commitID不同

使用git fetch更新代码,本地的库中master的commitID不变,还是等于1。

使用git pull更新代码,本地的库中master的commitID发生改变,变成了2。

4.git add

(1)添加指定目录到暂存区,包括子目录:

git add [dir]

例如:添加2个文件到暂存区

git add README hello.js 

(2)添加当前目录下的所有文件到暂存区:

git add .

5.git commit

将暂存区内容添加到本地仓库中

git commit -m "提交内容备注"

在执行git add . 之后执行git commit

6.git reset

(1)回滚代码,撤销某一次commit,并强推到远程仓库

如果需要删除的 commit 是最新的,那么可以通过 git reset 命令将代码回滚到之前某次提交的状态,但一定要将现有的代码做好备份,否则回滚之后这些变动都会消失。具体操作如下:

git log // 查询要回滚的 commit_id

git reset --hard commit_id // HEAD 就会指向此次的提交记录

git push origin HEAD --force // 强制推送到远端

(2)回退所有内容到上一个版本

git reset HEAD^

(3)回退 hello.js 文件的版本到上一个版本

git reset HEAD^ hello.js

执行 git reset HEAD 命令用于取消已缓存的内容。

执行 git reset HEAD 以取消之前 git add 添加,但不希望包含在下一提交快照中的缓存 。

(4)回退到指定版本

查看提交日志,回退到指定commit_id

git log
git reset --hard commit_id

或者

git reset 052e

(5)回退上上上一个版本

git reset --soft HEAD~3

备注:此次提交之后的修改会被退回到暂存区

(6)回退到某个版本回退点之前的所有信息。

git reset –hard bae128

备注:此次提交之后的修改不做任何保留,git status 查看工作区是没有记录的。

(7)将本地的状态回退到和远程的一样

git reset --hard origin/master

注意:谨慎使用 –hard 参数,它会删除回退点之前的所有信息。

(8)HEAD 说明:

可以使用 ~数字表示

(9)误删恢复

如果回滚代码之后发现复制错了 commit_id,或者误删了某次 commit 记录,也可以通过下方代码恢复:

git relog // 复制要恢复操作的前面的 hashgit reset --hard hash // 将 hash 换成要恢复的历史记录的 hash

注意:删除中间某次提交时最好不要用 git reset 回退远程库,因为之后其他人提交代码时用 git pull 也会把自己的本地仓库回退到之前的版本,容易出现差错进而增加不必要的工作量。

7.git branch

(1)新建分支

git branch 新建的分支名

(2)查看所有分支信息

git branch

(3) 删除分支

git branch master
git branch -d 分支名称

删除分支前,需要切换到其他分支

①删除本地分支

git branch
git checkout master
git branch -d 本地分支名

②删除远程分支

git push origin --delete 远程分支名称

如何本地分支已提交到远程仓库,想删除这个分支,除了删除本地分支,还需要远程分支也要删除,以上两个命令都要执行一次。

8.git status

查看当前分支状态

$ git status
On branch master

Initial commit

Changes to be committed:
  (use "git rm --cached <file>..." to unstage)

    new file:   README
    new file:   hello.php

9.git checkout

切换分支

10.git push

(1)将本地的 master 分支推送到 origin 主机的 master 分支。

git push origin master

(2)本地版本与远程版本有差异,但又要强制推送可以使用 --force 参数:

git push --force origin master

(3)指定分支

git push <远程主机名> <本地分支名>:<远程分支名>

完整操作

git branch
git checkout 分支名
修改代码
git add .
git commit -m "提交内容注释"
git push origin master

远程项目仓库对提交上来的分支代码还有做merge操作,才可以把分支代码合并到master中

11.git merge


(1)开发分支(dev)上的代码达到上线的标准后,要合并到 master 分支

git checkout dev
git pull
git checkout master
git merge dev
git push -u origin master

(2)当master代码改动了,需要更新开发分支(dev)上的代码

git checkout master 
git pull 
git checkout dev
git merge master 
git push -u origin dev

12.git rebase

当两个分支不在一条线上,需要执行 merge 操作时使用该命令。

(1)撤销提交

如果中间的某次 commit 需要删除,可以通过 git rebase 命令实现,方法如下:

git log // 查找要删除的前一次提交的 commit_id

git rebase -i commit_id // 将 commit_id 替换成复制的值

进入 Vim 编辑模式,将要删除的 commit 前面的 `pick` 改成 `drop`

保存并退出 Vim

(2)解决冲突

该命令执行时极有可能出现 reabase 冲突,可以通过以下方法解决:

git diff // 查看冲突内容

// 手动解决冲突(冲突位置已在文件中标明)

git add <file>git add -A // 添加

git rebase --continue // 继续 rebase

// 若还在 rebase 状态,则重复 2、3、4,直至 rebase 完成出现 applying 字样

git push

13.git revert

git revert:放弃某次提交。

git revert 之前的提交仍会保留在 git log 中,而此次撤销会做为一次新的提交。

git revert -m:用于对 merge 节点的操作,-m 指定具体某个提交点。

(1)撤销提交

要撤销中间某次提交时,使用 git revert 也是一个很好的选择:

git log // 查找需要撤销的 commit_id

git revert commit_id  // 撤销这次提交

(2)撤销 merge 节点提交

如果这次提交是 merge 节点的话,则需要加上 -m 指令:

git revert commit_id -m 1 // 第一个提交点

// 手动解决冲突

git add -A

git commit -m ""

git revert commit_id -m 2 // 第二个提交点

// 重复 2,3,4

git push

14.git log

(1)查看提交历史

(2)用 --oneline 选项来查看历史记录的简洁的版本


git log --oneline

(3)可以用 --graph 选项,查看历史中什么时候出现了分支、合并。

(4)可以用 --reverse 参数来逆向显示所有日志。

git log --reverse --oneline

(5)如果只想查找指定用户的提交日志

git log --author

例如,比方说我们要找 Git 源码中 liyinchi 提交的部分

git log --author=Linus --oneline -5

(6)如果你要指定日期,可以执行几个选项:–since 和 --before,但是你也可以用 --until 和 --after。

git log --oneline --before={3.weeks.ago} --after={2020-04-23} --no-merges

(7)git blame

git blame <file>

15.git remote


远程仓库操作

git remote show [remote]
git remote show https://github.com/liyinchigithub/Git-commands

(1)添加远程版本库

一般在新建项目时使用

git init
git add .
git commit -m "first commit"
git remote add origin https://github.com/liyinchigithub/Git-commands.git
git push -u origin master

(2)删除远程仓库

git remote rm name

(3)修改仓库名

git remote rename old_name new_name 

16.git config 命令

(1)显示当前的 git 配置信息

git config --list
credential.helper=osxkeychain
core.repositoryformatversion=0
core.filemode=true
core.bare=false
core.logallrefupdates=true
core.ignorecase=true
core.precomposeunicode=true

(2)编辑当前的 git 配置信息

git config -e

16.git rm

如果需要删除的 commit 是一个或多个文件,可以进行以下操作。

(1)被提交到仓库的某个文件需要删除,可以使用 git rm 命令:

git rm <file> // 从工作区和暂存区删除某个文件

git commit -m "" // 再次提交到仓库

(2)如果只想从暂存区删除文件,本地工作区不做出改变,可以:

git rm --cached <file>

(3)如果在工作区不小心删错了某个文件,可以用 git checkout 将暂存区的文件覆盖工作区的文件,从而把误删的文件恢复:

git checkout -- <file>

(4)用 git rm 删除文件,同时还会将这个删除操作记录下来;

用 rm 删除文件,删除的仅仅是本地物理文件,没有将其从 git 的记录中剔除。

(5)git add 和 git rm 区别,

git add 仅能记录添加、改动的动作,删除的动作需靠 git rm 来完成。

17.git tag

(1)打标签

到一个重要的阶段,并希望永远记住那个特别的提交快照,你可以使用 git tag 给它打上标签

git tag -a v1.0 -m "release 1.0 version" 
git push origin :v1.0
image

(2)查看本地标签

git tag

(3)查看远程所有 tag

git ls-remote --tags origin

(4)将本地tag推送到远程

git push origin v1.0
image

也可以仅执行该句,会自动生成本地tag并推送到远程

(5)完整的标签操作

git add .
git commit -m "first commit"
git push origin master
git push origin v1.0

或者

git add .
git commit -m "first commit"
git push origin master
git tag -a v1.1 -m "release 1.0 version"
git tag
git push origin :v1.1

(6)删除本地tag

git tag -d v1.0

(7)删除远程tag

git push origin :refs/tags/v1.0

(8)追加标签

如果我们忘了给某个提交打标签,又将它发布了,我们可以给它追加标签。

$ git tag -a v0.9 85fc7e7
$ git log --oneline --decorate --graph
*   d5e9fc2 (HEAD -> master) Merge branch 'change_site'
|\  
| * 7774248 (change_site) changed the runoob.php
* | c68142b 修改代码
|/  
* c1501a2 removed test.txt、add runoob.php
* 3e92c19 add test.txt
* 3b58100 (tag: v0.9) 第一次版本提交
*

(3)查看标签

git tag

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

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

相关文章

前端实现页面内容的截图与下载(html2canvas)

今天是一个发文的好日子&#x1f600;~ &#x1f447;&#x1f447;&#x1f447; 一个需求&#xff0c;要截取页面中的内容并截图保存&#xff0c;来看一看我是怎么实现的吧&#xff1a; 这里需要使用到插件--html2canvas 1.安装并引入html2canvas npm install html2canv…

Es 拼音搜索无法高亮

目录 背景&#xff1a; Es 版本&#xff1a; 第一步 第二步 &#xff08;错误步骤 - 只是记录过程&#xff09; 第三步 第四步 第五步 第六步 第七步 背景&#xff1a; app 原有的搜索功能无法进行拼音搜索&#xff0c;产品希望可以支持&#xff0c;例如内容中含有&a…

upload-labs关卡10(点和空格绕过)通关思路

文章目录 前言一、回顾前几关知识点二、靶场第十关通关思路1、看源代码2、bp抓包绕过3、检查文件是否成功上传 总结 前言 此文章只用于学习和反思巩固文件上传漏洞知识&#xff0c;禁止用于做非法攻击。注意靶场是可以练习的平台&#xff0c;不能随意去尚未授权的网站做渗透测…

软件质量保护与测试(第2版)学习总结第十一章 白盒测试

错误隐藏在角落里、集聚在边界处 ----Boris Beizer 白盒测试是看源代码的&#xff0c;静态分析和动态分析 11.2 控制流测试 程序结构主要有3种 顺序结构、分支结构、循环结构 #include "stdafx.h" …

C++实现KNN和K-Means

学校机器学习课程的实验课要求实现KNN和K-Means&#xff1a; &#xff08;平时没听课&#xff09;临时去查了一下KNN和K-Means是啥&#xff0c;然后自己用C写了小例子&#xff0c;想着写都写了那就把代码贴出来吧。 顺便再聊聊自己对于这俩算法的理解。 下面是文心一言的回答…

洛谷 P3131 [USACO16JAN] Subsequences Summing to Sevens S

被普及-卡的没思路真是蒟蒻啊233 优化思路 每次都在枚举(a[r]-a[l-1])%70&#xff0c;所以可以认为数组大小对最终答案没有影响&#xff0c;考虑对前缀和数组取模&#xff0c;那么如果有a[r]的值等于a[l-1]的值相等&#xff08;即余数相等&#xff09;&#xff0c;那么两者相减…

米尔AM62x核心板,高配价低,AM335x升级首选

AM335x是TI经典的工业MPU&#xff0c;它引领了一个时代&#xff0c;即工业市场从MCU向MPU演进&#xff0c;帮助产业界从Arm9迅速迁移至高性能Cortex-A8处理器。随着工业4.0的发展&#xff0c;HMI人机交互、工业工控、医疗等领域的应用面临迫切的升级需求&#xff0c;AM62x处理器…

Python 双门双向门禁控制板实时监控源码

本示例使用设备&#xff1a;实时网络双门双向门禁控制板可二次编程控制网络继电器远程开关-淘宝网 (taobao.com) #python通过缩进来表示代码块&#xff0c;不可以随意更改每行前面的空白&#xff0c;否则程序会运行错误&#xff01;&#xff01;&#xff01;如果缩进不一致&a…

这款IDEA插件真的爱了

IDEA是一款功能强大的集成开发环境&#xff08;IDE&#xff09;&#xff0c;它可以帮助开发人员更加高效地编写、调试和部署软件应用程序。我们在编写完接口代码后需要进行接口调试等操作&#xff0c;一般需要打开额外的调试工具。 今天给大家介绍一款IDEA插件&#xff1a;Api…

Taro编译警告解决方案:Error: chunk common [mini-css-extract-plugin]

文章目录 1. 背景2. 问题分析3. 解决方案3.1 更新 Taro 版本3.2 更新相关依赖3.3 调整 webpack 配置3.4 检查依赖版本 4. 拓展与分析4.1 拓展4.2 避免不必要的依赖4.3 查阅 Taro GitHub 仓库 5. 总结 &#x1f389;欢迎来到Java学习路线专栏~Taro编译警告解决方案&#xff1a;E…

golang学习笔记——斐波纳契数列

斐波纳契数列 编写一个程序来计算某个数字的斐波纳契数列。 斐波那契数列是一个数字列表&#xff0c;其中每个数字是前两个斐波那契数字之和。 例如&#xff0c;数字 6 的序列是 1,1,2,3,5,8&#xff0c;数字 7 的序列是 1,1,2,3,5,8,13&#xff0c;数字 8 的序列是 1,1,2,3,5…

[每周一更]-(第72期):Docker容器瘦身方式

Docker清理缓存操作 在构建测试的过程中&#xff0c;由于是自家小服务器&#xff0c;资源紧张&#xff0c;发现磁盘一直爆满&#xff0c;删除一些大镜像还是会占满的情况&#xff0c;就想到是不是也是缓存问题。 经过查询确实是build过程中的缓存启发的占用问题。 因此引出以下…

WPF创建自定义控件编译通过但是找不到资源

报错&#xff1a; 原因: 路径写错了&#xff1a; 不是这样&#xff1a; Source"pack://application:,,,/Controls/Styles/xTabControl.xaml" 而是这样&#xff1a; Source"pack://application:,,,/项目名;component/Controls/Styles/xTabControl.xaml …

Objectarx 使用libcurl请求WebApi

因为开发cad需要请求服务器的数据&#xff0c;再次之前我在服务器搭设了webapi用户传递数据&#xff0c;所以安装了libcurl在objectarx中使用数据。 Open VS2012 x64 Native Tools Command Prompt补充地址&#xff1a; 我在此将相关的引用配置图片&#xff0c;cad里面的应用和…

CI/CD --git版本控制系统

目录 一、git简介 二、git使用 三、github远程代码仓库 一、git简介 Git特点&#xff1a; 速度简单的设计对非线性开发模式的强力支持&#xff08;允许成千上万个并行开发的分支&#xff09;完全分布式有能力高效管理类似 Linux 内核一样的超大规模项目&#xff08;速度和数…

【Mysql】学习笔记

目录 基本操作登录指令&#xff1a;启动、关闭、重启mysql指令&#xff08;适用于centos7&#xff09;&#xff1a;查看mysql运行状态&#xff1a;删除和创建表 修改密码&#xff08;ubuntu18.04可行&#xff0c;其余版本行不行不知道&#xff09;3 使用MYSQL了解数据库和表 4 …

VR智慧景区:VR赋能文旅产业,激活消费潜能

随着国家数字化战略的不断深入实施&#xff0c;文旅产业数字化转型的步伐也在逐渐加快&#xff0c;以VR技术赋能文旅产业&#xff0c;让文旅景区线上线下双渠道融合&#xff0c;进一步呈现文化底蕴、激活消费潜能。 VR智慧景区以沉浸式、互动式、科技感的方式&#xff0c;将景区…

std::copy代替memcpy

在工作中&#xff0c;经常会有c/c的混合使用。但看到memcpy总是感觉不太安全&#xff0c;c中有一个替代品std::copy&#xff0c;用起来还不错&#xff0c;而且std::copy不会有效率上的损失&#xff0c;放心用吧。迭代器的方式还安全些。 将int数组转换为vector int inputArr[…

springboot+vue+element简单实现教学课程申报管理系统

目录 一、项目预览 二、项目效果图及说明 1.项目说明 1.登录 2.欢迎页 3.教师管理 4.课程申报 ​5.管理员管理 三、代码实现 1.后端项目结构图 2.数据库表脚本 3.路由配置 四、总结 一、项目预览 在线预览&#xff1a;点击访问其他项目访问&#xff1a;点击访问后端实…

恐怖地牢资产来袭!

我们将为您带来 VoxEdit 短片大赛的首场比赛&#xff01;在 6 天内创建可用资产。 主题&#xff1a;设计与恐怖和地牢相关的资产。这些资产必须非常实用&#xff0c;不需要动画。(如果你愿意&#xff0c;你也可以制作动画&#xff09;。 发挥你恐怖的一面&#xff0c;创造出适…