一.开发中为什么需要Git

因为在多人开发中Git可以管理代码,而且每个人都可以从库里面下载代码进行修改,每个人上传和修改Git都会有记录,如果出现大错误,还可以回退到正常版本。

二.Git原理

我们首先从代码库(Remote)下载代码到工作区(workspace),然后写代码,写好代码放到暂存区(index),觉得没问题了,就上传到本地库(Repository),本地库再上传到代码库(Remote)。

三. 基本操作

1.创建一个远端代码库(Remote),示例:在ubuntu上面创建远端代码库

     随便创建一个文件夹,用于存放git管理的代码库

sudo mkdir GitLib    //创建文件夹
​​​​​​​git init --bare      //创建裸代码库,创建完后,自动生成别名origin,后面用

2. 在工作区拉取远端代码库。

  • 本地端创建一个工作区的文件夹,进入Git Bash Here

  • 总共有四种协议(http,https,ssh,git)来和远端交互通,常用我们用ssh公钥进行git服务器交互就行。
    ssh-keygen -t rsa    //生成公钥
  •  一直回车,就会把公钥放在C:\Users\SF\.ssh,复制里面公钥
  • 把公钥放到服务器上面
    cd ~
    cd .ssh
    vi authorized_keys
    然后把刚刚复制的公钥放进去保存就行
  • 拉取服务器代码
     git clone ssh://harry@192.168.235.130:/home/harry/VsCodeProject/GitLib

    就会出现以下文件夹,(当然文件夹名字随便改,这是我改过的,原来的名字和服务器上面一样)

3.基础设置(用于后面知道是谁上传的代码什么的)

cd GitLib-sxf    //进入文件夹
git config user.name sxf    //设置用户名
git config user.email sxf@qq.com    //设置邮箱

4. Git各种操作指令

git add .        //把所有文件放到暂存区(index)
git add 文件名   //把单个文件放到暂存区(index)git commit .  -m "feat:function"      //把所有文件放到本地代码库(Repository)
git commit 文件名 -m "feat:function"  //把单个文件放到本地代码库(Repository)git push origin master//把存放在本地代码库的代码放到服务器上面(Remote),origin是创建服务器时候默认名,master是分支,意思是从那支分支提交到服务器origingit pull        //从服务器拉取代码到工作区git status      //查看状态,代码处于什么阶段
git log        //生成提交日志,看谁,在什么时候提交什么东西

5.逆向操作

git restore -S 文件名    //index->workspace,暂存区回退到工作区git reset --soft head^    //Repository->index,本地库回退到暂存区index
git reset --mixed head^    //Repository->workspace,本地库回退到工作区workspace
git reset --hard head^    //Repository->null,本地库直接删除之前操作git checkout        //workspace -> null,重置workspace里面的修改,例如:你添加一个函数,但你不想要了,可以使用这个
git checkout -- file
git checkout -f

6.整理操作

git commit --amend    //整理上一次提交,一个代码,你每次加一个函数就提交一次,日志里面就有你多次提交记录,显得很麻烦,如果只想日志里面出现一次,就用这个git rebase -i    //多次提交日志合并成一个

7.分支操作

git branch    //查看分支git branch 分支名    //创建分支
git checkout -b 分支名    //创建分支,并进入这个分支
git checkout 分支名    //切换到指定分支 
git switch 分支名    //切换到指定分支 git merge    //合并分支git branch -d 分支名    //删除分支如果你是在分支线上面添加修改代码,就得以下步骤更新代码数据:1.拉取 master最新数据;
git switch master//进入主线
git pull    //拉取最新代码2.先把 master合并到develop
git switch 分支名    //变更到分支
git merge master    //合并主线最新代码3.然后测试代码
进入代码解决冲突(因为人家比你先写好代码提交,所有你拉取最新代码后,占用同样位置,所有产生冲突)
git add.
git commit . -i -m "......"    //.是提交所有文件,-i是解决冲突提示文件,-m是添加提示4.合并到master,测试如果ok提交到远端
git checkout master
git merge 分支名
git push origin master

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

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

相关文章

OpenAI重磅开源GPT-oss:首款支持商用的AI Agent专属模型

今日凌晨,OpenAI宣布开源两款全新大模型——GPT-oss-120B(1168亿参数)与GPT-oss-20B(209亿参数),成为全球首个支持商业化应用的开放权重推理模型。该模型专为AI智能体(Agent)设计&am…

【STM32】GPIO的输入输出

GPIO是通用的输入输出接口,可配置8种输入模式,输出模式下可控制端口输出高低电平,用于点亮LED、控制蜂鸣器、模拟通信协议等;输入模式下可以读取端口的高低电平或者电压,用于读取按键、外接模块的电平信号、ADC的电压采…

5分钟了解OpenCV

在数字化时代,图像和视频已经成为信息传递的核心载体。从手机拍照的美颜功能到自动驾驶的路况识别,从医学影像分析到安防监控系统,视觉技术正深刻改变着我们的生活。而在这背后,OpenCV 作为一款强大的开源计算机视觉库&#xff0c…

Oracle 关闭 impdp任务

Oracle 关闭 impdp任务 执行 impdp system/123456 attachSYS_EXPORT_TABLE_01 执行 stop_jobimmediate

数据结构——链表2

1.2 实现单链表 在上一篇文章中&#xff0c;单链表的实现只有一少部分&#xff0c;这一篇接着来了解单链表剩下的接口实现。 SList.h#pragma once #include<stdio.h> #include<stdlib.h> #include<assert.h>//定义单链表就是定义节点&#xff0c;因为单链表…

Windows和Linux应急响应以及IP封堵

目录 1、Windows入侵排查思路 1.1 检查系统账号安全 1.2 检查异常端口、进程 1.3 检查启动项、计划任务、服务 1.4 检查系统相关信息 1.5 自动化查杀 1.6 日志分析 系统日志分析 Web 访问日志 2、Linux 入侵排查思路 2.1 账号安全 2.1.1、基本使用 2.1.2、入侵排查…

MIT成果登上Nature!液态神经网络YYDS

2025深度学习发论文&模型涨点之——液态神经网络液态神经网络&#xff08;Liquid Neural Networks&#xff0c;LNN&#xff09;是一种受生物神经系统启发的连续时间递归神经网络&#xff08;RNN&#xff09;&#xff0c;其核心创新在于将静态神经网络转化为由微分方程驱动的…

AI 对话高效输入指令攻略(四):AI+Apache ECharts:生成各种专业图表

- **AI与数据可视化的革命性结合**:介绍AI如何降低数据可视化门槛,提升效率。 - **Apache ECharts:专业可视化的利器**:使用表格对比展示ECharts的特点、优势和适用场景。 - **四步实现AI驱动图表生成**:通过分步指南讲解从环境准备到图表优化的全流程,包含多个代码示例及…

vue2 基础学习 day04 (结构/样式/逻辑、组件通信、进阶语法)下

一、非父子通信-event bus 事件总线1.作用非父子组件之间&#xff0c;进行简易消息传递。(复杂场景→ Vuex)2.步骤创建一个都能访问的事件总线 &#xff08;空Vue实例&#xff09;import Vue from vue const Bus new Vue() export default BusA组件&#xff08;接受方&#xf…

ubuntu 20.04 C和C++的标准头文件都放在哪个目录?

在 Ubuntu 20.04 中&#xff0c;C 和 C 标准头文件的存放目录主要由编译器&#xff08;如 GCC&#xff09;的安装路径决定&#xff0c;通常分为以下两类&#xff1a;​1. C 标准头文件​C 语言的标准头文件&#xff08;如 <stdio.h>、<stdlib.h> 等&#xff09;默认…

change和watch

是的&#xff0c;你理解得很对&#xff01; change 与 v-model 的结合&#xff1a;change 事件通常用于监听 表单元素的变化&#xff0c;但它并不一定意味着值发生了变化。它主要是当 用户与输入框交互时&#xff08;如点击选项、选择文本框内容、提交表单等&#xff09;触发的…

分布式微服务--GateWay(1)

一、什么是微服务网关&#xff08;API Gateway&#xff09; 定义&#xff1a;微服务网关是整个系统请求的统一入口&#xff0c;负责请求转发、过滤处理、安全校验等。 作用&#xff1a; 请求路由 日志记录 权限控制 参数校验 解决跨域问题 黑白名单控制 限流、熔断、降级…

大文件断点续传(vue+springboot+mysql)

断点续传vue前端代码后端代码controller 层service层持久层主表&#xff0c;初始化单次上传文件表&#xff0c;单次上传所有的文件记录文件分块表科普信息参考其他博主 流程图 vue前端代码 这里是只做了demo示例&#xff0c;主线测试没什么问题&#xff0c;前端同学可参考修…

Nodejs》》MySql

Node.js 操作MySQL数据库 文档 # 项目要先安装mysql包npm i mysqlxx // 安装指定版本npm i mysql // 默认安装最新版本 # 连接 mysq// 使用连接池连接const mysql require(mysql)# 建立连接const db mysql.createPool({host:, // 数据库的IP地址user:ro…

金仓数据库常见问题(持续更新)

目录 1.查看大小是否敏感写参数&#xff0c;提示&#xff1a;未认可的配置参数 "case_sensitive" 2.sys_backup.sh init时提示can not connect the primary node 3.设置逻辑备份运行脚本时提示错误are not allowed to use this program (crontab) 4.修改表字段类…

Docker Buildx最佳实践:多架构镜像构建指南

文章目录为什么需要 Docker Buildx安装与启用 Docker Buildx创建多架构构建器实例构建多架构镜像优化构建性能调试多架构构建实战案例&#xff1a;构建 Go 应用多架构镜像总结Docker Buildx 是 Docker 官方推出的扩展工具&#xff0c;用于支持多平台镜像构建&#xff0c;简化跨…

你用的是什么键盘?

在电竞行业飞速发展的当下&#xff0c;游戏键盘作为玩家操作的核心载体&#xff0c;其性能表现直接影响着游戏体验与竞技结果。而赛卓电子推出的磁轴键盘专用芯片 SC4823&#xff0c;凭借一系列突破性的技术特性&#xff0c;正成为游戏键盘领域的性能革新者。​对于游戏玩家而言…

Activiti 中各种 startProcessInstance 接口之间的区别

前言在用 RuntimeService 接口启动流程实例时&#xff0c;总是分不清楚不同 startProcessInstanceXXX 接口之间的区别&#xff0c;这篇文章基于 Activiti 7.0.0.GA 版本&#xff0c;对这一类接口进行一个梳理和归类。详解接口列表RuntimeService 接口中以 startProcessInstance…

新手BUG:函数中 static 变量的赋值语句只会执行一次

在 C 函数中使用 static 变量时&#xff0c;很多新手会陷入一个认知误区&#xff1a;认为变量的初始化语句会在每次函数调用时执行。比如在bool funcA() { // Q&#xff1a;多次调用funcA&#xff0c;funcB会被执行几次&#xff1f;// A&#xff1a;1次static bool value func…

Python 基础详解:数据类型(Data Types)—— 程序的“数据基石”

一、引言&#xff1a;为什么数据类型如此重要&#xff1f;在 Python 编程中&#xff0c;数据类型决定了&#xff1a;数据的存储方式可以对数据执行的操作数据的取值范围不同类型之间的运算规则理解数据类型是编写正确、高效程序的基础。Python 是动态类型语言&#xff0c;虽然你…