架构思考与实践:从通用到场景的转变

news2025/1/22 19:02:16

3d9153601e0315576ae5dca7a0381fee.gif

在当今复杂多变的商业环境中,企业架构的设计与优化成为了一个关键议题。本文通过一系列随笔,探讨了业务架构的价值、从通用架构到场景架构的转变、恰如其分的架构设计以及如何避免盲目低效等问题。通过对多个实际案例的分析,笔者揭示了架构设计不仅仅是技术问题,更是对企业现状和未来发展的深度理解与把握。本文适合希望深入了解业务架构及其实践意义的读者阅读。

4dce2759870c8eb341277c154cc6b88e.png

价值理解:(业务)架构的价值

当我们需要了解一个人时,需要“察其言观其行”,不过也难免“误判”。企业的发展与管理,最重要的还是要了解企业自身,知道在做哪些事情,有哪些能力。如果企业都不知道自身的能力和发展情况,那么管理层就容易“纸上谈兵”、“朝令夕改”,或选择“无为而治”。

因为不了解一线情况,就会提出不合时宜、不够长期的个人主张,下面的人也会“晕头转向”,企业长期也可能“原地踏步”。

bf1ed43600dab59dba3eec1463c7682f.jpeg

企业黑盒:盲目,低效

业务架构其实是为了“塑造一面镜子”,让企业看清自己。下面是本人之前梳理的一个整体逻辑图。从顶层的商业模式,到中间的业务能力、业务流程,再到具体的系统实现与资源消耗,是一个抽象层面的认知结构。

c63742b390606dc7f01ab2006d285ab2.png

业务架构大图

说白了,我们需要一个能够承上启下的模型,能够让企业外的人或者上层的管理者,在比较抽象的角度理解经营活动;同时让具体的干活的执行者能够知道“我在做什么”、“能够产生怎么价值”,“应该往什么方向演进”。也就是把一件事抽象地讲清楚。这个常用的语言就是业务架构大图中价值流和业务能力的部分。



下面是一个讲清楚实现“招聘员工”这个事情的案例,就是采用了“价值流映射到业务能力”的方法。

944cbf18c1690f74529977e8985e8f99.jpeg

价值流映射到业务能力案例,来自《TOGAF 口袋指南》

这里顺便抛出一下相关定义:

  • 价值流的定义:价值流表现为【一系列】端到端的【增值活动】,能够为客户、利益相关者或最终用户【创造整体效益】。

  • 价值流阶段的定义:价值流中的【增值活动】被称为价值流阶段,价值流每步入一个新的阶段就会为利益相关者【创造并增加增量价值】。

  • 业务能力的定义:业务能力是企业为实现特定【目的】或【成效】而可能【拥有】或【置换】的一种特殊【能力】或【产能】。



道理大家都懂,但是该怎么做呢?复杂系统下我们该如何实践?关于这个问题,说到了很多事情的痛点,我们缺少最佳实践,也就是一些优秀的模版。如果没有这些模版,我们很容易“走歪”,变成“东施效颦”、“照猫画虎”、“画蛇添足”等各种辛苦但又无奈迷茫的局面。

此时,我们应该去看一下业界实践和行业观点,多了解大家的实践。当我们见过好东西,就知道差在哪里了,也可能原本方向就是对的,缺的可能就是“信念”。

下图就是中国电信CRM 2010年的一个流程整理版本,是一个相对抽象的角度,讲清楚了中国电信的客户管理系统要干什么。

91db3df760435c787b83a602ca9fc20b.jpeg

CRM 整理流程框架,来自《中国电信CTG-MBOSS BSS CRM系统业务功能规范》

再进一步,上面是具体的一个价值流阶段展开,下面是抽象出来的功能架构。

4cadd4f2bae2835bd9443b3c54695999.jpeg

CRM 功能架构,来自《中国电信CTG-MBOSS BSS CRM系统业务功能规范》

继续进一步,将价值流阶段(纵)和一些功能主题(横)组合在一起的时候,就从一个比较高的层次,描述了企业要做哪些阶段的事,每个阶段需要哪些能力支撑,下面就是一本书中对上面电信系统的描述。

c7a4106962193e27e2b3b813a4d59315.jpeg

CRM 功能域划分,来自《业务架构·应用架构·数据架构实战》

回过头来,我们好像一直在讲如何理解企业要做什么事情,需要具备哪些能力,并没有具体讲如何避免盲目低效。但是,我们从日常的经验知道,掌握企业方向的都是少部分高层,让这部分高层理解企业的现状,是他们决策的起点,上面的理解,实际上是一份“沟通语言”、“顶层类目”、“业务模块”的抽象呈现,是“指令”、“反馈”的中间桥梁,也就是打开的企业黑盒。

在这样的基础上,我们可以进一步去做增量思考,相关能力是否不够完善(能力成熟度),多部门之间的能力是否有重叠(重复建设与成本),新的战略要补充什么能力(能力规划与组织招聘)等。

做事情之前,要把事情想清楚,想清楚之前,首先得能够有渠道和视角看到东西。看不到,看不明白,也就无法思考,更没法做出有效决策,那么只能随波逐流,听天由命。

转变认知:从通用架构走向场景架构

在知识与信息爆炸的情况下,传统的营销策略已经很难生效,因为大家会主观上过滤各种投放的广告。现在要想进一步促进销售,就需要进入特定场景,融入到不同用户的体验过程中,可以称之为场景营销。

6be6f8af0d145c6bd184554515883925.jpeg

知识爆炸

回到架构场景上,在相对成熟的公司中,由于基础的建设相对完善,我们现在很难通过一个相对简单和通用的方法解决一大类类似的问题,进而需要进入特定的场景,一步一步地进行场景分析和架构设计,个人认为可以是进入了“场景架构”的时代。

如果有“场景架构”这样的认知的话,我们会有什么样的期待变化呢?

  • 放弃一劳永逸的幻想:在这样的情况下,我们很难在不打开研究对象的时候,在外部进行一个切面研究就获得显著的改善效果。一个切面就能解决的,往往称为基础技术。

  • 需要进行归类与分级:在打开特定场景的情况下,意味着场景的发散,需要解决的问题很多,在有限的时间内,我们需要进行场景归类,和类型优先级的排序,针对不同的价值和收益,提供不同的解决策略。

  • 更加需要基础架构理论:因为场景的发散,我们会发现很多特殊的情况,或者与原先判断相左的案例,从而产生疑惑。为此,我们在解决场景问题前,需要不断完善横向理论,让理论更具包容性和策略性。在多种策略背后,我们需要对目标更加确认和清醒,让目标真正的可持续和符合实际情况。

  • 业务内容为先:理解场景意味着理解业务,这意味着我们需要跨进业务域,明白生产关系,各方诉求,也需要增加访谈的能力,了解业务背景。同时,这样意味着我们需要投入更多的精力,会经历更多的反复。

7fdc779ece3148a4ea63495cad7948eb.jpeg

不再期待架构中有“神灯”

“场景架构”的地位提升,往往发生在业务发展到比较成熟的阶段,是业务进入深水区时的认知改变。如果业务本身还没有很复杂,基础建设也还有空间,那也还有很多的通用策略去解决问题,但是这一部分往往属于技术架构、数据架构、应用架构等方面,而业务架构,则没有银弹。

3c0856fcdc3fe9a4a6ca43643a8d489e.jpeg

深水区需要精耕细作

过犹不及:明白什么是恰如其分

软件研发过程中,对架构的投入比例常有不同的看法:

  • 不需要架构活动:有人认为,完全不需要独立的架构活动,架构应该回归到日常研发过程中,软件开发者会在迭代中自我思考和解决;

  • 架构活动基于首要位置:有人认为,开始就需要进行整体的架构设计,这是后续工作能够不返工的关键。



在《恰如其分的软件架构》一书中提到,不同的场景下,需要的架构活动比例是不一样的,并不是绝对的0和1的事情,如果要进一步去认知比例的多少,应该转向“风险驱动的原则”:软件复杂,风险较大的,业务架构活动的比例就需要提高,反之则可以控制在较低比例,甚至没有。

再进一步看,实际上很多软件设计或多或少都需要结构和方案的设计,会考虑后续的扩展性、可维护性、可读性等方面,这个架构活动的比例是天然存在的。不过,很多的问题是,需不需要独立出来一个“架构(师)”的角色来承担各问题域的兼职角色。如果这样看的话,问题变得更加复杂了,软件工作中架构的“恰如其分”不仅仅是架构活动的比例,更需要考虑这个比例在人员上的分摊情况。

121471eb464adb01ee6d8af9d315f91f.jpeg

生活中恰如其分的设计

cc900437752a85e47be2b78331aaa7f6.png

不破不立:忘掉自己画的圈和规则

最近在架构书籍的序中看到一个观点:是说到最后要忘掉自己画的圈,不破不立。这让我很触动,我们身边的架构活动,一直都在试图建立规则,维护规则,甚至想方设法植入到生产中,让物理现实和逻辑空间保持强一致性,然后陷入到日常管理的“权利”快感中。

回顾我们的行动本身:当我们看到复杂的规则之后,尝试去设计和建立新的规则时,是不是想过,我们是将复杂变得简化,还是在复杂上增加复杂。

38ef73596530615d8886d1fe62b0376c.jpeg

思考不能偷懒

数学中一个很好的例子就是过拟合。当我们拟合的不错的时候,往往我们还会乐忠于不断调整,进行进一步的拟合,因为这样的增量对我们来说比较轻松,也容易看到结果。当看着拟合的曲线几乎完全覆盖所有的点时,往往会兴奋地欣赏着自己的杰作。

可再来一个新的点时候,我们却会陷入深深的茫然:才发现自己对过去发生的事情过于在意,进一步拟合的快感,虽省去了找新思路的的苦恼,但同时也让我们忽略了我们的职责是保持一定的适应性,是对未来(的点)进行预测。

82bb5d452cdf33731d168a5510536178.jpeg眼前短期的“漂亮”不是我们的目标

如何忘记自己给自己的画的圈?如何不固守自己的一亩三分地?如何跳出自己煮出来的“温水”?我想更好的办法,还是要牵引,不停地奔向远方,去看大海,看到更多的世界和想法。

当我们遇到一些问题的时候,我们往往可以找到一些基本的策略,可以不假思索地去执行与推进,因为以前就是这么做的,这样也很好做,前人可能把阻力磨平了,你只需要在上面做新的调整。

但是,时间与阶段发生了变化,我们面对的问题和环境也不一样,还是用前人的思想讲述当今的故事,往往是思想上的偷懒,逻辑经不起深度推敲。

ad287c962c9512c76e7fa80db92ad867.jpeg事情不能模糊化

可能大家潜意识里面都触碰到过这样的抉择,是继续思考下去把问题想清楚,还是拿着当前看似可通的逻辑去赶快拿结果。前者会面对思维的反复,充满痛苦;后者却可以快速地进入操作,让身体变累,头脑却变得轻松。

但是,思想的大海,一定是要经历蜿蜿蜒蜒的曲径,才能最终看到。让你兴奋的,也许是大海的波澜壮阔,也许只是你为了看大海,而一直前行走过的漫长道路。

忘记“圈”,其实还是让我们不要做思想上的懒惰者,不要享受“一招半式”唬人的快感,还是要踏踏实实地踏上思考苦旅。

342568f353e7a3b3b5063c966d0bb733.png

理解重复:重复的故事,不同的演绎

大话西游中,可通过“月光宝盒”回到过去,重新演绎历史,甚至能够进行走向的影响,但是总是只能改变细节,很难改变大结局,因为实物运行的规律是多方作用的结果。如果很难改变,如果只是重复演绎,那么这又有什么意义呢?

f2dd446a507b966df7438d79d6e7a5a6.jpeg使用月光宝盒回到过去

工作中,如果在一个相对成熟的公司,站在领导的层面,可能会有这样的疑问:为什么还是那么些产品,却仍需要那么多人?同样,站在一线的人,也会有这样的疑问:好几年前就有的产品,怎么一直要做,到底是什么原因。

如果我们细细去看,这些工作内容,往往不是同一个团队的持续工作,而是历史的多次重演:

  • 交互阵地变了:从PC 到 无线,再到各种智能设备,同样的产品,在不同交互阵地上需要重新建设。

  • 自建or共享:每个业务线都可以选择自建,因为共享的产品内容,往往因为人员有限,支持粒度有限,不够高效,所以不同业务可能也需要重复昨天的建设。

  • 范围变了:原来大家都是管好自己产品内的逻辑即可,因为大盘的增量本身会带动各个产品的增量,但是当增量有限,大家就需要扩大产品的覆盖范围,就需要从考虑大盘变成考虑各个其它产品场景,走入了各种叠加下产品逻辑设计的长尾工作中。

  • 维护人变了:即使什么都没有变化,但是人还是可能离开,那么新进来的人势必需要时间学习,通过各种资料去调查历史的故事,了解各个模块的设计和具体实现。



在一些团队“老人”的眼中,他们能够看到之前的一些故事,能够看到一些差异点,知道”重演“的原因。但是在团队新人的眼中,并不会感知之前的历史,只能看到自己在改写新的历史,但是如果被问到“为什么这个产品好几年了,为什么还在做?”时,可能并无法理解。

3b492902af53a04ec36867f61846dae4.jpeg

思考:循环中是否大部分是新的东西

我觉得,工作中“重复”的事情之所以那么多,因为我们工作的那层还是过于靠近业务,同时建设成本其实也并不高。只要有团队能够想出差异点,只要这个热度比较高,就很容易走向自建或者各种设计的漩涡中。就好比一个街道上开了个奶茶店,很快就会有一堆奶茶店,只要有赚头,就会有新店。我们很容易回答要做什么,因为做了可能就有机会(能找到各种逻辑),而且往往不用考虑成本(公司兜底)。

5ea2a43c416aa6a88e9660fa2af43a59.jpeg

不同公司的奶茶店(出现在一个公司会怎么样)

这个问题很类似的就是,经典电视剧可能每个几年就会重新拍一下。观众变了,演员变了,拍摄技术变了,即使故事情节也没有变,还是会有消费的群体,以前看过老的版本的人可能也不在目标客户中。

f169f980dac93c7fbaf6afba9da01166.jpeg

反复拍摄的电视剧

回过头来,如果工作中,我们在反复建设以前的产品,同时老板又会疑问为什么还需要那么多人时,其实还是要回到我们的业务:业务在反复打开"月光宝盒",期望引入各种变化,能够将原来特定结局,演绎成多个版本,为了他们的不同策略,这些策略可能是为了不同人群,可能是为了不同行业,可能是为了不同交互等。

但是,是否真的”重复“的关键还是在于:他们的策略或者目的是否在反复,还是在不断细化完善。这有着截然不同的感受的,一个是产品的重复建设or返工,一个是产品的逐渐完备 。

很幸运的是,我们的工作时间有限,很难经历一个产品的多次反复,总会有新的人演绎新的故事,是否重复并不重要,有人消费可能就够了。

此外,好比电视剧,虽然各种支持人员可以减少,但是演绎的人员的确要那么多,并不可能一个人演了全部的角色。那么,工作中可能只有减少产品新的各种功能,才可能减少特定的人员。

731b3ff16e2fc9d9e4fd289b04bc0b39.png

认知有限:我们不如专业人士擅长

近期参加了儿子幼儿园的家长开放日,期间看到老师教小朋友唱歌,很有感触,这里分享一下。

要学的歌词大致如下:

北风北风呼呼呼

雪花雪花飘飘飘

小手小手搓搓搓

天天锻炼身体好



北风北风呼呼呼

雪花雪花飘飘飘

小脚小脚跺跺跺

天天锻炼身体好



北风北风呼呼呼

雪花雪花飘飘飘

小球小球拍拍拍

天天锻炼身体好



引导的方式如下:

  • 抛出一个问题:冬天那么冷,做哪些事情可以暖和?有很多回答:洗热水澡,多穿衣服。

  • 继续递进问题:能不能不通过外物保持暖和?也有很多回答:做运动,搓搓手等。

  • 然后问:大家可以听听音乐中有哪些活动?开始播放音乐。听完后大家补充回答:可以搓手、跺脚、拍球。 老师将提到的东西,做成卡片,贴在小黑板上。

  • 然后问:哪些歌词出现了3次?大家回答:北风北风呼呼呼、雪花雪花飘飘飘、天天锻炼身体好。

  • 然后通过播放音乐,大家按照黑版提示唱了几遍。

  • 然后分2组,让大家依此进行了表演。



我发现通过这样一轮操作下来,小朋友们很快能够记住歌词内容并唱出来。这对于思维比较简单的小孩来说,的确很不容易。

这让我遐想万千,因为我们作为程序员,工作中很关注逻辑、结构、复用等。但是我们却没有很多好的实践,无论是大家对于一套架构的理解,还是说对于团队系统的认知。

但学歌这个过程,让我觉得大道至简,很多事都是相通的,甚至于说,我们陷入于软件世界中,缺少了最为广泛的生活视角,思考的源动力有限。生活是最好的老师,也是智慧最多的地方。

举例来说,上面的学歌过程,可以抽成很好的学习模版:

  • 提出一个关注点问题;

  • 将这个问题进一步细化描述,形成一定的目标;

  • 将需要了解的内容呈现出来,带着问题去观察了解;

  • 大家可以一起探讨,互相补充理解;

  • 尝试发现规律:比如什么经常重复,有哪些重要动作;

  • 形成自己的串联理解,尝试描述出来;

  • 进行实践,大家展示交流。



我不知道,按照我们日常工作中的一些理论或者逻辑,能否实现快速教会小朋友们这样的事情。或许说,我们日常的工作中的事情,本没有什么深层次的逻辑,只是将砖头,从A点搬到B点,有时也会再从B点搬回来。并没有思考如何搬,如何搬的更好;也很难教会拌水泥、扭钢丝这样的工作。事实上,我们可能得承认我们的认知有限。

结语

最后分享一句最近看到的话:“好的设计的重要目标之一就是让系统一目了然”,可能也是大道至简。

¤ 拓展阅读 ¤

3DXR技术 | 终端技术 | 音视频技术

服务端技术 | 技术质量 | 数据算法

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

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

相关文章

AG32 FPGA 的 Block RAM 资源:M9K 使用

1. 概述 AG32 FPGA 包含了 4 个 M9K 块,每个 M9K 块的容量为 8192 bits,总计为 4 个 M9K(4K bytes)。这使得 AG32 的内部存储非常适合嵌入式应用,能够有效地利用片上资源。 M9K 参数 参考自《AGRV2K_Rev2.0.pdf》。…

Java中如何安全地停止线程?

大家好,我是锋哥。今天分享关于【Java中如何安全地停止线程?】面试题。希望对大家有帮助; Java中如何安全地停止线程? 1000道 互联网大厂Java工程师 精选面试题-Java资源分享网 在Java中,安全地停止线程是一项重要的任务,尤其…

2025寒假备战蓝桥杯01---朴素二分查找的学习

文章目录 1.暴力方法的引入2.暴力解法的思考 与改进3.朴素二分查找的引入4.朴素二分查找的流程5.朴素二分查找的细节6.朴素二分查找的题目 1.暴力方法的引入 对于下面的这个有序的数据元素的组合,我们的暴力解法就是挨个进行遍历操作,一直找到和我们的这…

【HF设计模式】06-命令模式

声明:仅为个人学习总结,还请批判性查看,如有不同观点,欢迎交流。 摘要 《Head First设计模式》第6章笔记:结合示例应用和代码,介绍命令模式,包括遇到的问题、采用的解决方案、遵循的 OO 原则、…

Ubuntu16.04 安装OpenCV4.5.4 避坑

Ubuntu16.04 安装C版OpenCV4.5.4 Ubuntu16.04 VSCode下cmakeclanglldb调试c 文章目录 Ubuntu16.04 安装C版OpenCV4.5.41. 下载Opencv压缩包2. 安装Opencv-4.5.43. 配置OpenCV的编译环境4.测试是否安装成功 1. 下载Opencv压缩包 下载Opencv压缩包,选择source版本。…

Flutter 改完安卓 applicationId 后App 闪退问题。

一、问题 当我们项目创建完,想 build.gradle 改 applicationId 的时候,再次执行的时候可能会出现 app 闪退问题, 控制台不显示任何错误提示 也不出现 Exit 停止运行的情况。(像下方这样, 而 app 只是在模拟器中一闪而…

专利申请流程详解

专利申请流程详解 文章目录 专利申请流程详解前言一、什么是专利二、如何申请专利1. 注册国家知识产权局账号2. 账号登录和认证3. 专利费用减免4. 专利申请 三、注意事项(一)、外观设计专利(二)、实用新型专利(三&…

使用缓存保存验证码进行登录校验

在Spring Boot项目中使用Redis进行登录校验,一般的做法是将用户的登录状态(例如,JWT令牌或者用户信息)存储在Redis中,并在后续请求中进行校验。 我们需要建立两个拦截器:RefreshTokenInterceptor LoginIn…

会议签到系统的架构和实现

会议签到系统的架构和实现 摘要:通过定制安卓会议机开机APP呈现签到界面,并且通过W/B结构采集管理签到信息,实现会议签到的功能。为达到此目标本文将探讨使用Redis提供后台数据支持;使用SocketIo处理适时消息;使用Flask进行原型开…

通过Ukey或者OTP动态口令实现windows安全登录

通过 安当SLA(System Login Agent)实现Windows安全登录认证,是一种基于双因素认证(2FA)的解决方案,旨在提升 Windows 系统的登录安全性。以下是详细的实现方法和步骤: 1. 安当SLA的核心功能 安…

.Net Core微服务入门系列(一)——项目搭建

系列文章目录 1、.Net Core微服务入门系列(一)——项目搭建 2、.Net Core微服务入门全纪录(二)——Consul-服务注册与发现(上) 3、.Net Core微服务入门全纪录(三)——Consul-服务注…

Ubuntu 24.04 LTS 安装 Docker Desktop

Docker 简介 Docker 简介和安装Ubuntu上学习使用Docker的详细入门教程Docker 快速入门Ubuntu版(1h速通) Docker 安装 参考 How to Install Docker on Ubuntu 24.04: Step-by-Step Guide。 更新系统和安装依赖 在终端中运行以下命令以确保系统更新并…

Spring MVC:设置响应

目录 引言 1. 返回静态页面 1.1 Spring 默认扫描路径 1.2 RestController 1.2.1 Controller > 返回页面 1.2.2 ResponseBody 2. 返回 HTML 2.1 RequestMapping 2.1.1 produces(修改响应的 Content-Type) 2.1.2 其他属性 3. 返回 JSON 4. 设置状态码 4.1 HttpSer…

GD32F303 GCC 环境搭建

一、引言 在嵌入式开发领域,GD32F303 微控制器以其出色的性能和丰富的功能被广泛应用。为了充分发挥其潜力,搭建一个高效的开发环境并深入理解项目构建过程至关重要。本文将详细介绍如何基于 GCC 工具链搭建 GD32F303 的开发环境,重点聚焦于…

路径规划之启发式算法之二十八:候鸟优化算法(Migrating Birds Optimization, MBO)

候鸟优化算法(Migrating Birds Optimization, MBO)是一种基于群体智能的元启发式优化算法,其灵感来源于候鸟迁徙时的“V”字形飞行队列。这种队列结构能够有效减少能量消耗,同时提高飞行效率。MBO算法通过模拟候鸟的迁徙行为,利用群体间的协作和信息共享来优化问题的解。 …

ESP8266 MQTT服务器+阿里云

MQTT私有平台搭建(EMQX 阿里云) 阿里云服务器 EMQX 搭建私有MQTT平台 1、搜索EMQX开源版本 2、查看各版本EMQX支持的UBUNTU版本 3、查看服务器Ubuntu版本 4、使用APT安装模式 5、按照官网指示安装并启动 6、下载安装MQTTX测试工具 7、设置云服务…

【机器学习实战中阶】使用SARIMAX,ARIMA预测比特币价格,时间序列预测

数据集说明 比特币价格预测(轻量级CSV)关于数据集 致谢 这些数据来自CoinMarketCap,并且可以免费使用该数据。 https://coinmarketcap.com/ 数据集:链接: 价格预测器 源代码与数据集 算法说明 SARIMAX(Seasonal AutoRegressive …

Postgresql源码(140)理解PG的编译流程(make、Makefile、Makefile.global.in)

PG16 PG中使用的makefile看起来代码比较多,但是实际逻辑比较简单,这里做一些抽象总结。 总结 Makefile.global.in的$(recurse)宏自动生成了target,可以方便的进入内存目录进行编译。 all: all-common-recurse all-common-recurse: submak…

Java数据结构——优先队列

目录 引言1. 优先队列2. 优先队列的实现2.1 堆的概念2.2 堆的创建2.2.1 堆的向下调整2.3 堆的插入2.4 堆的删除 3. 总结 引言 前面一篇文章讲了二叉树,本篇将讲述数据结构中的优先队列,优先队列则需要用到完全二叉树来实现。 1. 优先队列 队列&#x…

51c大模型~合集105

我自己的原文哦~ https://blog.51cto.com/whaosoft/13101924 #刚刚,ChatGPT开始有了执行力! 现在 AI 智能体可以 24*7 小时为你打工。 2025 刚过去了半个月,OpenAI 在智能体领域「开大」了。 今天,OpenAI 正在为 ChatGPT 推出…