Git从入门到精通-第四章-更新仓库
目录
检查当前文件状态
追踪新文件
暂存已修改的文件(git add作用总结)
简化输出状态
忽略文件
查看已暂存和未暂存的修改 git diff
提交更新 git commit
跳过使用暂存区
前言:在工作区和Git仓库间设置暂存区的意义
1. 精准控制提交内容(颗粒度更细)
2. 避免误提交
3. 多阶段修改的拆分与合并
4. 高效构建提交对象
5. 与工作流工具集成
git commit -a操作并没有跳过暂存区
移除文件
移动文件
注:本文以proGit图文为基础
现在我们的计算机上有一个真实项目的Git仓库,并从这个仓库中检出了所有文件的工作副本。通常,你会对这些文件做修改,每完成一个阶段的目标,想要记录下它时,就将他提交到仓库
注意⚠️:在工作目录下的每一个文件就这两种状态: 已追踪 或 未追踪 。已追踪的文件是指那些被纳入了版本控制的文件,在上一次快照中有它们的记录,在工作一段时间后,它们的状态可能是未修改,已修改或已放入暂存区。简而言之,已追踪的文件就是Git已经知道的文件
工作目录中除已追踪文件外的其他所有文件,它们既不存在于上次快照的记录中,也没有被放入暂存区。 初次克隆某个仓库的时候,工作目录中的所有文件都属于已跟踪文件,并处于未修改状态,因为它们是刚从Git仓库中提出的
在编辑过某些文件后,由于自上次提交后你对它们做了修改,Git将它们标记为已修改文件。在工作时,你可以选择性地将这些修改过的文件放入暂存区,然后提交所有已暂存的修改,如此往复
检查当前文件状态
可以用 git status 命令查看哪些文件处于什么状态。如果在克隆仓库后立刻使用此命令,会看到类似这样的输出:
$ git status
On branch master
Your branch is up-to-date with 'origin/master'.
nothing to commit, working directory clean
这说明现在的工作目录相当干净 clean 。换句话说,所有已追踪的文件在上次提交后都未被更改过,此外,上面信息还表明当前目录下没有出现任何处于未跟踪的新文件,否则Git会列出来。最后,该命令还显示了当前所在分支 'origin/master' ,这是默认的分支名,并告诉你这个分支痛远程服务器上对应的分支没有偏离(我们在Git分支中会详细讨论分支和引用)
现在我们在这个项目目录下新建一个名为 README 的文件,这个文件之前并不在这个目录下,现在我们使用 git status 命令,将会看到一个新的为追踪文件:
$ echo 'My Project' > README
$ git status
On branch master
Your branch is up-to-date with 'origin/master'.
Untracked files:(use "git add <file>..." to include in what will be committed)READMEnothing added to commit but untracked files present (use "git add" to
track)
可以看到 Untracked files 下出现了 README 。未追踪的文件意味着Git在之前的快照(提交)中没有这些文件;Git不会自动将之纳入追踪范围,除非你明明白白地告诉它“我需要追踪该文件”,这样可以让你不必担心产生的二进制文件或者不想被追踪的文件被包含进来
追踪新文件
使用命令 git add 开始追踪一个文件,在这个例子中我们想要追踪名为 README 的文件,那么运行
git add README
这时我们再运行 git status 命令会看到 README 文件已被追踪,并处于暂存 Changes to be committed状态:
$ git status
On branch master
Your branch is up-to-date with 'origin/master'.
Changes to be committed:(use "git restore --staged <file>..." to unstage)new file: README
如果此时提交,那么该文件在你运行 git add 时的版本被留存在后续的历史记录中。 之前我们使用 git init 后就运行了 git add <files> 的命令,开始追踪当前目录下的文件。
如果 git add 使用文件或目录的路径作为参数,那么会开始递归地追踪该目录下的所有文件
暂存已修改的文件(git add作用总结)
现在我们修改一个被追踪的文件,如果我们现在修改了一个名为CONTRIBUTING.md的已追踪文件,然后我们运行git status命令,会看到:
$ git status
On branch master
Your branch is up-to-date with 'origin/master'.
Changes to be committed:(use "git reset HEAD <file>..." to unstage)new file: READMEChanges not staged for commit:(use "git add <file>..." to update what will be committed)(use "git checkout -- <file>..." to discard changes in working
directory)modified: CONTRIBUTING.md
可以看到,CONTRIBUTING.md 文件和 README 在 git add 之前不一样,README是新文件,未暂存时位于Untracked,而我们在原有文件更改后是位于在 Changes not staged for commit下,而且它不是 new file ,而是 modified ,说明已追踪文件的内容发生了变化,但还没有放到暂存区。要暂存这次更新,需要运行 git add 命令,这是一个多功能命令,这次它的作用和之前追踪新文件不同,这次是把已追踪文件放到暂存区,此外他还能用于合并时把有冲突的文件标记为已解决状态等。可以理解为“精确地将内容添加到下一次提交中”
现在我们git add CONTRIBUTING.md 再看看 git status
$ git add CONTRIBUTING.md
$ git status
On branch master
Your branch is up-to-date with 'origin/master'.
Changes to be committed:(use "git reset HEAD <file>..." to unstage)new file: READMEmodified: CONTRIBUTING.md
可以看到现在两个文件都在committed中暂存了,下次提交时就会一并记录到仓库中
假如现在我们第二次更改了 CONTRIBUTING.md 文件,再运行 git status 可以看到:
$ vim CONTRIBUTING.md
$ git status
On branch master
Your branch is up-to-date with 'origin/master'.
Changes to be committed:(use "git reset HEAD <file>..." to unstage)new file: READMEmodified: CONTRIBUTING.mdChanges not staged for commit:(use "git add <file>..." to update what will be committed)(use "git checkout -- <file>..." to discard changes in working
directory)modified: CONTRIBUTING.md
可以看到两个 CONTRIBUTING.md ,这说明再次更改后我们想当于产生了一个新版本的CONTRIBUTING.md,它会和前面已经暂存的旧版本的 CONTRIBUTING.md 区分,所以我们需要再次 git add 将新版本暂存
$ git add CONTRIBUTING.md
$ git status
On branch master
Your branch is up-to-date with 'origin/master'.
Changes to be committed:(use "git reset HEAD <file>..." to unstage)new file: READMEmodified: CONTRIBUTING.md
简化输出状态
我们可以用 git status -s 命令或 git status --short 命令来简化输出格式
$ git status -sM README
MM Rakefile
A lib/git.rb
M lib/simplegit.rb
?? LICENSE.txt
?? 代表新添加的、未跟踪的文件
A 代表新添加到暂存区的文件
M 代表修改过的文件
可以看到输出中最左边有两栏,左边是暂存区状态,右边是工作区状态,例如上面的输出说明:README 文件在工作区已修改但尚未暂存,而 lib/simplegit.rb 文件已修改且已暂存。 Rakefile 文件已修改,暂存后又作了修改,因此该文件的修改中既有已暂存的部分,又有未暂存的部分。
忽略文件
有些文件无须纳入 Git 的管理,也不希望它们总出现在未跟踪文件列表,这些文件一般是自动生成的文件,比如日志文件,或者编译过程中的临时文件等。这种情况下,我们可以创建一个名为 .gitignore 的文件,列出要忽略的文件,下面给个例子
$ cat .gitignore
*.[oa]
*~
第一行告诉 Git 忽略所有以 .o 或 .a 结尾的文件(这些一般都是在编译过程中产生的)
第二行告诉 Git 忽略所有名字以 ~ 结尾的文件(许多文本编辑软件,如Emacs,都用这样的文件名保存副本)
此外,你可能还需要忽略 log,tmp 或 pid 目录,以及自动生成的文档等等。要养成一开始就为你的心仓库设置好 .gitignore 文件的习惯,以免将来误提交这类无用的文件
.gitignore 文件格式如下:
• 所有空行或者以 # 开头的行都会被 Git 忽略。
• 可以使用标准的 glob 模式匹配,它会递归地应用在整个工作区中。
• 匹配模式可以以(/)开头防止递归。
• 匹配模式可以以(/)结尾指定目录。
• 要忽略指定模式以外的文件或目录,可以在模式前加上叹号(!)取反
上面的 glob模式 是指 shell 所使用的简化了的正则表达式。星号(*)匹配零个或多个任意字符;[abc] 匹配任何一个列在方括号中的字符 (这个例子要么匹配一个 a,要么匹配一个 b,要么匹配一个 c); 问号(?)只匹配一个任意字符;如果在方括号中使用短划线分隔两个字符, 表示所有在这两个字符范围内的都可以匹配(比如 [0-9] 表示匹配所有 0 到 9 的数字)。 使用两个星号(**)表示匹配任意中间目录,比如 a/**/z 可以匹配 a/z 、 a/b/z 或 a/b/c/z 等。
再看一个 .gitignore 文件的例子:
# 忽略所有的 .a 文件
*.a# 但跟踪所有的 lib.a,即便你在前面忽略了 .a 文件
!lib.a# 只忽略当前目录下的 TODO 文件,而不忽略 subdir/TODO
/TODO# 忽略任何目录下名为 build 的文件夹
build/# 忽略 doc/notes.txt,但不忽略 doc/server/arch.txt
doc/*.txt# 忽略 doc/ 目录及其所有子目录下的 .pdf 文件
doc/**/*.pdf
GitHub 有一个十分详细的针对数十种项目及语言的 .gitignore 文件列表, 你可以在https://github.com/github/gitignore 找到它。
在最简单的情况下,一个仓库可能只根目录下有一个 .gitignore 文件,它递归地应用到整个仓库中。 然而,子目录下也可以有额外的 .gitignore 文件。子目录中的 .gitignore文件中的规则只作用于它所在的目录中。 (Linux 内核的源码库拥有 206 个 .gitignore 文件。)
查看已暂存和未暂存的修改 git diff
如果 git status 命令的输出对于你来说过于简略,而你想知道具体修改了什么地方,可以用 git diff 命令。 稍后我们会详细介绍 git diff,你通常可能会用它来回答这两个问题:当前做的哪些更新尚未暂存? 有哪些更新已暂存并准备好下次提交? 虽然 git status 已经通过在相应栏下列出文件名的方式回答了这个问题,但 git diff 能通过文件补丁的格式更加具体地显示哪些行发生了改变。
假如再次修改 README 文件后暂存,然后编辑 CONTRIBUTING.md 文件后先不暂存, 运行 status 命令将会看到
$ git status
On branch master
Your branch is up-to-date with 'origin/master'.
Changes to be committed:(use "git reset HEAD <file>..." to unstage)modified: READMEChanges not staged for commit:(use "git add <file>..." to update what will be committed)(use "git checkout -- <file>..." to discard changes in working
directory)modified: CONTRIBUTING.md
要查看尚未暂存的文件更新了哪些部分,不加参数直接输入 git diff:
$ git diff
diff --git a/CONTRIBUTING.md b/CONTRIBUTING.md
index 8ebb991..643e24f 100644
--- a/CONTRIBUTING.md
+++ b/CONTRIBUTING.md
@@ -65,7 +65,8 @@ branch directly, things can get messy.Please include a nice description of your changes when you submit your
PR;if we have to read the whole diff to figure out why you're contributingin the first place, you're less likely to get feedback and have your
change
-merged in.
+merged in. Also, split your changes into comprehensive chunks if your
patch is
+longer than a dozen lines.If you are starting to work on a particular area, feel free to submit a
PRthat highlights your work in progress (and note in the PR title that it's
此命令比较的是工作目录中当前文件和暂存区域快照之间的差异。也就是修改之后还没有暂存起来的变化内容
若要查看已暂存的将要添加到下次提交里的内容,可以用 git diff --satged 命令,这条命令将对比已暂存文件与最后一次提交的文件差异:
$ git diff --staged
diff --git a/README b/README
new file mode 100644
index 0000000..03902a1
--- /dev/null
+++ b/README
@@ -0,0 +1 @@
+My Project
请注意,git diff 本身只显示尚未暂存的改动,而不是自上次提交以来所做的所有改动。 所以有时候你一下子暂存了所有更新过的文件,运行 git diff 后却什么也没有,就是这个原因。
像之前说的,暂存 CONTRIBUTING.md 后再编辑,可以使用 git status 查看已被暂存的修改或未被暂存的修改。 如果我们的环境(终端输出)看起来如下:
$ git add CONTRIBUTING.md
$ echo '# test line' >> CONTRIBUTING.md
$ git status
On branch master
Your branch is up-to-date with 'origin/master'.
Changes to be committed:(use "git reset HEAD <file>..." to unstage)modified: CONTRIBUTING.mdChanges not staged for commit:(use "git add <file>..." to update what will be committed)(use "git checkout -- <file>..." to discard changes in working
directory)modified: CONTRIBUTING.md
现在再运行 git diff 看暂存前后的变化
$ git diff
diff --git a/CONTRIBUTING.md b/CONTRIBUTING.md
index 643e24f..87f08c8 100644
--- a/CONTRIBUTING.md
+++ b/CONTRIBUTING.md
@@ -119,3 +119,4 @@ at the## Starter ProjectsSee our [projects
list](https://github.com/libgit2/libgit2/blob/development/PROJECTS.md).
+# test line
然后用 git diff --cashed 查看已经暂存起来的变化(--staged 和 --cached 是同义词)
$ git diff --cached
diff --git a/CONTRIBUTING.md b/CONTRIBUTING.md
index 8ebb991..643e24f 100644
--- a/CONTRIBUTING.md
+++ b/CONTRIBUTING.md
@@ -65,7 +65,8 @@ branch directly, things can get messy.Please include a nice description of your changes when you submit your
PR;if we have to read the whole diff to figure out why you're contributingin the first place, you're less likely to get feedback and have your
change
-merged in.
+merged in. Also, split your changes into comprehensive chunks if your
patch is
+longer than a dozen lines.If you are starting to work on a particular area, feel free to submit a
PRthat highlights your work in progress (and note in the PR title that it's
除了使用 git diff 来分析文件差异,也可以使用图形化的工具或外部 diff 工具来比较差异。 可以使用 git difftool 命令来调用 emerge 或 vimdiff 等软件(包括商业软件)输出 diff 的分析结果。 使用 git difftool --tool-help 命令来看你的系统支持哪些 Git Diff 插件。
提交更新 git commit
现在我们的暂存区已经准备就绪,可以提交了,在此之前,请务必确认还有什么已修改或者新建的文件还没有 git add 否则这些变化无法包含在这次提交中,只会留在本地磁盘。所以每次提交前先 git status 看下,然后再
git commit
这样会启动你选择的文本编辑器输入提交说明
启动的编辑器是通过 Shell 的环境变量 EDITOR 指定的,一般为 vim 或 emacs。 当然也可以按照 第一章 介绍的方式, 使用 git config --global core.editor 命令设置你喜欢的编辑器。
编辑器会显示类似下面的文本信息
# Please enter the commit message for your changes. Lines starting
# with '#' will be ignored, and an empty message aborts the commit.
# On branch master
# Your branch is up-to-date with 'origin/master'.
#
# Changes to be committed:
# new file: README
# modified: CONTRIBUTING.md
#
~
~
~
".git/COMMIT_EDITMSG" 9L, 283C
可以看到,默认的提交消息包含最后一次 git status 的输出,放在注释行里,另外开头还有一个空行,供你输入提交说明。 你完全可以去掉这些注释行,不过留着也没关系,多少能帮你回想起这次更新的内容有哪些。
更详细的内容修改提示可以用 -v 选项查看,这会将你所作的更改的 diff 输出呈现在编辑器中,以便让你知道本次提交具体作出哪些修改。
退出编辑器时,Git 会丢弃注释行,用你输入的提交说明生成一次提交。
另外,你也可以在 commit 命令后添加 -m 选项,将提交信息与命令放在同一行,如下所示:
$ git commit -m "Story 182: Fix benchmarks for speed"
[master 463dc4f] Story 182: Fix benchmarks for speed2 files changed, 2 insertions(+)create mode 100644 README
好,现在你已经创建了第一个提交! 可以看到,提交后它会告诉你,当前是在哪个分支(master)提交的,本次提交的完整 SHA-1 校验和是什么(463dc4f),以及在本次提交中,有多少文件修订过,多少行添加和删改过。
请记住,提交时记录的是放在暂存区域的快照。 任何还未暂存文件的仍然保持已修改状态,可以在下次提交时纳入版本管理。 每一次运行提交操作,都是对你项目作一次快照,以后可以回到这个状态,或者进行比较。
跳过使用暂存区
前言:在工作区和Git仓库间设置暂存区的意义
Git 设计中的暂存区(Staging Area,或称为索引 Index)是为了提供更灵活、可控的代码管理机制。虽然它增加了一个步骤,但带来了以下核心优势:
1. 精准控制提交内容(颗粒度更细)
- 问题:直接提交工作区改动时,所有未保存的修改会被一次性提交,可能导致无关代码混入提交记录。
- 解决方案:暂存区允许你选择性地添加文件(或代码块)到提交中。例如:
git add file1.txt # 添加某个文件 git add -p file2.txt # 交互式选择文件中的部分代码块
- 结果:提交历史更清晰,每个提交仅包含逻辑相关的改动。
2. 避免误提交
- 问题:工作区可能包含调试代码、临时文件或未完成的修改,直接提交可能污染仓库。
- 解决方案:暂存区作为“缓冲区”,需显式添加改动,用户可通过
git status
检查确认后再提交。 - 结果:减少意外提交无用文件的风险(如
.log
,.tmp
等)。
3. 多阶段修改的拆分与合并
- 场景:若同时修改了功能 A 和 B,但需要分两次提交。
- 操作:
git add featureA/ # 暂存功能 A git commit -m "Add feature A" git add featureB/ # 暂存功能 B git commit -m "Add feature B"
- 结果:无需频繁切换代码状态即可拆分逻辑独立的修改。
4. 高效构建提交对象
- 技术细节:Git 的提交是基于暂存区的快照,而非直接对比工作区。暂存区记录文件的元数据(如 SHA-1、时间戳),使得提交时只需打包已暂存的内容,无需全量扫描工作区。
- 优势:提交操作更快,尤其适合大型项目。
5. 与工作流工具集成
- 高级用法:暂存区支持与
git stash
(临时保存未提交的改动)、git checkout -- <file>
(撤销未暂存的修改)等命令协作,提供更灵活的工作流。
为什么不能绕过暂存区?
- Git 提供了
git commit -a
选项,可以直接提交所有已跟踪文件的修改,相当于自动执行git add -u
+git commit
。但这依然依赖暂存区的机制,且无法处理未跟踪的新文件或部分代码块。
总结
暂存区是 Git 强大功能的核心设计之一,它通过分离 工作区 → 暂存区 → 仓库 的流程,赋予开发者精细控制提交内容的能力。虽然初期可能感觉繁琐,但熟悉后能显著提升代码管理的效率和代码库的可维护性。
git commit -a操作并没有跳过暂存区
虽然proGit中写了“Git 提供了一个跳过使用暂存区域的方式”,但是我个人认为并没有跳过暂存区,而是自动将已追踪文件的修改添加到暂存区后再提交(省略 git add 操作)
git commit -a 想当于下面的两句话
git add -u # 将所有已跟踪(tracked)文件的修改添加到暂存区(不包含新文件)
git commit # 提交暂存区的内容
假设之前已经有已经在暂存区的文件,在git commit -a后会随着新的添加到暂存区的文件一起提交
总结一下 git commit -a 的作用:
- 自动将工作区中所有已跟踪文件的最新修改添加到暂存区(相当于执行
git add -u
) - 提交暂存区中所有内容(包括之前手动添加的 + 本次自动添加的)
除了未追踪的文件都会被提交
$ git status
On branch master
Your branch is up-to-date with 'origin/master'.
Changes not staged for commit:(use "git add <file>..." to update what will be committed)(use "git checkout -- <file>..." to discard changes in working
directory)modified: CONTRIBUTING.mdno changes added to commit (use "git add" and/or "git commit -a")
$ git commit -a -m 'added new benchmarks'
[master 83e38c7] added new benchmarks1 file changed, 5 insertions(+), 0 deletions(-)
看到了吗?提交之前不再需要 git add 文件“CONTRIBUTING.md”了。 这是因为 -a 选项使本次提交包含了所有修改过的文件。 这很方便,但是要小心,有时这个选项会将不需要的文件添加到提交中。
移除文件
要从 Git 中移除某个文件,就必须要从已跟踪文件清单中移除(确切地说,是从暂存区域移除),然后提交。可以用 git rm 命令完成此项工作,并连带从工作目录中删除指定的文件,这样以后就不会出现在未跟踪文件清单中了。
如果只是简单地从工作目录中手工删除文件,运行 git status 时就会在 “Changes not staged for commit” 部分(也就是 未暂存清单)看到:
$ rm PROJECTS.md
$ git status
On branch master
Your branch is up-to-date with 'origin/master'.
Changes not staged for commit:(use "git add/rm <file>..." to update what will be committed)(use "git checkout -- <file>..." to discard changes in working
directory)deleted: PROJECTS.mdno changes added to commit (use "git add" and/or "git commit -a")
然后再运行 git rm 记录此次移除文件的操作:
$ git rm PROJECTS.md
rm 'PROJECTS.md'
$ git status
On branch master
Your branch is up-to-date with 'origin/master'.
Changes to be committed:(use "git reset HEAD <file>..." to unstage)deleted: PROJECTS.md
下一次提交时,该文件就不再纳入版本管理了。 如果要删除之前修改过或已经放到暂存区的文件,则必须使用强制删除选项 -f(译注:即 force 的首字母)。 这是一种安全特性,用于防止误删尚未添加到快照的数据,这 样的数据不能被 Git 恢复。
另外一种情况是,我们想把文件从 Git 仓库中删除(亦即从暂存区域移除),但仍然希望保留在当前工作目录中。 换句话说,你想让文件保留在磁盘,但是并不想让 Git 继续跟踪。 当你忘记添加 .gitignore 文件,不小 心把一个很大的日志文件或一堆 .a 这样的编译生成文件添加到暂存区时,这一做法尤其有用。 为达到这一目的,使用 --cached 选项:
git rm --cashed README
git rm 命令后面可以列出文件或者目录的名字,也可以使用 glob 模式。比如:
git rm log/\*.log
注意到星号 * 之前的反斜杠 \, 因为 Git 有它自己的文件模式扩展匹配方式,所以我们不用 shell 来帮忙展开。此命令删除 log/ 目录下扩展名为 .log 的所有文件。 类似的比如:
git rm \*~
该命令会删除所有名字以 ~ 结尾的文件
移动文件
不像其它的 VCS 系统,Git 并不显式跟踪文件移动操作。 如果在 Git 中重命名了某个文件,仓库中存储的元数据并不会体现出这是一次改名操作。 不过 Git 非常聪明,它会推断出究竟发生了什么,至于具体是如何做到的,我们稍后再谈。
既然如此,当你看到 Git 的 mv 命令时一定会困惑不已。 要在 Git 中对文件改名,可以这么做:
git mv file_from file_to
它会恰如预期般正常工作。 实际上,即便此时查看状态信息,也会明白无误地看到关于重命名操作的说明:
$ git mv README.md README
$ git status
On branch master
Your branch is up-to-date with 'origin/master'.
Changes to be committed:(use "git reset HEAD <file>..." to unstage)renamed: README.md -> README
其实运行了 git mv 相当于运行了下面三条命令:
mv README.md README
git rm README.md
git add README
如此分开操作,Git 也会意识到这是一次重命名,所以不管何种方式结果都一样。 两者唯一的区别在于,git mv 是一条命令而非三条命令,直接使用 git mv 方便得多。 不过在使用其他工具重命名文件时,记得在提交前 git rm 删除旧文件名,再 git add 添加新文件名。
相关文章:
Git从入门到精通-第四章-更新仓库
目录 检查当前文件状态 追踪新文件 暂存已修改的文件(git add作用总结) 简化输出状态 忽略文件 查看已暂存和未暂存的修改 git diff 提交更新 git commit 跳过使用暂存区 前言:在工作区和Git仓库间设置暂存区的意义 1. 精准控制…...
RPG8.增加武器
1.创建一个Actor的c类 2.创建武器WeaponBase的子类,给玩家的武器 3.进入WeaponBase,只留下构造函数,并且将bCanEventTick改为false,增加组件。 #pragma once#include "CoreMinimal.h" #include "GameFramework/Ac…...
力扣1128题解
记录 2525.5.4 题目: 思路: 先将dominoes[i]的二元全部变为前大后小的形式,再遍历该数组,用数组来记录。 代码: class Solution {public int numEquivDominoPairs(int[][] dominoes) {int [] [] cnt new int [10…...
微服务框架选型
1 Thrift, gRPC, Dubbo,Spring Cloud性能对比 指标ThriftgRPCDubboSpring Cloud序列化速度最快 (Binary)快 (Protobuf)中等 (Hessian2)慢 (JSON/XML)网络吞吐量最高 (无HTTP开销)高 (HTTP/2)中等 (TCP)低 (HTTP/1.1)延迟<1ms1-3ms2-5ms10…...
DeepSeek-Prover-V2模型原理速览
文章目录 prerequisite:Lean4研究亮点通过子目标分解实现递归证明搜索基于子目标的定理证明中的课程学习 统一非形式化推理和形式化证明通过合成数据实现冷启动以推理为导向的强化学习 DeepSeek-Prover-V2 的训练细节专家迭代监督式微调 快速使用REF DeepSeek-Prove…...
网络编程,使用select()进行简单服务端与客户端通信
这里在Ubuntu环境下演示 一般流程 服务端常用函数: socket():创建一个新的套接字。bind():将套接字与特定的IP地址和端口绑定。listen():使套接字开始监听传入的连接请求。accept():接受一个传入的连接请求ÿ…...
QT数据库实验
一、实验目的和要求 1、掌握Qt中掌握绘图工具和图形界面设计;绘制常见的图形。 2、熟悉Qt界面设计中常用的控件。 3、了解滚动条、滑动条、进度条、旋转按钮控件的用法。 二、实验内容 1、设计一个绘图软件,完成图像的绘制操作。 2、建立按钮的信号…...
【PyTorch完全指南】从深度学习原理到工业级实践
目录 🌟 前言技术背景与价值当前技术痛点解决方案概述目标读者说明🔍 一、技术原理剖析核心概念图解核心作用讲解关键技术模块技术选型对比🛠 二、实战演示环境配置要求核心代码实现1. 基础Tensor操作2. 神经网络构建3. 训练循环实现运行结果验证⚡ 三、性能对比测试方法…...
Spring AI 实战:第七章、Spring AI Advisor机制之记忆大师
引言:当AI的记性比金鱼还差 你:我叫张三,很高兴认识你AI:很高兴认识你,张三! 如果你有任何问题或者需要帮助,请随时告诉我你:我叫什么AI:抱歉,我无法知道你的名字。不过你可以告诉我一些关于你的信息,如果你愿意分享的话!AI的内心OS:爱谁谁,我反正不知道 如上图所…...
工业AI质检:从传统算法到多模态大模型应用
工业AI质检:从传统算法到多模态大模型应用 引言 在制造业质量控制领域,传统人工检测的漏检率高达15%-20%,而基于规则算法的视觉检测系统仅能处理已知缺陷类型。随着多模态大模型技术的突破,工业质检正进入"认知智能"新阶段——系统不仅能识别缺陷,更能理解工艺…...
STM32智能垃圾桶:四种控制模式实战开发
简介 从零到一打造企业级智能垃圾桶系统,实现按键、语音、红外、蓝牙多模式控制。本项目采用STM32F103C8T6作为主控芯片,通过模块化设计整合多种控制方式,确保系统稳定、高效且易于维护。文章将提供完整硬件连接方案、代码实现细节及企业级开发技术,帮助开发者掌握智能垃圾…...
Python语句入门:从基础到实践
Python作为一门简洁优雅的编程语言,其语句结构清晰易懂,非常适合初学者学习。本文将全面介绍Python中的各种基本语句,帮助编程新手快速掌握Python编程基础。语句是计算机执行程序的最小单位。 一、Python语句概述 Python程序由一系列语句组…...
Kubernetes(k8s)学习笔记(五)--部署Ingress实现域名访问和负载均衡
Ingress是基于nginx,通过在k8s中部署ingress,可实现域名访问和pod节点间的负载均衡。 下面是实现过程: 一.准备一个ingress-controller.yaml文件 apiVersion: v1 kind: Namespace metadata:name: ingress-nginxlabels:app.kubernetes.io/n…...
数据库MySQL学习——day8(复习与巩固基础知识)
文章目录 1. 数据库基础概念复习2. 常用SQL命令复习2.1 SELECT 查询数据2.2 INSERT 插入数据2.3 UPDATE 更新数据2.4 DELETE 删除数据 3. 表操作复习3.1 创建表3.2 修改表3.3 删除表 4. 实践任务4.1 创建样例数据库和表4.2 插入和更新数据4.3 使用WHERE、ORDER BY、LIMIT进行查…...
【ArcGIS微课1000例】0144:沿线或多边形要素添加折点,将曲线线段(贝塞尔、圆弧和椭圆弧)替换为线段。
文章目录 增密工具介绍举例1. 圆2. 椭圆3. 折线增密工具介绍 沿线或多边形要素添加折点。还可将曲线线段(贝塞尔、圆弧和椭圆弧)替换为线段。 原理图如下所示: 用法: 通过距离参数对直线段进行增密。利用距离、最大偏转角或最大偏移偏差参数,通过增密操作对曲线段进行简化…...
python中的模块/库
python中的模块/库 什么是库/模块,通俗来讲是用来干啥的? 模块/库就是一个/多个.py的一个文件。通常是用来定义一些通用的方法,避免代码冗余。怎么python中自带的这些模块和库? 使用import进行导入,之后其中的内容就可…...
全面掌握 Jetpack Compose 的 State 体系:核心用法与最佳实践
Jetpack Compose 中的 State 类型全面解析 Jetpack Compose 提供了多种 State 类型来管理 UI 状态。以下是主要的 State 类型及其使用场景: 基础 State 类型 1. mutableStateOf 最基本的可观察状态,用于简单值的变化跟踪: var count by …...
Pyhton类方法添加装饰器案例解析
from functools import wrapsdef keep_alive(func):"""装饰器:为方法自动维护长连接"""wraps(func)def wrapper(self, *args, **kwargs):if not self.conn:self.conn ConnectHandler(**self.device_params)self.conn.enable()return…...
58认知干货:创业经验分享及企业形式的汇总
机会永远都是留给有眼光、能发现机会的人,而不是留给有准备的人!往往机会就在身边,普罗大众却无法发现,而真正适合创业的人,天然具备这方面的能力。 当然后天的补足也未尝不可:“故常有欲以观其微,常无欲以观其妙。””引用《道德经》 读懂这句话自然便会拥有对商业和…...
n8n 快速入门2:构建自动化工作流
n8n 快速入门2:构建自动化工作流 什么是n8n?项目目标准备工作步骤一:创建新工作流步骤二:添加触发节点步骤三:配置NASA节点与凭证1. 添加NASA节点2. 设置NASA API凭证3. 使用表达式设置时间范围步骤四:添加If条件节点1. 创建条件分支2. 测试条件逻辑步骤五:配置输出节点…...
TimSort算法解析
文章目录 1. 核心数据结构1.1 TimSort类定义1.2 关键概念:Run 2. TimSort解决的具体问题分析2.1 处理现实世界中的数据特性2.2 提高排序稳定性2.3 优化归并排序的空间复杂度2.4 处理特殊情况的鲁棒性2.5 适应性能力与算法自调整2.6 优化合并操作效率 3. TimSort核心…...
CATIA高效工作指南——曲面设计篇(一)
引言 在工业设计领域,CATIA的曲面建模与线束展开功能是构建复杂产品的核心技术。本文整合了曲面封闭性检查、无参数曲面创建、缝合优化策略等核心知识点,结合实战案例与高阶技巧,为工程师提供系统化的解决方案。 一…...
PCB叠层设计方案
1叠层处理 在设计多层 PCB 电路板之前, 设计者需要首先根据电路的规模、 电路板的尺寸和电磁兼容( EMC)的要求来确定所采用的电路板结构, 也就是决定采用 4 层,6 层, 还是更多层数的电路板。 这就是设计多层…...
机器人编程基础---C语言中的控制语句
C语言中的控制语句 C语言中的控制语句条件语句if 语句switch 语句循环语句for 循环while 循环do-while 循环代码示例C语言中的控制语句 控制语句是编程中用于控制程序执行流程的语句。在C语言中,控制语句包括条件语句和循环语句,它们允许程序根据条件选择不同的执行路径或重…...
13.Excel:分列
一 分列的作用 将一个单元格中的内容拆分到两个或多个单元格当中。 二 如何使用 1.常规分列使用 注意:分列功能一次只能拆分一列。 长度一致或者数据间有分隔符。 补充:快速选择一列。 CTRL shift 向下箭头。 补充:中英文逗号不同。 可以先通…...
理解数学概念——幂律(power law)
在统计学中,幂律(power law)(即按照幂的规律)是指两个量之间的函数关系,其中一个量的相对变化会导致另一个量以与常量指数成正比的关系产生相对变化:一个量随着另一个量的幂而变化。(例如, ,r 的变化导致s 按照幂 的…...
Go语言chan底层原理
本篇文章内容参考小徐先生等文章,带有个人注解等内容,帮助大家更好的了解chan的底层实现,原文是在语雀chan底层,可以点击查看,如果感觉还不错的同学,不妨点一个免费的赞和关注,冲冲冲࿰…...
传感器数据处理笔记
里程计模型: 两轮差分地盘的运动学模型三轮全向底盘的运动学模型航迹推算(Dead Reckoning) 里程计标定 线性最小二乘的基本原理最小二乘的直线拟合最小二乘在里程计标定中的应用 差分底盘的优势就是: 结构简单便宜࿰…...
8.5 从零到生产:Docker+K8s+CI/CD全链路部署实战手册
从零到生产:Docker+K8s+CI/CD全链路部署实战手册 #mermaid-svg-61OPZrCvQokymEG2 {font-family:"trebuchet ms",verdana,arial,sans-serif;font-size:16px;fill:#333;}#mermaid-svg-61OPZrCvQokymEG2 .error-icon{fill:#552222;}#mermaid-svg-61OPZrCvQokymEG2 .err…...
Android逆向学习(八)Xposed快速上手(上)
Android逆向学习(八)Xposed快速上手(上) 前言 xposed是一个用来hook的工具,简而言之,通过替换/system/bin/app_process程序控制zygote进程,这样的话,app_process在启动过程中会加载XposedBridge.jar这个j…...
Linux网络编程:套接字
目录 一 前言 二 源ip地址和目的ip地址 三 认识端口号 四 理解 "端口号" 和 "进程ID" 五 理解源端口号和目的端口号 六 认识TCP(Transmission Control Protocol)协议 七 UDP((User Datagram Protocolÿ…...
C++八股--6--mysql 日志与并发控制
这里向大家介绍一下数据库基础:共分为以下章节 10前序.日志系统 这是数据库的核心。我放到首页来介绍,给大家一个前置概念,方便进行更好的学习 日志文件我们用来记录事务对数据库更新操作的文件,分为以记录为单位的文件和数据块…...
bc 命令
一.bc 命令概述 bc 是 Linux 系统中一个用于任意精度算术运算的计算器语言,它支持整数和浮点数的计算,还能进行复杂的数学运算。在你给出的代码里,bc 被用来执行数值比较和计算。 二.| bc 和 | bc -l 的作用与功能 1. | bc | 是管道符号&…...
文献分享:CH-CL配对和VL结构域的完整性影响IgG1分泌过程
背景 IgG抗体的CH1结构域通过内质网蛋白质量控制(ERQC)机制,由分子伴侣BiP介导,控制抗体的组装和分泌。然而,目前尚不清楚这一过程是否需要可变域。2024年5月2日,韩国亚洲大学的研究人员在Frontiersin Mol…...
【vue3】黑马程序员前端Vue3小兔鲜电商项目【八】
黑马程序员前端Vue3小兔鲜电商项目【八】登录页面 登录页面的主要功能就是表单校验和登录登出业务。 账号密码 accountpasswordcdshi0080123456cdshi0081123456cdshi0082123456cdshi0083123456cdshi0084123456cdshi0085123456cdshi0086123456cdshi0087123456cdshi0088123456 …...
spring cloud 与 cloud alibaba 版本对照表
Spring cloud的组件 spring官方提供netflix提供alibaba提供其它注册中心consuleurekanacosapache(zookeeper)、tencent(paloris北极星)负载均衡loadBalancerribbondubbo远程调用openFeignfeigndubbogoogle(grpc)熔断器cricutBreakerhystrixsentinel网关gatewayzuul第一代MSE&a…...
Rockermq的部署与使用(0-1)
RocketMQ 是阿里巴巴开源的一款 分布式消息中间件,具有高吞吐、低延迟、高可用等特点,广泛应用于多个领域,包括异步通信解耦、企业解决方案、金融支付、电信、电子商务、快递物流、广告营销、社交、即时通信、移动应用、手游、视频、物…...
基于SpringBoot + HTML 的宠物医院预约管理
宠物医院管理系统,java项目,springboot项目。idea能打开运行。 使用技术:springboot,mybatis,HTML ,mysql 5.7 共分为三个角色:系统管理员、医生、用户 功能模块:系统管理࿰…...
Python的ArcPy基于Excel表格对大量遥感影像批量重分类
本文介绍基于Python中的ArcPy模块,以Excel表格内的信息,对遥感影像加以重分类的方法。 首先,明确一下本文的需求。现有按照文章ArcPy批量将栅格文件的属性表导出为Excel表格的方法(https://blog.csdn.net/zhebushibiaoshifu/artic…...
qml显示视频帧(QQuickImageProvider)
一、实现方式 解码视频可以选择:opencv、ffmpeg等。 显示视频可以选择:Qt Multimedia、QQuickImageProvider、ShaderEffect、自定义QQuickItem等。 本文使用opencv解码视频,QQuickImageProvider显示视频。 二、QQuickImageProvider 中,requestImage 和 requestTexture区…...
硬件工程师面试常见问题(13)
第六十一问:电压跟随器问题(有待改进) 电压跟随器主要用途在哪里? 答:电压跟随器主要用途:一般用于多级放大电路的输入入级、输出级,也可连接两电路,起缓冲作用。 电压跟随器电路连…...
[特殊字符] 专业角度深入讲解:大模型备案(生成式人工智能)
🏷️ 一、什么是大模型备案? 大模型备案是指 大模型产品 在向公众开放及商用之前,经过 国家互联网信息办公室(网信办) 等监管部门的 备案审批 过程。 ✅ 目的: 加强生成式 AI 服务的合规管理 促进 AI 技…...
机器学习的简单介绍
目录 一、发展历程与学科定位 二、核心研究方向与技术突破 三、技术挑战与瓶颈 四、未来趋势与创新方向 五、应用场景与产业影响 总结与展望 机器学习作为人工智能的核心分支,近年来在理论和应用层面均取得了突破性进展。本文将从发展历程、核心研究方向、…...
多语言笔记系列:Polyglot Notebooks 混合使用多语言并共享变量
混合使用多语言并共享变量 混合使用多种语言(C#、F#、Powershell、SQL、KQL、Python、Html、JavaScript、JavaScript、Mermaind等语言),是多语言笔记的最大特性,并且支持各语言之间共享变量这一创新功能。 语言及共享变量的支持情况 语言变量共享C#支…...
操作系统结构图
操作系统组成结构 ├── 用户界面(外壳) │ ├── 图形用户界面(GUI): 提供可视化交互(如窗口、图标) │ └── 命令行界面(CLI): 通过文本指令操作(如Bash、PowerShe…...
Docker 使用与部署(超详细)
目录 引入 入门使用 部署对比 镜像仓库 命令解释 基础 常见命令 示例 数据卷的使用 数据卷的概念 数据卷的使用 挂载本地目录文件 镜像 结构 Dockerfile 容器网络 部署 DockerCompose 语法 编辑 基础命令 引入 当我们在 Linux 上部署一个集成了很多中间件…...
Android第三次面试总结之Java篇补充
一、Array 与 ArrayList 在 Android 中的深度对比与优化 1. 内存模型与性能差异的本质原因 数组(Array)的内存布局 基本类型数组(如 int[])在 Java 中是连续的原始数据块,直接存储值,无额外对象开销&#…...
CVPR2023 | 通过降低对图像块损坏的敏感性来提高视觉Transformer的鲁棒性
Improving Robustness of Vision Transformers by Reducing Sensitivity to Patch Corruptions 摘要-Abstract引言-Introduction相关工作-Related Work降低对Patch损坏的敏感性-Reducing Sensitivity to Patch Corruptions实验-Experiments分析与讨论-Analysis and Discussions…...
NV228NV254固态美光颗粒NV255NV263
NV228NV254固态美光颗粒NV255NV263 美光颗粒固态硬盘技术解析与选购指南 一、美光颗粒技术体系解析 1. 颗粒分类与性能差异 美光颗粒采用独特编号体系,NV254(如MT29F8T08GLLBHL4-36QMES)代表8Tb TLC颗粒,采用BOS(浮…...
LeetCode 1007. 行相等的最少多米诺旋转 题解
示例 输入:tops [2,1,2,4,2,2], bottoms [5,2,6,2,3,2] 输出:2 解释: 图一表示:在我们旋转之前, tops 和 bottoms 给出的多米诺牌。 如果我们旋转第二个和第四个多米诺骨牌,我们可以使上面一行中的每个…...