Git从入门到精通
Git 是什么
Git 是一个分布式版本控制系统,主要用于跟踪和管理文件(尤其是代码)的变更。
Git的下载与安装
- 进入git官网下载界面,选择
Windows
系统。
- 点击选择
Git for Windows/x64 Setup
,进行安装。
注意:
Git GUI
是Git提供的一个图形界面工具,Git Bash
是Git提供的一个命令行工具,Git Bash中可以使用linux命令。
Git环境配置
- 安装好
git
后,鼠标右键,打开Git Bash
。
2.设置用户信息(用户名和邮箱)。
输入命令 :
git config --global user.name "用户名"
-----设置用户名git config --global user.email "邮箱"
-----设置邮箱
基本概念
- 仓库(Repository) :存储项目所有文件和版本历史记录的目录。
- 提交(Commit) :
保存一次修改
,包含唯一 ID、作者和描述,将此修改保存在本地仓库,同时提交推送到远程仓库。 - 分支(Branch) :从主线分离的独立开发线,默认分支通常叫
main
或master
,即主线。 - 远程仓库(Remote) :托管在网络上的共享仓库(如 GitHub)。
在项目当中,每个开发人员都有自己的一个本地仓库,用来存储项目的文件和修改记录,同时,项目中还有一个共享仓库(远程仓库),该仓库可以供所有开发者访问,其同样存放着项目的文件和修改记录,如果共享仓库崩溃,各个开发者还有各自的本地仓库,可以继续开发项目,这样不会因为远程仓库崩溃而导致整个项目的数据全部丢失,这就是 分布式 的意义
。
当多人协作开发同一个项目时,大家都各自从远程仓库上将文件或代码 拉取(pull) 到自己的本地仓库中,然后再对文件或代码进行增删改(前提:本地要创建仓库且必须要与远程仓库连接),完成后,将修改内容提交推送(push) 到 远程仓库。
本地仓库
- 本地仓库就是在本台主机上的一个用于存放远程仓库中的项目相关文件的目录。
- 创建本地仓库-----首先创建一个文件夹,在该文件夹中打开Git Bash,输入命令:
git init
,当命令行后面出现master
时,表明仓库创建成功,即该文件夹就是新建的本地仓库。
本地仓库的基本使用
在本地仓库中,对文件进行修改(增加,删除,更新)
会存在几个状态,这些修改的状态会随着我们执行Git命令而发生变化。
如上图所示,本地仓库分为3个部分,分别为工作区,暂存区,仓库
。
- 当我们使用指令创建一个文件(
touch 文件名
)时,该文件此时的状态就是未追踪(untracked
),如果我们直接修改一个现成的文件,则文件的状态就变成未暂存(unstaged
),所有文件的修改都是在工作区进行,这时候这些文件并没有与git产生联系。 - 使用指令
git add 文件名
可以将指定文件的修改从工作区转到暂存区(可以理解为一个缓冲区)。 - 暂存区可以通过使用指令
git commit 文件名
将其内的指定文件的修改提交给本地仓库,此时,就产生了联系,开始由Git来管理该文件,对该文件的修改变成了一条提交记录(换句话说,仓库中每一条提交记录,都对应着一个对应文件的版本)。 - 我们可以通过使用命令
git rm --cached 文件名
将暂存区的文件修改转到工作区,此时文件状态变成了未存储
(unstaged)。 - 使用指令
git commit -m "该条记录的注释"
,将暂存区的内容提交到仓库的当前分支,这时候,文件的修改是以一条记录的形式记录在仓库的日志中,-m
后面加的是对应记录的注释,目的告诉其他人此次修改干了什么。 - 以上,3个部分相互交互,它们交互的内容可以理解为就是指定文件的修改版本。
注意: 整个仓库的所有文件的版本都是以仓库中最新记录为准,我们可以通过日志中记录回滚到指定的仓库文件版本。
主线与分支
在 Git 中,主线(Main Branch) 和分支(Branch) 是代码管理的核心概念,用于组织不同版本的代码和并行开发。一个项目可以有多个分支,但是只能有一个主支。
- 主线:就是整个项目的 "官方"版本 ,是项目的稳定版本,始终保持可用。所有经过测试的、可发布的代码最终会合并到主线。
- 分支:是从主线(或其他分支) 分离出来的 独立开发线,用于在不干扰主线的情况下进行功能开发、Bug 修复或实验性修改。每一个开发者都各自对应着一条分支,互不干扰,独立开发,修改,当开发者完成各自任务,经测试没问题后,就会将分支合并到主线上,算是得到了 “项目官方的认可”。
- 主线与分支极大地方便了多人协作开发同一个项目,而共享仓库(远程仓库) 一般都是在网上(如GitHub,代码托管平台),这表明开发者可以远程开发项目。
注意:同一时刻,只能操作一条分支——即当前分支,仓库里面的文件与当前所在的分支有关,分支切换,仓库中的文件也会跟着切换(主线也是一条分支)。
如上图所示,HEAD->
指向哪条分支,哪条分支就是当前分支(master是主线)。
本地分支合并冲突
当两个分支都对同一个文件的同一行进行修改后,在与主线合并时,就会产生冲突,即主线到底以哪个版本为主?
这时候,我们就需要手动的去解决冲突:
- 处理文件中冲突的地方(打开冲突文件,其中的冲突标识如下,HEAD表示当前分支)。
<<<<<<< HEAD 你的修改 ======= 远程的修改 >>>>>>> 发生冲突的分支名
- 将解决完冲突的文件加入暂存区(
git add .
)。 - 提交到仓库(
git commit .
)。
开发中分支使用原则和流程
在开发中,分支一般有如下使用原则:
master (生产)分支
: 主分支(主线),整个项目工程最终上线使用的分支。develop(开发)分支
:是从master创建的分支,一般作为开发部门的主要分支,用于开发新的功能,阶段开发完成后,需要合并到master分支,准备上线。future/xxx分支
:是从develop创建的分支,因为develop分支作为开发部门的主要分支,我们不可能在上面直接进行开发(部门不止你一人),因此需要再建分支进行开发代码的编写,最后将所有的开发代码全部提交到develop(开发)分支
上。hotfix/xxx分支
:一般作为线上bug修复使用,修复完成后将该分支合并到所有的其他主要分支当中,如master分支,develop分支,test分支。test分支
:一般是用来做测试的分支。
远程仓库
远程仓库即共享仓库,通常我们会借助网上的代码托管平台来创建远程仓库,比如Github
,码云
,GitLab
等,以下以码云为例。
远程仓库的创建
- 登录码云官网,注册码云账号。
- 点击加号,创建远程仓库。
- 设置完仓库的相关信息,点击创建即可。
远程仓库身份认证
当我们要对远程仓库进行操作(拉取和推送代码)时,需要先进行身份认证,一般采用公私钥对的方式来验证身份。
配置SSH公钥
- 在本地仓库生成公钥:在Git Bash中输入命令
ssh-keygen -t rsa
,然后一路回车,如果公钥已存在,则会自动覆盖。 - 查看公钥:输入命令
cat ~/.ssh/id_rsa.pub
。 - 将公钥复制下来,在登录码云官网,点击右上角用户->点击设置->找到
ssh公钥设置
- 验证是否成功:在Git Bash中输入命令
ssh -T git@gitee.com
,回车,输入yes,再回车,出现以下信息表示成功:
通过以上方式,就将本地仓库与gitee平台的对应账号绑定,本地仓库在操作该账号对应的远程仓库时,无需再输入用户名和密码进行身份验证。
添加指定远程仓库
一个账号中可能会有很多的远程仓库,因此我们要告诉本地仓库,它对应的远程仓库具体是哪一个,绝大多数情况下,同一时刻,本地仓库只与一个远程仓库对应。
- 获取到远程仓库的地址。
- 在本地仓库中输入命令
git remote add 远程仓库的名字 远程仓库的地址
,添加远程仓库到本地,其中仓库名字可以随便取,一般命名为origin
。 - 通过 命令
git remote
,查看当前的本地仓库对应的远程仓库的名字(可能不止一个)。
远程仓库克隆
当我们想要获取到指定远程仓库中所有的内容时,我们只需要在本地Git Bash
中输入命令git clone 远程仓库的地址 本地仓库的名字
即可,该指令的作用为在本地创建一个仓库并拉取指定远程仓库中的所有内容到本地。
远程合并冲突
在一段时间,A,B修改了同一个文件,同一行代码,此时会发生合并冲突。
A在本地修改完代码后,优先提交推送到远程仓库,此时B在本地修改代码,然后也需要提交推送到远程仓库,因为B用户是晚于A用户的,因此需要先拉取远程仓库,经合并后才能进行推送,此刻就发生了远程合并冲突。
远程合并冲突的解决方式与本地合并冲突方式一致,在我们拉取并合并(pull
)到远程分支时,发生冲突,这时候,我们找到冲突的文件,进行删改,解决完冲突后,重新提交并推送。
多人协作使用远程仓库流程
在使用 Git 时,如果多人协作开发同一分支,通常需要遵循以下流程:
拉取远程更新 → 合并冲突 → 提交并推送。
如果跳过拉取直接推送修改,可能会导致以下问题:
- 推送被拒绝(最常见)-----如果远程仓库的分支已经有新提交(
其他人推送过代码
),而你的本地分支未同步(未拉取
),直接运行git push
会收到错误。 - 覆盖他人代码(危险!)-----如果强制推送(
git push -f
),会用你的本地提交覆盖远程分支,导致其他人的提交丢失。
注意:此操作非常危险,仅限特殊场景(如修复误提交),团队协作中严禁随意使用!
- 后续合并更复杂-----即使你强制推送成功,其他人在拉取代码时会发现历史冲突,需要手动解决,增加协作成本。
正确步骤:
- 拉取远程最新代码
git pull origin <分支名>
# 等同于 git fetch + git merge
-
git pull
会做两件事:- 从远程仓库下载最新代码(
git fetch
)。 - 自动合并到当前分支(
git merge
)。
- 从远程仓库下载最新代码(
- 解决合并冲突(如果有)
-
如果多人修改了同一文件的同一部分,Git 会提示冲突,需手动编辑文件解决冲突。
-
冲突标记示例:
<<<<<<< HEAD 你的修改 ======= 远程的修改 >>>>>>> commit_id
删除冲突标记,保留正确代码,然后保存文件。
- 提交并推送
git add . # 添加解决冲突后的文件
git commit -m "解决合并冲突"
git push origin <分支名> # 推送更新到远程
Git常用命令
Git 基础指令
git add 文件名
----- 将指定文件的修改由工作区转到暂存区,git add .
,工作区所有修改全部转移。git rm --cached 文件名
----- 将指定文件的修改由暂存区转到工作区,git rm --cached .
,暂存区所有修改全部转移。git status
-----获取到当前仓库工作区和暂存区中的各个文件修改信息。git commit -m "注释内容"
-----将暂存区内容提交到本地仓库的当前分支。git log
-----查看提交日志,--all
查看所有分支,--pretty=oneline
将提交信息显示为一行,--abbrev-commit
使得输出的commitId
(每条记录的唯一ID号) 更简短,--graph
以图的形式显示。git reset --hard commitID(提交记录的唯一ID)
----- 将仓库中所有文件的版本切换为指定记录提交时刻的版本,切换后,原来在该记录之后的所有记录全部被删除,该记录成为最新记录。git reflog
-----查看仓库的所有相关操作记录,从操作记录中,我们可以获取到已经被删除的记录的ID号,从而恢复到已经被删除的版本:git reset --hard 已被删除的ID号
。git branch
----- 查看所有分支。git branch 分支名
----- 创建新分支。git checkout 分支名
----- 切换到指定分支(该分支已存在)。git checkout -b 分支名
----- 创建并切换到指定分支(该分支原先不存在)。git merge 分支名
----- 将指定分支合并到当前分支(一般都是合并到master分支)。git branch -d 分支名
----- 删除指定分支,需要做检查。git branch -D 分支名
----- 强制删除指定分支,不需要做检查。git remote add 远程仓库的名字 远程仓库的地址
----- 添加远程仓库到本地。git remote
----- 查看当前的本地仓库对应的远程仓库的名字(可能不止一个),其中仓库名字可以随便取,一般命名为origin
。git push 远程仓库名 本地分支名
----- 将本地的某个分支提交推送到远程仓库。git push 远程仓库名 本地分支名:远程分支名
----- 将本地的某个分支提交推送到远程仓库,并命名,如果远程分支名与本地分支名相同,则可以省略远程分支名。
git push -f --set-upstream 远程仓库名 本地分支名:远程分支名
参数
-f
表示强制提交推送,当远程仓库对应的分支上有修改时,系统是不会让你提交的,这个时候就可以使用-f
,强制提交。参数
--set-upstream
表示让本地的该分支与对应的远程分支建立关联,这样该本地分支就与该远程分支绑定在了一起。
git push
-----将当前分支提交推送到已建立关联的远程分支上。git pull 远程仓库名 远程分支名
----- 将远程分支的更新拉到本地,并自动与当前分支进行合并。git fetch 远程仓库名 远程分支名
----- 将远程分支的更新拉到本地,但不会与当前分支进行合并。
若没有远程仓库名和远程分支名,则默认抓取与当前分支相关联的远程分支的更新内容。
忽略指定文件
当我们在提交修改时,有时候并不想把所有文件都提交,只想提交指定类型的文件,这时候,我们可以采用以下方式解决:
- 创建文件.gitignore (
touch .gitignore
)。 - 使用
vim编辑器
对文件.gitignore进行编辑,在其中添加提交时要忽略的文件,可以使用通配符,如*.jpg
表示忽略所有的jpg文件。
相关文章:
Git从入门到精通
Git 是什么 Git 是一个分布式版本控制系统,主要用于跟踪和管理文件(尤其是代码)的变更。 Git的下载与安装 进入git官网下载界面,选择Windows系统。 点击选择Git for Windows/x64 Setup,进行安装。 注意: Git GUI 是Git提供的一个图形界面工…...
Binary Prediction with a Rainfall Dataset-(回归+特征工程+xgb)
Binary Prediction with a Rainfall Dataset 题意: 给你每天的天气信息,让你预测降雨量。 数据处理: 1.根据特征值构造天气降雨量的新特征值 2.根据时间构造月和季节特征 3.处理缺失值 建立模型: 1.建立lightgbm模型 2.建立…...
【C++】unordered_map与set的模拟实现
unordered系列map和set,与普通区别 用法几乎相同,键值唯一,区别unordered系列迭代器是单向的并且遍历出来不是有序的。unordered系列在数据规模大且无序的情况下性能更优 底层实现: map 和 set :基于平衡二叉树&…...
老旧设备升级利器:Modbus TCP转 Profinet让能效监控更智能
在工业自动化领域,ModbusTCP和Profinet是两种常见的通讯协议。Profinet是西门子公司推出的基于以太网的实时工业以太网标准,而Modbus则是由施耐德电气提出的全球首个真正开放的、应用于电子控制器上的现场总线协议。这两种协议各有各的优点,但…...
编译原理--期末复习
本文是我学习以下博主视频所作的笔记,写的不够清晰,建议大家直接去看这些博主的视频,他/她们讲得非常好: 基础知识概念: 1.【【编译原理】期末复习 零基础自学】,资料 2.【编译原理—混子速成期末保过】&…...
软件工程各种图总结
目录 1.数据流图 2.N-S盒图 3.程序流程图 4.UML图 UML用例图 UML状态图 UML时序图 5.E-R图 首先要先了解整个软件生命周期: 通常包含以下五个阶段:需求分析-》设计-》编码 -》测试-》运行和维护。 软件工程中应用到的图全部有:系统…...
Go 与 Gin 搭建简易 Postman:实现基础 HTTP 拨测的详细指南
Go 与 Gin 搭建简易 Postman:实现基础 HTTP 拨测的详细指南 文章目录 Go 与 Gin 搭建简易 Postman:实现基础 HTTP 拨测的详细指南项目简介代码结构各部分代码功能说明: 代码实现:main.go代码解释 handlers/probe.go代码解释 probe…...
层次原理图
层次原理图简介 层次原理图(Hierarchical Schematic)是一种常用于电子工程与系统设计的可视化工具,通过分层结构将复杂系统分解为多个可管理的子模块。它如同“设计蓝图”,以树状结构呈现整体与局部的关系:顶层展现系…...
嵌入式硬件篇---拓展板
文章目录 前言 前言 本文简单介绍了拓展板的原理以及使用。...
Redis的主从架构
主从模式 全量同步 首先主从同步过程第一步 会先比较replication id 判断是否是第一次同步假设为第一次同步 那么就会 启动bgsave异步生成RDB 同时fork子进程记录生成期间的新数据发送RDB给从节点 清空本地数据写入RDB 增量同步 对比ReplicationID不同因此选择增量同步在Rep…...
IIS入门指南:原理、部署与实战
引言:Web服务的基石 在Windows Server机房中,超过35%的企业级网站运行在IIS(Internet Information Services)之上。作为微软生态的核心Web服务器,IIS不仅支撑着ASP.NET应用的运行,更是Windows Server系统管…...
【上位机——WPF】布局控件
布局控件 常用布局控件Panel基类Grid(网格)UniformGrid(均匀分布)StackPanel(堆积面板)WrapPanel(换行面板)DockerPanel(停靠面板)Canvas(画布布局)Border(边框)GridSplitter(分割窗口)常用布局控件 Grid:网格,根据自定义行和列来设置控件的布局StackPanel:栈式面板,包含的…...
使用 C# 入门深度学习:线性代数详细讲解
在深度学习的领域中,线性代数是基础数学工具之一。无论是神经网络的训练过程,还是数据的预处理和特征提取,线性代数的知识都无处不在。掌握线性代数的核心概念,对于理解和实现深度学习算法至关重要。在本篇文章中,我们…...
操作系统之EXT文件系统
1.理解硬件 1.1磁盘、服务器、机柜、机房 机械磁盘是计算机中唯一的一个机械设备 磁盘--- 外设慢容量大,价格便宜 1.1.1光盘 1.1.2服务器 1.1.3机房 1.2磁盘的物理结构 1.3磁盘的存储结构 一个盘片又两个面 每个面都有一个磁头 磁头沿着盘面的半径移动 1.3.1…...
继MCP、A2A之上的“AG-UI”协议横空出世,人机交互迈入新纪元
第一章:AI交互的进化与挑战 1.1 从命令行到智能交互 人工智能的发展历程中,人机交互的方式经历了多次变革。早期的AI系统依赖命令行输入,用户需通过特定指令与机器沟通。随着自然语言处理技术的进步,语音助手和聊天机器人逐渐普…...
Java大厂面试:从Web框架到微服务技术的场景化提问与解析
Java大厂面试:从Web框架到微服务技术的场景化提问与解析 场景: 某知名互联网大厂的面试现场。面试官一脸严肃,对面坐着搞笑的程序员谢飞机。以下是他们的对话: 第一轮:Web框架基础与数据库操作 面试官:谢…...
最新缺陷检测模型:EPSC-YOLO(YOLOV9改进)
目录 引言:工业缺陷检测的挑战与突破 一、EPSC-YOLO整体架构解析 二、核心模块技术解析 1. EMA多尺度注意力模块:让模型"看得更全面" 2. PyConv金字塔卷积:多尺度特征提取利器 3. CISBA模块:通道-空间注意力再进化 4. Soft-NMS:更智能的重叠框处理 三、实…...
leetcode hot100刷题日记——2.字母异位词分组
涉及知识点:vector、哈希表 解答我的解答的时间复杂度分析我的解答的空间复杂度分析复习:排序算法的时间复杂度 和第一题需要的知识点相同,所以知识点复习可见 link1《leetcode hot100刷题日记——1.两数之和》 解题思路:是字母异位词的字符…...
elementUI 单选框存在多个互斥的选项中选择的场景
使用 el-radio-group 来使用单选框组,代码如下: <el-radio-group input"valueChangeHandler" v-model"featureForm.type"><el-radio name"feature" label"feature">业务对象</el-radio><…...
基于区块链技术的智能汽车诊断与性能分析
我是穿拖鞋的汉子,魔都中坚持长期主义的汽车电子工程师。 老规矩,分享一段喜欢的文字,避免自己成为高知识低文化的工程师: 钝感力的“钝”,不是木讷、迟钝,而是直面困境的韧劲和耐力,是面对外界…...
基于区块链技术的供应链溯源系统:重塑信任与透明度
在当今全球化的商业环境中,供应链的复杂性不断增加,产品从原材料采购到最终交付消费者手中的过程涉及多个环节和众多参与者。然而,传统供应链管理面临着诸多挑战,如信息不透明、数据易篡改、追溯困难等,这些挑战不仅影…...
基于OpenCV的实时文档扫描与矫正技术
文章目录 引言一、系统概述二、核心代码解析1. 导入必要库2. 辅助函数定义3. 坐标点排序函数4. 透视变换函数5. 主程序流程 三、完整代码四、结语 引言 在日常工作和学习中,我们经常需要将纸质文档数字化。手动拍摄文档照片常常会出现角度倾斜、透视变形等问题&…...
基于STM32F103与Marvell88W8686的WIFI无线监控视频传输系统研发(论文)
基于STM32F103与Marvell88W8686的WIFI无线监控视频传输系统研发 中文摘要 在当今社会信息化进程不断加速的时代背景下,众多领域对于监控系统的需求日益增长,像车内安全监控、电梯运行监控等场景都离不开监控系统的支持。过去,不少领域普遍采用…...
华为云Astro中各种变量与参数的区别与用法
目录 🧠 华为云 Astro 各类变量与参数详解 🧩 一、变量与参数的核心作用是什么? 🖼️ 二、整体分类与结构图 📘 三、逐一详细解析 + 类比说明 + 使用建议 🔹 1. 输入参数(Input Parameter) 🔹 2. 输出参数(Output Parameter) 🔹 3. 变量(本地变量)…...
数字人技术的核心:AI与动作捕捉的双引擎驱动(210)
**摘要:**数字人技术从静态建模迈向动态交互,AI与动作捕捉技术的深度融合推动其智能化发展。尽管面临表情僵硬、动作脱节、交互机械等技术瓶颈,但通过多模态融合技术、轻量化动捕方案等创新,数字人正逐步实现自然交互与情感表达。…...
华为云Astro轻应用创建业务对象(BO)的概念梳理
目录 一、业务对象(BO)是什么?——【详细概念解释】 二、形象理解业务对象(BO) 🍱 类比方式: 📦 举个具体例子:以做一个“智能烟雾报警系统”应用 三、为什么使用BO很重要? 四、小结: 一、业务对象(BO)是什么?——【详细概念解释】 在华为云Astro轻应用…...
MySQL开发规范
目录 一、建表规约 二、索引规约 三、SQL语句 四、 ORM映射 一、建表规约 强制: 1、表达是与否概念的字段,必须使用is_xxx的方式命名(PoJo中不加is前缀),数据类型是unsigned tinyint(1表示是…...
K8s入门教程(一)
Kubernetes(K8s)入门教程:从零开始掌握容器编排 目录 Kubernetes(K8s)入门教程:从零开始掌握容器编排 1. Kubernetes 简介 1.1 什么是 Kubernetes? 1.2 核心功能 2. 环境搭建与 Minikube 安装 2.1 安装 Minikube 安装步骤(以 macOS 为例): 安装 kubectl(Kub…...
k8s备份namespace
在 Kubernetes 中备份 Namespace 有多种方法,以下是几种常见的备份方式: 1.使用 kubectl 命令备份 通过 kubectl 命令可以导出指定 Namespace 中的资源,生成 YAML 文件进行备份。 备份所有资源: kubectl -n <namespace> ge…...
前端动画库 Anime.js 的V4 版本,兼容 Vue、React
前端动画库 Anime.js 更新了 V4 版本,并对其官网进行了全面更新,增加了许多令人惊艳的效果,尤其是时间轴动画效果,让开发者可以更精确地控制动画节奏。 这一版本的发布不仅带来了全新的模块化 API 和显著的性能提升,还…...
OpenHarmony外设驱动使用 (四),Face_auth
OpenHarmony外设驱动使用 (四) Face_auth 概述 功能简介 人脸识别功能是端侧设备不可或缺的一部分,为设备提供一种用户认证能力,可应用于设备解锁、支付、应用登录等身份认证场景。它是基于人的脸部特征信息进行身份识别的一种…...
【Java ee初阶】jvm(1)
一、JVM Java虚拟机 面试中相关的问题有三块: 1.JVM内存区域划分 2.JVM的类加载机制 3.JVM的垃圾回收机制 JDK、JRE 和 JVM 的关系 JDK(Java Development Kit)是 Java 开发工具包,包含了编写、编译和调试 Java 程序所需的所…...
【Java ee初阶】jvm(2)
类加载机制: JVM从最开始的读取.class文件,到最终构造完成 类 对象的整个过程,也就是把 类 从硬盘 加载到内存中的机制。 Java的类加载机制主要分为五个步骤:加载、验证、准备、解析和初始化。 步骤一 加载(Loading…...
Django 项目创建全攻略
目录 一、环境准备 1. 安装 Python 2. 安装虚拟环境(可选但推荐) 3. 安装 Django 二、创建 Django 项目 1. 使用命令创建项目 2. 运行开发服务器 三、创建 Django 应用 1. 创建应用 2. 注册应用 四、配置项目 1. 数据…...
windows11 安装好后右键没有 git bash 命令
win键 R 键,输出 regedit,打开注册表 找到 \HKEY_CLASSES_ROOT\Directory\Background\shell 新建项 git-bash 然后在 git-bash 下在新建项 Command,默认值设为 "C:\Program Files\Git\git-bash.exe" --cd"%v." 在 …...
Java八股文——Java基础篇
目录 1、你是怎样理解OOP面向对象2、重载和重写的区别3、接口与抽象类的区别4、深拷贝与浅拷贝的理解5、sleep和wait区别主要区别 6、什么是自动拆装箱,int和Integer有什么区别自动拆装箱int和Integer的区别Integer缓存机制 7、和equals区别String特殊情况 8、Strin…...
蓝桥杯19682 完全背包
问题描述 有 N 件物品和一个体积为 M 的背包。第 i 个物品的体积为 vi,价值为 wi。每件物品可以使用无限次。 请问可以通过什么样的方式选择物品,使得物品总体积不超过 M 的情况下总价值最大,输出这个最大价值即可。 输入格式 第一行…...
2025年- H27-Lc135- 239.滑动窗口最大值(自定义双端队列)---java版
1.题目描述 2.思路 (1)双端队列可以移除最左边的元素,也可以移除最右边的元素(两端移除) (2)在最右边插入元素(右边加入) (3)队列单调性…...
EKS 工作节点的集群网络架构
AWS EKS(弹性 Kubernetes 服务)是亚马逊提供的托管 Kubernetes 服务,一旦配置完成,即可像变魔术一样运行。但这通常是 EKS 的默认设置。如果您打算根据组织的设计、合规性标准和隐私要求进行自定义,该怎么办࿱…...
【技海登峰】Kafka漫谈系列(十一)SpringBoot整合Kafka之消费者Consumer
【技海登峰】Kafka漫谈系列(十一)SpringBoot整合Kafka之消费者Consumer spring-kafka官方文档: https://docs.spring.io/spring-kafka/docs/2.8.10/reference/pdf/spring-kafka-reference.pdf KafkaTemplate API: https://docs.spring.io/spring-kafka/api/org/springframe…...
Python字符串格式化(一):三种经典格式化方法
文章目录 一、% operator:C语言风格的初代格式化方案(Python 2.0引入)1. 语法核心:占位符与类型码2. 进阶用法:格式修饰符3. 致命缺陷:类型严格匹配的陷阱4. 适用场景:旧代码维护的兼容性选择 二…...
浅谈无服务器WebSocket的优势
实际上,一个实用的解决方案是将构建业务关键型实时平台的复杂性卸载到专门的云服务中。 完全托管的无服务器 WebSocket 解决方案为事件驱动的消息传递提供了基础结构;它使底层基础设施成为一种商品。客户端使用提供程序服务发送/接收低延迟消息,并专注于…...
10.7 LangChain v0.3架构大升级:模块化设计+多阶段混合检索,开发效率飙升3倍!
LangChain v0.3 技术生态与未来发展 关键词:LangChain Chains, Agents 架构, Retrieval Strategy, LangGraph, 模块化设计 3. LangChain 项目:Chains, Agents, Retrieval Strategy LangChain v0.3 通过 Chains-Agents-Retrieval 三位一体的技术栈,构建起完整的大模型应用开…...
GLPK(GNU线性规划工具包)中建模语言MathProg的使用
GNU MathProg是一种用于描述线性数学规划模型的建模语言。用GNU MathProg语言编写的模型描述由一组语句和数据块组成。 在MathProg中,模型以集合、参数、变量、约束和目标(sets, parameters, variables, constraints, objectives称为模型对象)的形式进行描述。 在Ma…...
系统思考:IT企业项目困境分析
最近遇到一家快速发展的IT技术公司,遭遇了项目进度滞后、团队沟通不畅和资源分配不合理等一系列挑战。虽然他们拥有一支技术强大的团队,但在项目管理和团队协作上却显得力不从心。结果,多个项目超预算、交期延迟,客户满意度直线下…...
计算机网络 - 2.基础协议
1.TCP协议 1.TCP(Transmission Control Protocol):传输控制协议2.TCP协议是一种面向连接的、可靠的、 基于字节流的传输层通信协议 1.面向连接:两个使用TCP协议的应用(通常一个客户和一个服务器)在彼此交换数据包之前必须先建立一个TCP连接2.可靠的 1.数据传输之前都要建立…...
go语法大赏
前些日子单机房稳定性下降,找了好一会才找到真正的原因。这里面涉及到不少go语法细节,正好大家一起看一下。 一、仿真代码 这是仿真之后的代码 package mainimport ("fmt""go.uber.org/atomic""time" )type StopSignal…...
运行vscode编辑器源码
距离上次二次开发vscode已经是三年前的事了,当时是1.60.0版本,目前vscode已升级到了1.99.2版本,里面改动很大,最近下载下来了新版源码跑起来看看 准备node、python 源码里面node版本做了限制 2025-01-27 09:53:00.450 [info] Fo…...
ShenNiusModularity项目源码学习(26:ShenNius.Admin.Mvc项目分析-11)
本文学习并分析ShenNiusModularity项目中商城系统模块的小程序用户页面、用户收货地址页面。 1、小程序用户页面 小程序用户页面用于检索、浏览使用商城系统的用户数据(保存在shop_appuser表内,系统用户保存在sys_user表内),该页…...
C#中的成员常量:编译时的静态魔法
在C#编程中,常量(const)是一个强大而特殊的语言特性,特别是当它们作为类的成员时。本文将深入探讨成员常量的特性、使用场景以及与静态量的区别。 成员常量的基本特性 成员常量是声明在类内部的常量,具有以下核心特点: 声明位置…...