Git 命令代码管理详解
一、Git 初相识:版本控制的神器
在当今的软件开发领域,版本控制如同基石般重要,而 Git 无疑是其中最耀眼的明珠。它由 Linus Torvalds 在 2005 年创造,最初是为了更好地管理 Linux 内核源代码。随着时间的推移,Git 凭借其卓越的特性,迅速在全球开发者社区中广泛传播,成为了现代软件开发过程中不可或缺的关键工具。
想象一下,没有版本控制的软件开发会是怎样一番混乱景象:代码频繁修改,一旦出现问题,很难追溯到错误源头;团队协作时,成员各自为政,代码合并冲突不断,项目进度受阻。而 Git 的出现,完美地解决了这些痛点。
对于个人开发者而言,Git 就像是一位贴心的助手。当你独自探索项目时,它能帮你记录每一次代码的改动,无论是新功能的添加、Bug 的修复,还是代码结构的优化。你可以随时回顾之前的版本,找回那些可能被误删或改错的代码片段,让你的开发过程更加从容不迫。
在团队协作场景下,Git 更是发挥着无可替代的作用。它允许多个开发者同时在不同的分支上工作,互不干扰。例如,一个电商项目团队,前端开发人员可以在 “frontend-feature” 分支专注优化页面交互,后端开发人员在 “backend-api” 分支全力开发新的接口,等各自功能稳定后,再轻松地将分支合并到主分支,实现无缝对接。这种并行开发的模式,极大地提高了团队的开发效率,让项目能够快速迭代推进。
不仅如此,Git 还具备强大的分布式特性。每个开发者都拥有本地仓库,即便在没有网络连接的情况下,依然可以正常进行代码提交、查看历史记录等操作。等到网络恢复,再与远程仓库同步,确保团队成员之间的代码始终保持一致。
可以说,掌握 Git,就等于掌握了软件开发的主动权,它能让你的开发之路更加顺畅,让团队协作更加高效,开启代码管理的全新篇章。接下来,就让我们深入探索 Git 的奇妙世界,领略那些常用命令的魅力。
二、Git 的基础命令:开启代码管理之旅
现在,让我们正式踏上 Git 的学习之旅,从那些最基础、最常用的命令开始。
- git init:这是你在 Git 世界迈出的第一步,用于初始化一个新的本地 Git 仓库。想象你有一个全新的项目文件夹,里面存放着刚写的代码文件,在项目根目录下打开终端,输入 “git init”,瞬间,Git 就为你创建了一个隐藏的.git 文件夹,这里面藏着 Git 管理项目所需的所有 “魔法道具”,比如版本历史记录、分支信息等,你的项目就此被纳入 Git 的版本控制体系,开启了可追溯、可管理的新篇章。例如:
$ mkdir my_project $ cd my_project $ git init Initialized empty Git repository in /Users/yourname/my_project/.git/
- git clone:当你想要获取一份远程仓库(如 GitHub、GitLab 上的项目)的副本到本地时,它就派上用场了。语法是 “git clone [远程仓库地址]”,执行后,Git 会在本地创建一个与远程仓库同名的文件夹,把远程仓库的代码、分支等信息完整地拷贝过来,你就可以在本地尽情地探索、修改代码了。比如:
$ git clone https://github.com/username/repository.git Cloning into 'repository'... remote: Enumerating objects: 100, done. remote: Counting objects: 100% (100/100), done. remote: Compressing objects: 100% (50/50), done. remote: Total 100 (delta 30), reused 80 (delta 20) Receiving objects: 100% (100/100), 10.00 KiB | 10.00 KiB/s, done. Resolving deltas: 100% (30/30), done.
- git add:代码写好、修改完,想要提交到仓库,得先把它们添加到暂存区,这就是 “git add” 的活儿。你可以 “git add [具体文件名]” 逐个添加,也能用 “git add.” 一键添加当前目录下所有修改和新增的文件。比如:
$ git add main.py $ git add.
- git commit:文件添加到暂存区后,就该 “git commit” 登场,将暂存区的内容提交到本地仓库,形成一个版本记录。“git commit -m ' 提交说明 '” 是最常用的方式,提交说明要简洁明了,概括本次提交的改动内容,方便后续回溯查找问题。例如:
$ git commit -m "修复登录页面的密码验证Bug" [master 123abcde] 修复登录页面的密码验证Bug1 file changed, 5 insertions(+), 3 deletions(-)
- git status:它就像一个贴心的小助手,随时告诉你当前仓库的状态。运行 “git status”,它会显示哪些文件已修改未暂存、哪些文件已暂存未提交、有没有新建的未跟踪文件等信息,让你对项目的代码变动了如指掌。比如:
$ 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 restore <file>..." to discard changes in working directory)modified: README.mdUntracked files:(use "git add <file>..." to include in what will be committed)new_feature.pyno changes added to commit (use "git add" and/or "git commit -a")
- git diff:好奇自己改了哪些代码?“git diff” 帮你查看工作区与暂存区的差异,展示哪些行被添加、修改或删除,助你精细把控代码变动。若想看暂存区与上次提交的差异,用 “git diff --cached”。像这样:
$ git diff diff --git a/main.py b/main.py index 123456..654321 100644 --- a/main.py +++ b/main.py @@ -10,6 +10,8 @@ def login():username = input("请输入用户名:")password = input("请输入密码:")if username == "admin" and password == "123456": + print("登录成功,欢迎管理员!")return Trueelse:print("用户名或密码错误")
- git log:想回顾项目的提交历史,“git log” 就是时光机。它按时间倒序列出每次提交的作者、日期、提交 ID 和提交说明,你能清晰看到项目的演进脉络,还能用 “git log -p” 查看每次提交的详细代码变动。例如:
$ git log commit 123abcde (HEAD -> master) Author: Your Name <your@email.com> Date: Mon Jan 1 10:00:00 2024 -0800修复登录页面的密码验证Bugcommit 456defgh Author: Your Name <your@email.com> Date: Sun Dec 31 15:00:00 2023 -0800添加用户注册功能...
这些基础命令如同基石,构建起你使用 Git 进行版本控制的底层架构,熟练掌握它们,后续的高级玩法才能信手拈来。
三、分支管理:并行开发的利器
在 Git 的强大功能体系中,分支管理犹如一把利剑,为开发者开辟出并行开发的广阔天地。它允许我们在同一项目下,同时进行多个功能的开发、测试与修复,互不干扰,极大地提升了开发效率。
- git branch:这是分支管理的基础命令,用于查看本地分支列表。在终端输入 “git branch”,当前所在分支前会标有 “*” 号,一目了然。例如:
$ git branch * masterdevfeature-a
若要创建新分支,使用 “git branch [分支名]”。比如,启动一个新功能开发,可创建 “feature-b” 分支:
$ git branch feature-b
它只是创建了分支指针,指向当前提交,HEAD 仍指向原分支。若想创建并切换到新分支,用 “git checkout -b [分支名]” 更便捷,一步到位。像这样:
$ git checkout -b fix-bug Switched to a new branch 'fix-bug'
- git checkout:是切换分支的得力工具。执行 “git checkout [分支名]”,就能让 HEAD 指向目标分支,工作区、暂存区也随之切换。如在 “feature-a” 开发告一段落,切换回 “master”:
$ git checkout master Switched to branch'master'
若未提交修改就切换,Git 会阻止并提示提交或暂存,防止工作丢失。不过,加上 “-f” 参数可强制切换,覆盖本地修改,慎用!另外,“git checkout” 还能恢复文件,“git checkout -- [文件名]” 可从暂存区或上次提交恢复文件,撤销工作区修改。假设改错了 “main.py”,用它轻松找回:
$ git checkout -- main.py
- git merge:用于合并分支,将指定分支合并到当前分支。常见场景是把开发完的功能分支合并到主分支。如 “feature-a” 稳定后,切换到 “master” 合并:
$ git checkout master $ git merge feature-a Updating 123456..abcdef Fast-forwardmain.py | 10 +++++++---README.md | 5 ++++-2 files changed, 12 insertions(+), 3 deletions(-)
这里出现 “Fast-forward”,是 Git 自动采用的快进式合并,因 “feature-a” 基于 “master” 最新提交,无新分叉,Git 直接将 “master” 指针移到 “feature-a” 最新提交。但多分支并行开发复杂,常遇非快进合并,产生合并冲突,需手动解决。比如 “dev” 和 “master” 同时改 “config.ini” 不同部分,合并就会冲突:
$ git merge dev Auto-merging config.ini CONFLICT (content): Merge conflict in config.ini Automatic merge failed; fix conflicts and then commit the result.
此时,打开 “config.ini”,会看到 Git 用 “<<<<<<<”“=======”“>>>>>>>” 标记冲突内容,手动选保留或修改后,“git add” 标记解决,再 “git commit” 完成合并。
- git cherry-pick:这是个强大且灵活的命令,能将指定提交应用到当前分支,无需合并整个分支。比如 “feature-b” 分支某次提交修复关键 Bug,想快速应用到 “master”:
$ git checkout master $ git cherry-pick abcdef # abcdef是修复Bug的提交哈希值 [master 789ghi] Fix critical bug1 file changed, 5 insertions(+), 3 deletions(-)
它不仅能挑单个提交,还支持多个,用空格分隔哈希值或指定范围,如 “git cherry-pick abcdef 123456” 或 “git cherry-pick abcdef^..67890”(不含起始提交)。若操作冲突,解决方法类似合并冲突,修改后 “git add”,再用 “git cherry-pick --continue” 继续,想放弃就 “git cherry-pick --abort”。
合理运用分支管理策略,结合这些命令,能让团队协作如虎添翼,不同功能并行推进、快速整合,项目迭代更高效。
四、远程仓库交互:团队协作的桥梁
在现代软件开发的协作舞台上,与远程仓库的交互是 Git 的核心好戏。它打破了地域与设备的限制,让全球开发者能无缝对接,共同雕琢代码大厦。
- git remote:这是管理远程仓库连接的 “总控台”。输入 “git remote”,不带参数,能列出本地仓库关联的所有远程仓库简称,像常见的 “origin”。若加 “-v” 参数,即 “git remote -v”,它会详细展示每个远程仓库的简称与对应的 URL,让你清楚数据流向何处。比如:
$ git remote origin $ git remote -v origin https://github.com/username/repository.git (fetch) origin https://github.com/username/repository.git (push)
初次接触项目,需添加远程仓库,用 “git remote add [简称] [URL]”。如团队新建 GitHub 仓库,你在本地项目执行:
$ git remote add origin https://github.com/teamname/project.git
就建立了本地与远程的纽带,后续推送、拉取就靠它指引方向。若远程地址变更,可用 “git remote set-url [简称] [新 URL]” 更新,无缝切换数据源。
- git pull:它是团队保持同步的关键动作,用于从远程仓库拉取最新代码并合并到本地当前分支。本质上,它是 “git fetch” 与 “git merge” 的组合拳。执行 “git pull”,默认从 “origin” 远程仓库拉取当前分支对应的远程分支代码,自动合并。像:
$ git pull remote: Enumerating objects: 10, done. remote: Counting objects: 100% (10/10), done. remote: Compressing objects: 100% (5/5), done. remote: Total 10 (delta 3), reused 8 (delta 2) Receiving objects: 100% (10/10), 1.00 KiB | 1.00 KiB/s, done. Resolving deltas: 100% (3/3), done. Updating 123456..abcdef Fast-forwardmain.py | 2 +-1 file changed, 1 insertion(+), 1 deletion(-)
这里 “Fast-forward” 表示快进合并,远程分支领先且无分叉,本地分支指针直接前移。但多分支并行常遇冲突,拉取时 Git 会暂停,提示手动解决冲突,修改文件、“git add” 标记、“git commit” 完成合并,确保代码和谐统一。
- git push:开发者将本地成果推向世界的有力工具,把本地分支更新推送到远程仓库对应分支。格式为 “git push [远程主机名] [本地分支名]:[远程分支名]”。如将本地 “master” 分支推送到 “origin” 的 “master”:
$ git push origin master Counting objects: 20, done. Delta compression using up to 4 threads. Compressing objects: 100% (15/15), done. Writing objects: 100% (20/20), 1.64 KiB | 560.00 KiB/s, done. Total 20 (delta 5), reused 0 (delta 0) To https://github.com/username/repository.git123456..abcdef master -> master
首次推送新分支,建议加 “-u” 参数,如 “git push -u origin feature-branch”,它不仅推送,还建立本地分支与远程分支追踪关系,后续 “git push”“git pull” 可省略分支名,自动匹配。若远程分支有新提交且冲突,需先拉取合并;若执意推送覆盖,用 “--force” 参数,但这可能破坏他人工作,务必谨慎,协作中沟通先行,避免 “代码战争”。
五、标签管理:项目里程碑的标记
在 Git 的世界里,标签(Tag)扮演着至关重要的角色,它像是一个个醒目的里程碑,标记着项目发展历程中的关键节点。无论是软件版本的发布,还是重要功能的完成,都能通过标签精准定位,让项目管理更加井然有序。
使用 “git tag” 命令可以轻松创建标签。最简单的形式,直接在命令后跟上标签名称,如 “git tag v1.0”,便能为当前所在的提交打上一个名为 “v1.0” 的轻量标签。这种轻量标签就像是一个便捷的书签,指向特定的提交,不过它仅包含最基本的信息,没有额外的附注。若你想要创建带有详细信息的附注标签,可以使用 “git tag -a [标签名] -m [附注信息]” 的形式。例如,“git tag -a v2.0 -m ' 正式发布第二版,包含全新界面设计与优化功能 '”,这样创建的标签不仅能标记版本,还记录了版本的关键特性,方便后续回溯查阅。
想查看已有的标签,只需在终端输入 “git tag”,所有的标签就会按字典序整齐列出,一目了然。若你对某个特定标签的详细信息感兴趣,比如它对应的提交详情、作者、创建日期以及附注内容等,可以使用 “git show [标签名]” 命令。像查看刚刚创建的 “v2.0” 标签的详细信息,运行 “git show v2.0”,屏幕上便会清晰展示出该标签所关联提交的所有相关信息,仿佛打开了一扇通往当时开发场景的时光之门。
有时候,项目推进过程中,可能需要删除一些不再适用或打错的标签。删除本地标签使用 “git tag -d [标签名]” 命令,比如发现之前的 “v1.0-test” 标签有误,执行 “git tag -d v1.0-test” 就能迅速清理。不过要注意,默认情况下,创建的标签仅存储在本地,并不会自动推送到远程仓库。如果要推送标签到远程,让团队成员共享,需使用 “git push origin [标签名]” 命令,如 “git push origin v2.0”,将本地的 “v2.0” 标签推送到远程仓库 “origin”。要是本地积累了多个标签,想要一次性全部推送到远端,使用 “git push origin --tags” 即可,简单高效,确保远程与本地标签状态一致,团队成员都能基于统一的版本标记开展工作。
六、撤销与回退:错误修正的后悔药
在软件开发的漫长旅程中,即便经验丰富的开发者,也难免会踏入代码的 “雷区”,犯下一些错误。幸运的是,Git 提供了一系列强大的撤销与回退命令,如同给我们配备了 “后悔药”,让修正错误不再困难重重。
当我们在工作区对文件进行了修改,却突然意识到这是个错误的方向,想要撤销这些尚未暂存的更改时,“git checkout -- [文件名]” 就是我们的救星。它能迅速将指定文件恢复到最近一次提交或暂存时的状态。比如,你在 “main.py” 中写了一些测试代码,后来发现并不需要,执行 “git checkout -- main.py”,文件就会瞬间回到之前的干净版本,仿佛错误从未发生过。
要是已经使用 “git add” 将修改添加到了暂存区,但还没提交,而此时你又想撤回暂存区的更改,让文件回到工作区未暂存时的模样,“git reset HEAD [文件名]” 便能派上用场。它巧妙地将暂存区的修改回退到工作区,给你重新审视代码的机会。假设你不小心把一些调试信息也 “git add” 了,执行 “git reset HEAD main.py”,这些调试信息就从暂存区撤回,等待你的进一步处理。
而一旦错误的代码已经提交到了本地仓库,想要回退版本,就需要根据不同的场景选择合适的命令。如果只是想在本地仓库撤销某次提交,并且希望保留工作区和暂存区的更改,以便后续继续修改,“git reset --soft [提交哈希值]” 是个不错的选择。它会温柔地将 HEAD 指针移动到指定提交,版本库回退,但工作区和暂存区不受影响,让你可以轻松调整代码后重新提交。例如,你提交了一个功能,但发现漏了一些关键优化,使用 “git reset --soft [上一版本哈希值]” 回退,接着完善代码再提交即可。
与之相对的,“git reset --hard [提交哈希值]” 则是一剂猛药。它会毫不留情地将暂存区与工作区都强制回退到指定版本,彻底抹去后续的提交记录。这在你确定某个错误提交导致项目完全偏离正轨,想要彻底重来时非常有用,但务必谨慎使用,因为一旦执行,未提交的代码将永久丢失。
还有一种情况,当你已经将错误的提交推送到了远程仓库,想要补救就需要更加小心谨慎。首先在本地使用上述合适的 “git reset” 命令回退版本,然后使用 “git push origin [分支名] --force” 强制推送到远程仓库。不过,这种强制推送会重写远程仓库的历史记录,极有可能影响其他协作者的工作,所以在操作之前,一定要与团队成员充分沟通,达成共识,避免引发 “代码冲突大战”。
另外,“git stash” 命令也独具魅力,它能将当前工作区的修改暂存起来,让你的工作区瞬间变得干净整洁,就像把杂乱的物品暂时收纳进了一个魔法盒子。当你正在开发一个新功能,突然遇到紧急 Bug 需要修复,而当前工作区的代码又尚未完成不宜提交时,“git stash” 就能大显身手。执行后,你的修改被安全保存,工作区切换到上次提交的状态,等 Bug 修复完,再通过 “git stash pop” 将暂存的修改取出来,继续未完成的工作,无缝衔接,高效便捷。
七、进阶技巧:提升效率的秘籍
当你熟练掌握了 Git 的基础与核心命令后,是时候探索一些进阶技巧,进一步提升开发效率,让你在代码管理的世界里游刃有余。
想查看某个特定文件的详细历史记录,“git log [文件名]” 便能精准定位。比如,你想追溯 “config.ini” 的配置变更历程,输入 “git log config.ini”,它会列出该文件的所有提交记录,包括每次提交的作者、日期、提交说明以及具体的代码改动,让你清晰洞察配置参数的演变逻辑,快速排查因配置变更引发的问题。
搜索提交记录时,“git log” 的过滤功能堪称强大。按作者过滤,使用 “git log --author=' 作者名字 '”,能迅速聚焦特定开发者的所有提交,当你排查某位同事代码中的潜在问题,或回顾其负责模块的开发历程时,这招极为实用;依提交信息过滤,“git log --grep=' 关键词 '” 可帮你找出包含特定关键词的提交,像团队规定提交信息需关联问题单号,通过 “git log --grep='JRA-123'” 就能精准定位相关修复提交;按日期筛选也不在话下,“git log --after=' 起始日期 ' --before=' 结束日期 '” 划定时间区间,如查看近两周内的提交,执行 “git log --after='2 weeks ago'” 即可,让你聚焦特定时段的代码变更。
为常用命令配置别名能大幅节省输入时间。在全局配置文件(~/.gitconfig)中,添加 “[alias]” 段落,如 “st = status”“cm = commit -m”“lg = log --color --graph --pretty=format:'% Cred% h% Creset -% C (yellow)% d% Creset % s % Cgreen (% cr) % C (bold blue)<% an>Creset' --abbrev-commit”,之后输入 “git st”“git cm ' 更新说明 '”“git lg” 就能分别替代原本冗长的命令,提升操作流畅度。你还可依据个人习惯自由定制别名,打造专属快捷指令集,让 Git 操作如丝般顺滑。
八、总结与展望:Git 学习永不止步
至此,我们一同走过了 Git 命令的精彩旅程,从基础的仓库初始化、文件提交,到分支的灵活运用、远程仓库的交互,再到标签标记、错误回退以及进阶技巧,每一个环节都蕴含着 Git 的强大与精妙。这些命令如同积木,组合起来便能搭建出高效、有序的软件开发流程,无论是个人开发者独自探索创新,还是团队成员协同攻坚,都离不开它们的助力。
然而,Git 的世界广袤无垠,我们所触及的仅是冰山一角。随着技术的不断演进,新的需求与挑战会接踵而至,像大型项目中的复杂分支管理策略优化、跨团队协作时更流畅的代码集成流程,都有待我们进一步探索。持续学习 Git 的高级特性、深入理解其底层原理,将让我们在面对复杂场景时游刃有余,开发效率更上一层楼。
希望各位读者以此次学习为起点,在日常实践中不断磨砺对 Git 命令的运用能力,尝试新的技巧,解决新的问题,让 Git 真正成为手中的利剑,斩断开发路上的荆棘,开启属于自己的代码传奇之旅,为个人成长与团队成就赋能添彩,向着更高的技术巅峰奋勇攀登。
相关文章:
![](https://i-blog.csdnimg.cn/direct/f3a44e9c9f2e4c2cb37ab5eb3d07b0bb.png)
Git 命令代码管理详解
一、Git 初相识:版本控制的神器 在当今的软件开发领域,版本控制如同基石般重要,而 Git 无疑是其中最耀眼的明珠。它由 Linus Torvalds 在 2005 年创造,最初是为了更好地管理 Linux 内核源代码。随着时间的推移,Git 凭借…...
![](https://www.ngui.cc/images/no-images.jpg)
Docker的安装和使用
容器技术 容器与虚拟机的区别 虚拟机 (VM) VM包含完整的操作系统,并在虚拟化层之上运行多个操作系统实例。 VM需要更多的系统资源(CPU、内存、存储)来管理这些操作系统实例。 容器 (Container) 容器共享主机操作系统的内核,具…...
![](https://i-blog.csdnimg.cn/direct/20edbcc5bb6748bda7a90a9bede56782.jpeg)
Flink系统知识讲解之:Flink内存管理详解
Flink系统知识讲解之:Flink内存管理详解 在现阶段,大部分开源的大数据计算引擎都是用Java或者是基于JVM的编程语言实现的,如Apache Hadoop、Apache Spark、Apache Drill、Apache Flink等。Java语言的好处是不用考虑底层,降低了程…...
![](https://i-blog.csdnimg.cn/direct/c97cf4df5d964991b3328a9f3c64fb35.gif)
使用JMeter模拟多IP发送请求!
你是否曾遇到过这样的场景:使用 JMeter 进行压力测试时,单一 IP 被服务器限流或者屏蔽?这时,如何让 JMeter 模拟多个 IP 发送请求,成功突破测试限制,成为测试工程师必须攻克的难题。今天,我们就…...
![](https://www.ngui.cc/images/no-images.jpg)
【Ubuntu与Linux操作系统:六、软件包管理】
第6章 软件包管理 6.1 Linux软件安装基础 Linux的软件包是以二进制或源码形式发布的程序集合,包含程序文件和元数据。软件包管理器是Linux系统的重要工具,用于安装、更新和卸载软件。 1. 常见的软件包管理器: DEB 系统(如Ubunt…...
![](https://i-blog.csdnimg.cn/direct/25a8b000544943b7bce1b5552c579807.png)
【数据结构-堆】力扣1834. 单线程 CPU
给你一个二维数组 tasks ,用于表示 n 项从 0 到 n - 1 编号的任务。其中 tasks[i] [enqueueTimei, processingTimei] 意味着第 i 项任务将会于 enqueueTimei 时进入任务队列,需要 processingTimei 的时长完成执行。 现…...
![](https://i-blog.csdnimg.cn/direct/4113d074bb334fe18382aa83f9e111a9.gif)
【前端动效】原生js实现拖拽排课效果
目录 1. 效果展示 2. 效果分析 2.1 关键点 2.2 实现方法 3. 代码实现 3.1 html部分 3.2 css部分 3.3 js部分 3.4 完整代码 4. 总结 1. 效果展示 如图所示,页面左侧有一个包含不同课程(如语文、数学等)的列表,页面右侧…...
![](https://i-blog.csdnimg.cn/direct/4878c4e842844b1782e8195f52258b31.png)
C#使用OpenTK绘制3D可拖动旋转图形三棱锥
接上篇,绘制着色矩形 C#使用OpenTK绘制一个着色矩形-CSDN博客 上一篇安装OpenTK.GLControl后,这里可以直接拖动控件GLControl 我们会发现GLControl继承于UserControl //// 摘要:// OpenGL-aware WinForms control. The WinForms designer will always call the default//…...
![](https://i-blog.csdnimg.cn/direct/5f99ca0f093b45538cb7e82e49c0881b.jpeg#pic_center)
排序的本质、数据类型及算法选择
排序的本质、数据类型及算法选择 一、排序的本质二、排序的数据类型三、排序算法的选择依据 前两天老金写了篇 “十大排序简介”,有点意犹未尽,这一回老金想把排序连根拔起,从排序的本质说道说道。 一、排序的本质 从字面上理解,…...
![](https://csdnimg.cn/release/blog_editor_html/release2.3.7/ckeditor/plugins/CsdnLink/icons/icon-default.png?t=O83A)
Python的列表基础知识点(超详细流程)
目录 一、环境搭建 二、列表 2.1 详情 2.2 列表定义 2.3 列表长度 2.4 列表索引 2.5 切片索引 2.6 添加 2.7 插入 2.8 剔除 2.8.1 pop方法 2.8.2 del方法 2.9 任何数据类型 2.10 拼接 2.10.1 “” 2.10.2 “*” 2.11 逆序 编辑 2.12 计算出现次数 2.13 排序…...
![](https://i-blog.csdnimg.cn/direct/b2834b2225df4a6fa33691c18f579bcf.jpeg#pic_center)
HarmonyOS鸿蒙开发 弹窗及加载中指示器HUD功能实现
HarmonyOS鸿蒙开发 弹窗及加载中指示器HUD功能实现 最近在学习鸿蒙开发过程中,阅读了官方文档,在之前做flutter时候,经常使用overlay,使用OverlayEntry加入到overlayState来做添加悬浮按钮、提示弹窗、加载中指示器、加载失败的t…...
![](https://www.ngui.cc/images/no-images.jpg)
【Ubuntu与Linux操作系统:一、Ubuntu安装与基本使用】
第1章 Ubuntu安装与基本使用 1.1 Linux与Ubuntu Linux是一种开源、类Unix操作系统内核,拥有高稳定性和强大的网络功能。由于其开源性和灵活性,Linux被广泛应用于服务器、嵌入式设备以及桌面环境中。 Ubuntu是基于Debian的一个流行Linux发行版…...
![](https://www.ngui.cc/images/no-images.jpg)
React 元素渲染
React 元素渲染 React 是一个用于构建用户界面的 JavaScript 库,它允许开发人员创建大型应用程序,这些应用程序可以随着时间的推移而高效地更新和渲染。React 的核心概念之一是元素渲染,它描述了如何将 JavaScript 对象转换为 DOM࿰…...
![](https://i-blog.csdnimg.cn/direct/918242775f684d628b7dcf2ee74eb48c.png)
【2024年华为OD机试】 (C卷,100分)- 括号匹配(Java JS PythonC/C++)
一、问题描述 题目描述 给定一个字符串,里边可能包含“()”、“[]”、“{}”三种括号,请编写程序检查该字符串中的括号是否成对出现,且嵌套关系正确。 若括号成对出现且嵌套关系正确,或该字符串中无括号字符,输出&am…...
![](https://www.ngui.cc/images/no-images.jpg)
解锁企业数字化转型新力量:OpenCoze(开源扣子)
在当今数字化浪潮席卷之下,企业对于高效管理和协同运作的需求愈发迫切,而开源技术正逐渐成为众多企业破局的关键利器。今天,想给大家介绍一款极具潜力的开源项目 ——OpenCoze,中文名称 “开源扣子”。 一、OpenCoze 是什么&…...
![](https://www.ngui.cc/images/no-images.jpg)
【网络云SRE运维开发】2025第2周-每日【2025/01/12】小测-【第12章 rip路由协议】理论和实操考试题解析
文章目录 选择题答案及解析理论题答案及解析实操题答案及解析下一步进阶 选择题答案及解析 RIP路由协议是基于哪种算法的动态路由协议? 答案:B. 距离矢量算法解析:链路状态算法用于OSPF等协议;最小生成树算法主要用于生成树协议&…...
![](https://i-blog.csdnimg.cn/direct/1a378366c0b6438e93a3a7e27cceff36.png)
【微服务】8、分布式事务 ( XA 和 AT )
文章目录 利用Seata解决分布式事务问题(XA模式)AT模式1. AT模式原理引入2. AT模式执行流程与XA模式对比3. AT模式性能优势及潜在问题4. AT模式数据一致性解决方案5. AT模式一阶段操作总结6. AT模式二阶段操作分析7. AT模式整体特点8. AT模式与XA模式对比…...
![](https://i-blog.csdnimg.cn/direct/9f22f472208546088f9e5950f4c5674b.png)
CVE-2025-22777 (CVSS 9.8):WordPress | GiveWP 插件的严重漏洞
漏洞描述 GiveWP 插件中发现了一个严重漏洞,该插件是 WordPress 最广泛使用的在线捐赠和筹款工具之一。该漏洞的编号为 CVE-2025-22777,CVSS 评分为 9.8,表明其严重性。 GiveWP 插件拥有超过 100,000 个活跃安装,为全球无数捐赠平…...
![](https://i-blog.csdnimg.cn/direct/e9d02e9a805c4475ab4135be80b26e9e.png)
TypeScript Jest 单元测试 搭建
NPM TypeScript 项目搭建 创建目录 mkdir mockprojectcd mockproject初始化NPM项目 npm init -y安装TypeScript npm i -D typescript使用VSCode 打开项目 创建TS配置文件tsconfig.json {"compilerOptions": {"target": "es5","module&…...
![](https://i-blog.csdnimg.cn/direct/477379116ef24bd5959377b471f534aa.png)
基于 SSH 的任务调度系统
文末附有完整项目代码 在当今科技飞速发展的时代,任务调度系统的重要性日益凸显。本文将详细介绍一个基于 SSH(SpringStruts2Hibernate)的任务调度系统的设计与实现。 一、系统概述 本系统旨在改变传统人工任务调度方式,通过计算…...
![](https://i-blog.csdnimg.cn/direct/91ad74c2af6f44349bbb523d98602826.png#pic_center)
filestream安装使用全套+filebeat的模块用法
1 filestream介绍 官方宣布:输入类型为log在filebeat7.16版本已经弃用了 Filestream 是 Filebeat 中的一种 输入类型(Input),用于处理日志文件的读取。它是为了取代 Filebeat 中传统的 log 输入(Input)设…...
![](https://img-blog.csdnimg.cn/9b70aa7d88a648b08fee4f1450ec7ac0.png)
java项目之房屋租赁系统源码(springboot+mysql+vue)
项目简介 房屋租赁系统实现了以下功能: 房屋租赁系统的主要使用者分为: 系统管理:个人中心、房屋信息管理、预约看房管理、合同信息管理、房屋报修管理、维修处理管理、房屋评价管理等模块的查看及相应操作; 房屋信息管理&#…...
![](https://i-blog.csdnimg.cn/direct/56e11e37ea8f4975a7031a1587e10e5c.png)
sap mm学习笔记
1. 业务流程 2. 组织架构 3. 物料主数据 4.采购主数据 5. 采购管理 6. 库存管理 7.物料主数据 8. 采购申请 ME51N...
![](https://i-blog.csdnimg.cn/img_convert/b3279f942ab4c460c5f3fc8ea9404027.gif)
代码随想录_链表
代码随想录02 链表 203.移除链表元素 力扣题目链接(opens new window) 题意:删除链表中等于给定值 val 的所有节点。 示例 1: 输入:head [1,2,6,3,4,5,6], val 6 输出:[1,2,3,4,5] 示例 2: 输入:he…...
![](https://www.ngui.cc/images/no-images.jpg)
EF Code 并发控制
【悲观控制】 不推荐用,EF Core 没有封装悲观并发控制的使用,需要使用原生Sql来使用悲观并发控制 一般使用行锁、表锁等排他锁对资源进行锁定,同时只有一个使用者操作被锁定的资源 拿sql server举例,可以使用表所、或者行所解决…...
![](https://www.ngui.cc/images/no-images.jpg)
ceph fs status 输出详解
ceph fs status 命令用于显示 Ceph 文件系统的状态信息,其中各列的含义如下: RANK:元数据服务器(MDS)的等级或标识符。 STATE:MDS 的当前状态,例如 active(活跃)、stan…...
![](https://i-blog.csdnimg.cn/img_convert/a8607eac360b15d4fe8d3a2cb305551c.png)
FFmpeg Muxer HLS
使用FFmpeg命令来研究它对HLS协议的支持程度是最好的方法: ffmpeg -h muxerhls Muxer HLS Muxer hls [Apple HTTP Live Streaming]:Common extensions: m3u8.Default video codec: h264.Default audio codec: aac.Default subtitle codec: webvtt. 这里面告诉我…...
![](https://i-blog.csdnimg.cn/img_convert/ad90abf88be5a206bb543aef6d6d1ac7.png)
如何用SQL语句来查询表或索引的行存/列存存储方式|OceanBase 用户问题集锦
一、问题背景 自OceanBase 4.3.0版本起,支持了列存引擎,允许表和索引以行存、纯列存或行列冗余的形式创建,且这些存储方式可以自由组合。除了使用 show create table命令来查看表和索引的存储类型外,也有用户询问如何通过SQL语句…...
![](https://i-blog.csdnimg.cn/direct/d42aae37f0a84104bd3a732241fbec0b.png)
回归预测 | MATLAB实GRU多输入单输出回归预测
回归预测 | MATLAB实GRU多输入单输出回归预测 目录 回归预测 | MATLAB实GRU多输入单输出回归预测预测效果基本介绍程序设计参考资料 预测效果 基本介绍 回归预测 | MATLAB实GRU多输入单输出回归预测。使用GRU作为RNN的一种变体来处理时间序列数据。GRU相比传统的RNN有较好的记…...
![](https://i-blog.csdnimg.cn/direct/d8ffb62f4c044ccdbdccd8324c6a9d45.png#pic_center)
【OpenGL/Assimp】渲染模型、半透明材质与封装光源
文章目录 渲染成果Assimp库准备:Mesh类修改:透明贴图使用:光源封装:使用方式在如下测试环境中: 渲染成果 Assimp库准备: 从GitHub拉取源码,根据网络教程,借助CMake生成VS工程项目&a…...
![](https://img-blog.csdnimg.cn/img_convert/6677fd70ef7de85432e3d4c53b10a949.png)
本溪城乡建设委员会网站/企业网站排名优化
500立方米的锦鲤鱼池过滤系统改造后,水质终于清澈了!锦鲤鱼池作为园林景观项目的组成元素之一,其核心在于用水造景,在很多公共区域、市政园林、酒店会所、私家庭院都有分布。在当前,锦鲤鱼池可以说随处可见,…...
![](https://img-blog.csdnimg.cn/img_convert/e0c1adc755fb8b68ea602c400549e0aa.png)
政法门户网站建设情况/南京百度提升优化
前言提到数据库索引,大家肯定很熟悉,在日常工作中经常会接触到。这几天看了不少相关文章、书籍和课程。决定自己总结一篇文章,虽然我写的这篇文章肯定不如网上各路大神的好文,但是自己总结一遍总归记得更牢固。这应该也是一种好的…...
![](/images/no-images.jpg)
网站建设 付款方式/已备案域名交易平台
一. 数字测试 格式:n1 -op n2 测试操作op: eq/ne/le/ge/lt/gt --> 等于/不等于/小于等于/大于等于/小于/大于 1. 数字比较可以使用特殊的(())操作符,用法更接近于C语言,见数字测试。 二. 字符串测试 s1 s2 #s1与s2是否相同…...
![](https://img-blog.csdnimg.cn/2020052522493013.png?x-oss-process=image/watermark,type_ZmFuZ3poZW5naGVpdGk,shadow_10,text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L2l0eXc1MjA=,size_16,color_FFFFFF,t_70)
有哪些可以做问卷的网站/国际形势最新消息
1、选择 2、应用确认...
![](http://blog.fens.me/wp-content/uploads/2016/04/pay50.png)
建网站做站在/完美动力培训价格表
AngularJS体验式编程系列文章,将介绍如何用angularjs构建一个强大的web前端系统。angularjs是由Google团队开发的一款非常优秀web前端框架。在当前如此多的web框架下,angularjs能脱颖而出,从架构设计上就高人一等,双向数据绑定&am…...
![](/images/no-images.jpg)
php网站开发进程/seo搜索引擎优化到底是什么
1. basename("/mnt/img/image01.jpg")函数:得到文件名;输出结果为:image01.jpg. 使用 basename($uriString) 我们可以得到一个包含扩展名的文件名; 如果不需要扩展名,也可以使用 basename($uriString, $extString) 过滤扩展名,仅仅…...