go语言学习-git代码管理

1、功能

1、版本控制:可以追踪代码的变更记录,并且可以看到修改的内容,以及版本的回溯
2、分支管理:可以让我们同时处理多个任务,并且不会影响稳定的分支(主分支)
3、团队协作:可以让多人协同开发,并且在没有相互影响的条件下独立完成工作
4、代码审查、知识wiki等

2、主流代码仓库

  • github
  • gitee
  • gitlab

3、 git使用

git官网

3.1 git配置

1、配置全局用户名和邮箱:

git config --global user.name "你的名字" 
git config --global user.email 你的邮箱

2、查看配置:

git config user.name
git config --list

3、配置 SSH 密钥:
如果没有生成过 ssh key 需要先生成 key

ssh-keygen.exe -t rsa -C "你的邮箱"  #windows生成方法
ssh-keygen  -t rsa -C "你的邮箱"  #linux生成

4、之后把公钥放置在仓库(Gitee 为例,账户自行注册)
找到设置的位置,然后按照下面部分去修改。
在这里插入图片描述

3.2 git仓库管理

在这里插入图片描述

#把仓库克隆到本地
git clone git@gitee.com:***.git

#创建一个文件并上传
git add .
git commit -am "first commit"
git push origin master

#提交已有的代码至新仓库
git init
git add README.md
git commit -m "first commit"
git remote add origin git@gitee.com:***.git
git push -u origin "master"

3.3 git基础命令

#克隆远程已有的仓库至本地
git clone 远程地址
#更新本地代码(拉取远程仓库中的新代码到本地)
git pull <shortname> <remote_branch>:<local_brach>
#添加所有修改的文件,但不包含删除文件到暂存区
git add .
#添加所有修改的文件以及删除的文件到暂存区
git add -A (--all)
#添加单个或者多个文件/目录到暂存区
git add file1/dir1 file2/dir2
#从文件从暂存区提交至本地仓库
	# -a: 类似于 git add,但是不包含新添加的文件 
	# -m: 注释内容
git commit -am "提交信息"
#把本地仓库的代码提交至远程仓库
git push <shortname> <remote_branch>

3.4 Git分支管理

# 创建分支(不常用)
git branch NEW_BRANCH_NAME
# 切换分支
git checkout BRANCH_NAME
# 创建分支并切换到新分支(常用):
git checkout -b NEW_BRANCH_NAME
# 查看本地仓库所有分支:
git branch
# 查看远程仓库的所有分支:
git branch -r
# 查看远程和本地所有分支:
git branch -a
# 同步新分支到远程仓库
git push origin NEW_BRANCH_NAME
# 删除分支:
git branch -d BRANCH_NAME
# 强制删除分支:
git branch -D BRANCH_NAME
# 删除远程分支:
git push origin --delete BRANCH_NAME
# 合并分支:
git merge BRANCH_NAME

3.5 Git版本管理

# 查看代码提交记录:
git log
# 查看当前环境文件变更状态:
git status
# 查看修改了什么内容:
# 还可以直接对比两个版本的差异:
git diff COMMIT_ID COMMIT_ID
# 撤销单个文件的修改:
git checkout -- FILE_NAME
# 撤销所有文件的修改:
git reset --hard
# 回滚到某个版本:
git reset --hard 4cd8a3b9f2e19111cda949b792ed8f3bd22795fd
# 把回滚的内容强制推送到远程仓库:
git push origin master --force

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

ESP32 Arduino实战基础篇-使用中断和定时器

本教程介绍如何使用 PIR 运动传感器通过 ESP32 检测运动。在此示例中,当检测到运动(触发中断)时,ESP32 会启动计时器并打开 LED 并持续预定义的秒数。当计时器倒计时结束时,LED 自动关闭。 通过这个例子,我们还将探讨两个重要的概念:中断和定时器。 中断介绍 要使用 P…

Layout工程师们--Allegro X AI实现pcb自动布局布线

Cadence 推出 Allegro X AI&#xff0c;旨在加速 PCB 设计流程&#xff0c;可将周转时间缩短 10 倍以上 楷登电子&#xff08;美国 Cadence 公司&#xff0c;NASDAQ&#xff1a;CDNS&#xff09;今日宣布推出 Cadence Allegro X AI technology&#xff0c;这是 Cadence 新一代…

使用FFmpeg合并多个ts视频文件转为mp4格式

前言 爬取完视频发现都是ts文件&#xff0c;而且都是几百KB的视频片段&#xff0c;.ts 全名叫&#xff1a;MPEG Transport Stream&#xff0c;它是一个万能的多媒体容器&#xff0c;可以装下音频、视频、字幕。有时我们需要将.ts文件转换为其他更加广泛被支持的格式&#xff0…

【Linux系统编程十八】:(基础IO5)--动静态库共享/动静态加载问题(涉及地址空间)

【Linux系统编程十八】&#xff1a;动静态库共享/动静态加载问题(涉及地址空间&#xff09; 一.可执行程序如何被加载的1.加载之前2.加载之后①如何执行第一条命令②缺页中断/与地址空间建立联系 二.动态库如何加载的三.动态库如何实现多进程间共享的 一.可执行程序如何被加载的…

怎么调监控清晰度,监控画面不清晰怎么修复?

监控画面不清晰怎么修复&#xff0c;通过调整视频的分辨率可以达到使视频更清晰的目的&#xff0c;另外就是如果是室外的环境下&#xff0c;视频的监控镜头会积累灰尘&#xff0c;擦一下镜头有可能会使得拍摄的视频更清晰一些。另外就是可以通过一些软件将视频分辨率提高&#…

零件更复杂、公差更严格?3D桌面引擎HOOPS助力MBD开发,优化质量流程!

在制造与计量行业&#xff0c;随着零件变得越来越复杂、越来越小并且需要更严格的公差&#xff0c;质量保证比以往任何时候都更加重要。工业4.0使基于3D模型的定义工作流程变得更加普遍&#xff0c;但质量流程仍然严重依赖2D图纸。从MBD数据集手动准备2D绘图非常耗时&#xff0…

mysql之squid代理服务器

&#xff08;一&#xff09;squid代理服务器 1、nginx做代理服务器 &#xff08;1&#xff09;反向代理&#xff08;负载均衡&#xff09; &#xff08;2&#xff09;缓存 &#xff08;3&#xff09;nginx无法做正向&#xff0c;通过proxy_pass进行反向代理 2、squid&…

010.Springboot之养老院管理系统

《010.Springboot之养老院管理系统》 项目简介 需要源码及数据库的私信… [1]本系统涉及到的技术主要如下&#xff1a; 推荐环境配置&#xff1a;DEA jdk1.8 Maven MySQL 前后端分离; 后台&#xff1a;SpringBootmybatis; 前台&#xff1a;LayuithymeleafjQuery; [2]功能模…

nginx反向代理配置

1.1 安装nginx 本节以安装“nginx-1.7.9”为例讲解nginx的安装方法&#xff0c;请确认已获取了“nginx-1.7.9.tar.gz”包。 步骤 1 以root用户登录服务器。 步骤 2 通过SSH或XFTP等工具将nginx安装包“nginx-1.7.9.tar.gz”上传到Linux服务器的“/tmp”目录下。 步骤 3 进入…

OpenAI暂停ChatGPT Plus新用户注册;迷宫与图神经网络

&#x1f989; AI新闻 &#x1f680; OpenAI暂停ChatGPT Plus新用户注册&#xff0c;考虑用户体验 摘要&#xff1a;OpenAI决定暂停ChatGPT Plus新用户注册&#xff0c;以应对开发日后使用量激增带来的压力&#xff0c;确保每个人都能享受良好的体验。根据调查机构Writerbudd…

LT8711UXD 是一款高性能双通道 Type-C/DP1.4 至 HDMI2.0 转换器

1. 描述 LT8711UXD 是一款高性能双通道 Type-C/DP1.4 至 HDMI2.0 转换器&#xff0c;设计用于将 USB Type-C 源或 DP1.4 源连接至 HDMI2.0 接收器。LT8711UXD 集成了一个 DP1.4 兼容接收器和一个 HDMI2.0 兼容发射器。此外&#xff0c;还包括两个 CC 控制器用于 CC 通信以实现…

【文件上传】empirecms 文件上传 (CVE-2018-18086)

1.1漏洞描述 描述: EmpireCMS&#xff08;帝国网站管理系统&#xff09;是一套内容管理系统&#xff08;CMS&#xff09;。 EmpireCMS 7.5版本中的e/class/moddofun.php文件的‘LoadInMod’函数存在安全漏洞。可利用该漏洞上传任意文件。 漏洞编号CVE-2018-18086漏洞类型文件…

NFS共享

目录 三种存储类型 作用&#xff1a; FTP文本传输协议 原理 FTP服务状态码 用户认证 常见FTP相关软件 vsftpd 软件介绍 用户和其共享目录 基础操作 安装服务端 客户端连接服务端 登录成功 匿名用户登录 1.服务端配置 2.客户端配置 3.服务端查看 匿名用户下载 删除…

Git 基本操作

目录 创建仓库命令 git init git clone 提交与修改 git add git status git diff git commit git reset git rm git mv git checkout git switch git restore 提交日志 git log git blame 远程操作 git remote git fetch git pull git push Git 的工作就…

C# NAudio 音频库

C# NAudio 音频库 NAudio安装NAudio简述简单示例1录制麦克风录制系统声卡WAV格式播放MP3格式播放AudioFileReader读取播放音频MediaFoundationReader 读取播放音频 NAudio安装 项目>NuGet包管理器 搜索NAudio点击安装&#xff0c;自动安装依赖库。 安装成功后工具箱会新增…

网站安全攻防战:守护数据的钢铁堡垒

在数字化时代&#xff0c;网站的安全性至关重要&#xff0c;因为它不仅关乎用户的隐私信息&#xff0c;还涉及到业务的正常运行。一旦网站受到攻击&#xff0c;可能导致数据泄露、服务中断等问题&#xff0c;因此网站安全应成为企业和个人关注的焦点。本文将探讨网站安全的重要…

GBase8a-GDCA-第一次阶段测试

文章目录 主要内容 总结 主要内容 GBase8a-第一阶段测试答案 总结 以上是今天要讲的内容&#xff0c;GBase8a-GDCA-第一次阶段测试题及答案。

NewStarCTF2023 Week3 Reverse方向 题目STL WP

分析 代码不多&#xff0c;逻辑挺清楚的。 先用Z3解出V7&#xff1a; from z3 import *s Solver() v1, v2, v3, v4, v5, v6 BitVecs(v1 v2 v3 v4 v5 v6, 32) v7, v8, v9, v10, v11 BitVecs(v7 v8 v9 v10 v11, 32)s.add((v1 << 15) ^ v1 0x2882D802120E) s.add((v2 …

Linux_安装docker

安装包管理工具yum-utils&#xff0c;并设置docker储存库&#xff08;如果已有&#xff0c;不用安装&#xff09; # 安装包管理工具 sudo yum install -y yum-utils # 安装docker储存库 sudo yum-config-manager \--add-repo \http://mirrors.aliyun.com/docker-ce/linux/cen…

ERP管理系统为何成为制造业的必备工具

ERP管理系统为何成为制造业的必备工具&#xff1f; 全球化和数字化快速发展&#xff0c;制造业面临着越来越多的挑战和机遇。为了提高生产效率、降低成本、优化资源配置&#xff0c;许多制造业企业开始引入ERP管理系统。那么&#xff0c;为何ERP管理系统成为制造业的必备工具呢…