建站易/今日百度小说排行榜风云榜

建站易,今日百度小说排行榜风云榜,电子商务网站的建设,网站建设公司中心Git最佳实践指南:从入门到熟练(Windows/Linux双系统详解) 一、环境搭建与基础配置(适用Windows/Linux) 1.1 Git安装与验证 # Windows系统安装(推荐Chocolatey包管理) # 直接下载git二进制文件…

Git最佳实践指南:从入门到熟练(Windows/Linux双系统详解)

一、环境搭建与基础配置(适用Windows/Linux)

1.1 Git安装与验证

# Windows系统安装(推荐Chocolatey包管理)
# 直接下载git二进制文件安装包更方便
choco install git# Linux系统安装(Debian系)
sudo apt-get update && sudo apt-get install git# 验证安装
git --version

安装教程参考:CSDN《Windows系统Git安装教程》1、《Linux源码安装Git》1

1.2 全局身份配置

# 设置全局用户名(建议与代码托管平台一致)
git config --global user.name "YourName"
git config --global user.email "your_email@example.com"# 查看配置
git config --list

身份信息会永久记录在提交历史中2

1.3 SSH密钥生成(团队协作必备)

# 生成RSA密钥对(两系统通用)
ssh-keygen -t rsa -b 4096 -C "your_email@example.com"# Windows默认存储路径:
# C:\Users\用户名\.ssh\id_rsa.pub# Linux默认存储路径:
# ~/.ssh/id_rsa.pub

将公钥添加到GitHub/GitLab的SSH Keys设置中6


1.4 分支策略规划矩阵

分支类型创建方式生命周期典型命名
develop主开发分支永久develop
featuregit checkout -b feature/xxx短期feature/login
hotfixgit checkout -b hotfix/xxx短期hotfix/payment
releasegit checkout -b release/v1.0中期release/v1.0

1.5 分支策略矩阵

分支类型生命周期操作权限典型命名
main永久只读main/master
release短期只读release/v1.0
hotfix短期开发hotfix/login
feature中期开发feature/pay

1.6 文件状态管理说明

状态查看命令转换操作
未跟踪git status红色git add <file>
已暂存git status绿色git restore --staged
已提交git loggit commit --amend

1.7 Git三区工作原理11

Git三区工作流程图

1.7.1 三区对应命令
工作区暂存区版本库
git addgit commitgit push
git restoregit resetgit tag
文件修改可见临时存储区历史版本存储
1.7.2 状态转换示例
# 从工作区到暂存区
git add main.py# 从暂存区撤回
git restore --staged main.py# 提交到版本库
git commit -m "新增核心模块"

二、新项目启动标准流程(团队协作版)12

Git三个工作区示意图
(注:三个核心工作区说明详见附录)

2.1 初始化仓库(组长操作)

# 创建主仓库(GitLab/GitHub新建仓库)
# 设置默认分支为develop
git init --initial-branch=develop# 创建并切换分支(推荐)git checkout -b feature/login# 查看分支拓扑图
git log --graph --oneline --all# 合并分支(保留提交历史)
git checkout main
git merge feature/login# 变基操作(线性历史)
git checkout feature/login
git rebase main

变基前必须确保分支未推送到远程3

2.2、仓库管理关键操作(组长)

2.2.1 本地仓库改名(跨平台方案)34

# Windows系统
ren old_project new_project
cd new_project
git remote set-url origin new_repo_url# Linux系统
mv old_project new_project
cd new_project
git remote set-url origin git@newhost:user/new_project.git
2.2.2 远程仓库改名(需权限)
# 托管平台操作(以GitHub为例):
1. Settings -> Repository name修改
2. 本地同步:
git remote set-url origin git@github.com:user/new_name.git 

2.2.3 修改远程关联(三种方法)910

# 方法一:直接修改(推荐)
git remote set-url origin git@newhost.com:user/repo.git# 方法二:先删后加
git remote rm origin
git remote add origin git@newhost.com:user/repo.git# 方法三:编辑配置文件
vi .git/config  # 修改[remote "origin"]下的url

2.3 成员协作配置

# 成员操作(以Linux为例)
# 本地初始化(适合新项目)
mkdir project && cd project
git init#已有项目
cd devRoot
git clone git@gitlab.com:group/project.git   # 克隆主仓库
cd project
git remote rename origin upstream            # 重命名主仓库引用
git remote add origin git@gitlab.com:user/project.git  # 添加个人仓库
git push -u origin develop                   # 推送本地分支
2.3.1 代码暂存与恢复
# 暂存当前修改(紧急切换分支时)
git stash push -m "暂存登录模块修改"# 查看暂存列表
git stash list# 恢复最近暂存
git stash pop# 选择性恢复
git stash apply stash@{2}

2.4 冲突解决四步法

  1. 定位冲突文件:git status显示冲突文件
  2. 使用IDE工具合并(VSCode/GitKraken)
  3. 手动编辑标记区(保留需要的代码)
  4. 标记解决完成:
git add resolved_file
git commit -m "解决登录模块冲突"

三、版本控制进阶技巧

3.1 历史操作追溯

# 查看精简历史
git log --oneline -n 5# 文件修改追溯
git blame src/main.js# 差异对比(跨分支)
git diff main..feature/pay --stat

3.2 版本回滚策略

# 软回退(保留修改)
git reset --soft HEAD~1# 硬回退(慎用)
git reset --hard a1b2c3d# 恢复误删提交
git reflog
git checkout lost_commit_hash

四、跨平台操作差异处理

4.1 换行符统一方案

# 全局设置(推荐)
git config --global core.autocrlf input  # Linux/Mac
git config --global core.autocrlf true   # Windows# 修复现有仓库
git rm --cached -r .
git reset --hard

4.2 路径处理规范

# Windows路径处理(转义特殊字符)
git add "src/modules/new\ feature"# Linux路径处理
git add src/modules/new_feature

五、最佳实践清单

5.1 提交规范(参考Angular标准)

git commit -m "feat(login): 增加短信验证码登录功能- 实现短信平台对接
- 添加频率限制功能
- 完善错误处理逻辑Closes #123"

类型说明:feat/fix/docs/style/refactor/test3

5.2 每日工作流模板19

5.2.1 早间同步
# 早间同步
# 拉取最新代码(推荐变基方式)
git fetch upstream
git rebase upstream/develop
git fetch --all --prune
git rebase origin/main
5.2.2 功能开发流程
# 创建功能分支,开发过程
git checkout -b feature/user-auth# ... coding ...增加新功能
# 开发完成后提交
git add .
git commit -m "feat(auth): 增加JWT认证模块 "
git push origin HEAD:feature/user-auth# 解决冲突后提交
git add .
git rebase --continue
5.2.3 晚间清理操作
# 晚间推送
# 创建合并请求(MR/PR)
git push origin feature/xxx# 删除已合并分支
git branch --merged | grep -v '\*\|develop' | xargs -n 1 git branch -d# 清理远程引用
git remote prune origin

六、高频问题解决方案

6.1 分支误删恢复

# 查找丢失的提交
git reflog
# 恢复分支
git checkout -b recovered-branch commit_hash# 基于main创建热修复分支
git checkout -b hotfix/payment main# 提交修复代码
git commit -m "fix(pay): 修复金额计算精度问题"# 合并到main和develop
git checkout main
git merge --no-ff hotfix/payment
git checkout develop
git merge --no-ff hotfix/payment

6.2 清理历史大文件

# 查找大文件
git rev-list --objects --all | grep "$(git verify-pack -v .git/objects/pack/*.idx | sort -k 3 -n | tail -5 | awk '{print$1}')"# 使用BFG清理
java -jar bfg.jar --strip-blobs-bigger-than 100M
git reflog expire --expire=now --all
git gc --prune=now --aggressive

七、可视化工具推荐

7.1 工具对比表

工具适用场景跨平台学习曲线
GitKraken复杂分支管理✔️中等
SourceTree日常操作✔️简单
VS Code GitLens代码追溯✔️
TortoiseGit文件状态可视化Windows

推荐组合:VS Code + GitLens插件3

八、持续学习资源推荐

  1. 官方文档:git help <command>
  2. 图解Git:https://marklodato.github.io/visual-git-guide
  3. 交互式学习:https://learngitbranching.js.org
  4. 进阶书籍:《Pro Git》(免费电子版)35
  5. 安装git,关于git的一切及vs code 跟git的结合在上面链接中说得很明白。

本指南综合Git核心原理与工程实践经验,覆盖95%日常开发场景。建议配合实际项目演练掌握各项技能,遇到特殊问题时可查阅对应章节的解决方案。

## 附录:进阶操作速查表| 操作类型         | Windows命令示例              | Linux命令示例               |
|------------------|------------------------------|-----------------------------|
| 分支重命名       | git branch -m old new        | git branch -m old new       |
| 查看远程URL      | git remote -v                | git remote -v               |
| 修改提交信息      | git commit --amend           | git commit --amend          |
| 差异比较          | git diff HEAD^               | git diff HEAD^              |> 本指南整合Git核心原理与工程实践,覆盖项目全生命周期操作。建议结合可视化工具(如VS Code GitLens)提升操作效率,遇到特殊问题时优先使用`git reflog`追溯操作历史。

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

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

相关文章

联想 SR590 服务器 530-8i RAID 控制器更换损坏的硬盘

坏了的硬盘会自动亮黄灯。用一个空的新盘来替换&#xff0c;新盘最好不要有东西。但是有东西可能也没啥&#xff0c;因为我看 RAID 控制器里有格式化的选项 1. 从 IPMI 把服务器关机&#xff0c;电源键进入绿色闪烁状态 2. 断电&#xff0c;推开塑料滑块拉出支架&#xff0c;…

【c语言】字符函数和字符串函数(1)

一、字符分类函数 c语言中有部分函数是专门做字符分类的&#xff0c;也就是一个字符是属于什么类型的字符&#xff0c;这些函 数的使用要包含一个头文件ctype.h中。 其具体如下图所示&#xff1a; 这些函数的使用方式都类似&#xff0c;下面我们通过一个函数来看其…

六十天前端强化训练之第二天CSS选择器与盒模型深度解析

欢迎来到编程星辰海的博客讲解 目录 一、CSS 核心概念 1. 三种引入方式 2. CSS 注释 3. 常见单位系统 二、CSS选择器核心知识 1. 基础选择器类型 2. 组合选择器 3. 伪类选择器&#xff08;部分示例&#xff09; 4. 优先级计算规则 三、盒模型深度解析 1. 标准盒模型图…

【音视频】音视频录制、播放原理

一、音视频录制原理 通常&#xff0c;音视频录制的步骤如下图所示&#xff1a; 我们分别从音频和视频开始采样&#xff0c;通过麦克风和摄像头来接受我们的音频信息和图像信息&#xff0c;这通常是同时进行的&#xff0c;不过&#xff0c;通常视频的采集会比音频的采集慢&…

解锁养生密码,拥抱健康生活

在快节奏的现代生活中&#xff0c;养生不再是一种选择&#xff0c;而是我们保持活力、提升生活质量的关键。它不是什么高深莫测的学问&#xff0c;而是一系列融入日常的简单习惯&#xff0c;每一个习惯都在为我们的健康加分。 早晨&#xff0c;当第一缕阳光洒进窗户&#xff0c…

7种内外网数据交换方案全解析 哪种安全、高效、合规?

内外网数据交换方案主要解决了企业跨网络数据传输中的安全、效率与合规性问题。通过采用先进的加密技术、高效的数据传输协议以及严格的审批和审计机制&#xff0c;该方案确保了数据在内外网之间的安全交换&#xff0c;同时提高了传输效率&#xff0c;并满足了企业对数据合规性…

【WSL2】 Ubuntu20.04 GUI图形化界面 VcXsrv ROS noetic Vscode 主机代理 配置

【WSL2】 Ubuntu20.04 GUI图形化界面 VcXsrv ROS noetic Vscode 主机代理 配置 前言整体思路安装 WSL2Windows 环境升级为 WIN11 专业版启用window子系统及虚拟化 安装WSL2通过 Windows 命令提示符安装 WSL安装所需的 Linux 发行版&#xff08;如 Ubuntu 20.04&#xff09;查看…

Solidity study

Solidity 开发环境 Solidity编辑器&#xff1a;Solidity编辑器是一种专门用于编写和编辑Solidity代码的编辑器。常用的Solidity编辑器包括Visual Studio Code、Atom和Sublime Text。以太坊开发环境&#xff1a;以太坊开发环境&#xff08;Ethereum Development Environment&am…

【废物研究生零基础刷算法】DFS与递归(一)典型题型

文章目录 跳台阶递归实现指数级枚举递归实现排列型枚举上面两题总结 递归实现组合型枚举P1036选数 跳台阶 思路&#xff1a; 如果 n 1&#xff0c;只有一种走法&#xff08;走 1 级&#xff09;。如果 n 2&#xff0c;有两种走法&#xff08;11 或 2&#xff09;。对于 n &g…

【Python量化金融实战】-第1章:Python量化金融概述:1.1量化金融的定义与发展历程

本小节学习建议&#xff1a;掌握Python编程、统计学&#xff08;时间序列分析&#xff09;、金融学基础&#xff08;资产定价理论&#xff09;三者结合&#xff0c;是进入量化领域的核心路径。 &#x1f449; 点击关注不迷路 &#x1f449; 点击关注不迷路 文章目录 1.1 量化金…

观成科技:海莲花“PerfSpyRAT”木马加密通信分析

1.概述 在2024年9月中旬至10月&#xff0c;东南亚APT组织“海莲花”通过GitHub发布开源安全工具项目&#xff0c;针对网络安全人员发起了定向攻击。通过对相关攻击活动进行分析&#xff0c;可以将其与一些海莲花的样本关联起来。这些样本的通信数据结构与海莲花此前使用的攻击…

2024-2025 学年广东省职业院校技能大赛 “信息安全管理与评估”赛项 技能测试试卷(一)

2024-2025 学年广东省职业院校技能大赛 “信息安全管理与评估”赛项 技能测试试卷&#xff08;一&#xff09; 第一部分&#xff1a;网络平台搭建与设备安全防护任务书DCRS:DCFW:DCWS:WAF: 第二部分&#xff1a;网络安全事件响应、数字取证调查、应用程序安全任务书任务 1&…

2月25(信息差)

&#x1f30d;四川省人民医院接入DeepSeek 将AI技术应用于看病全流程 &#x1f384;机器人新风口&#xff01;OpenAI押注公司 采用这种新材料 更轻盈耐磨&#xff01;尼龙概念股名单 ✨小米15 Ultra、小米SU7 Ultra定档2月27日 雷军宣布&#xff1a;向超高端进发 1.深夜王炸&…

【栈与队列】二叉树最大宽度

文章目录 662. 二叉树最大宽度解题思路&#xff1a;队列 广度搜索 662. 二叉树最大宽度 662. 二叉树最大宽度 ​ 给你一棵二叉树的根节点 root &#xff0c;返回树的 最大宽度 。 ​ 树的 最大宽度 是所有层中最大的 宽度 。 ​ 每一层的 宽度 被定义为该层最左和最右的非…

大语言模型安全测试:WDTA 标准下的全面解读与实践展望

1.前言 在人工智能&#xff08;AI&#xff09;飞速发展的时代&#xff0c;大语言模型&#xff08;LLM&#xff09;凭借其强大的语言理解和生成能力&#xff0c;广泛应用于智能客服、智能写作、智能翻译等众多领域&#xff0c;深刻改变着人们的生活和工作方式。然而&#xff0c…

在WINDOWS系统使用CMake gui编译NLopt配合VSCode使用

1. 准备工作 安装CMake&#xff1a;从CMake官网下载并安装CMake。下载Nlopt源码&#xff1a;从Nlopt官网或GitHub仓库下载Nlopt源码。安装编译器&#xff1a;确保已安装Visual Studio或其他支持的编译器&#xff08;如MinGW&#xff09;。 2. 配置CMake 方式1 打开CMake GU…

C++ QT 6.6.1 QCustomPlot的导入及使用注意事项和示例 | 关于高版本QT使用QCustomPlot报错问题解决的办法

C QT 6.6.1 QCustomPlot的导入及使用注意事项和示例 | 关于高版本QT使用QCustomPlot报错问题解决的办法 记录一下 qmake .pro文件的配置 QT core gui printsupportgreaterThan(QT_MAJOR_VERSION, 4): QT widgetsCONFIG c17# You can make your code fail to compil…

LLM+多智能体协作:基于CrewAI与DeepSeek的邮件自动化实践

文章目录 引言理解 Flows&#xff08;工作流&#xff09;与 Crews&#xff08;协作组&#xff09;一、环境准备与工具安装1.1 Python环境搭建1.2 创建并激活虚拟环境1.3 安装核心依赖库&#xff08;crewai、litellm&#xff09; 二、本地DeepSeek R1大模型部署2.1 Ollama框架安…

window下kafka安装

kafka下载 下载好,直接解压即可 默认是带有zookeeper(注册中心) 需要先启动zookeeper zookeeper配置 先配置下zookeeper 这个data文件夹是自定建的 随意建在哪里 注意 这里斜杠用和linux一样 启动zookeeper 进入bin/windows目录 启动zookeeper zookeeper-server-start.ba…

浅谈 Redis 主从复制原理(二)

大家好&#xff0c;我是此林。 【浅谈 Redis 主从集群原理&#xff08;一&#xff09; 】 上一篇文章中&#xff0c;说到了 Redis 主从复制的全量同步和增量同步&#xff0c;repl_baklog 复制缓冲区&#xff0c;以及 slave 挂掉之后数据同步的措施。 下面介绍的上一篇遗留问…