Python设计模式:构建模式
1. 什么是构建模式
构建模式(Builder Pattern)是一种创建型设计模式,它允许使用多个简单的对象一步步构建一个复杂的对象。构建模式通过将构建过程与表示分离,使得同样的构建过程可以创建不同的表示。换句话说,构建模式提供了一种灵活的方式来创建复杂对象,避免了构造函数参数过多的问题。
- 工厂模式通过一个工厂类来创建对象,适合于创建多个相似对象,隐藏了对象创建的具体实现。
- 构建模式通过构建者和指挥者的组合,逐步构建一个复杂对象,适合于需要多个步骤和多个部分的组合。
- 组合模式则允许将对象组合成树形结构,适合于处理部分和整体的层次关系。
1.1 工厂模式与构建模式的对比
在工厂模式中,我们将创建一个简单的汽车工厂来生成汽车对象。
class Car:def __init__(self, make, model):self.make = makeself.model = modeldef __str__(self):return f"{self.make} {self.model}"class CarFactory:@staticmethoddef create_car(make, model):return Car(make, model)# 客户端代码
if __name__ == "__main__":car1 = CarFactory.create_car("Toyota", "Camry")car2 = CarFactory.create_car("Honda", "Accord")print(car1) # 输出: Toyota Camryprint(car2) # 输出: Honda Accord
在构建模式中,我们将使用构建者模式逐步构建一个复杂的汽车对象。
# 产品类
class Car:def __init__(self):self.make = Noneself.model = Noneself.year = Noneself.color = Nonedef __str__(self):return f"{self.year} {self.color} {self.make} {self.model}"# 构建者接口
class CarBuilder:def set_make(self, make):passdef set_model(self, model):passdef set_year(self, year):passdef set_color(self, color):passdef build(self):pass# 具体构建者
class ConcreteCarBuilder(CarBuilder):def __init__(self):self.car = Car()def set_make(self, make):self.car.make = makedef set_model(self, model):self.car.model = modeldef set_year(self, year):self.car.year = yeardef set_color(self, color):self.car.color = colordef build(self):return self.car# 指挥者
class Director:def __init__(self, builder):self.builder = builderdef construct_car(self, make, model, year, color):self.builder.set_make(make)self.builder.set_model(model)self.builder.set_year(year)self.builder.set_color(color)return self.builder.build()# 客户端代码
if __name__ == "__main__":builder = ConcreteCarBuilder()director = Director(builder)# 构建一辆车car = director.construct_car("Toyota", "Camry", 2022, "Blue")print(car) # 输出: 2022 Blue Toyota Camry
1.2 组合模式与构建模式的对比
在组合模式中,我们将创建一个文件系统的结构,允许文件和文件夹以树形结构组合。
class Component:def operation(self):passclass File(Component):def __init__(self, name):self.name = namedef operation(self):return f"File: {self.name}"class Folder(Component):def __init__(self, name):self.name = nameself.children = []def add(self, component):self.children.append(component)def remove(self, component):self.children.remove(component)def operation(self):results = [f"Folder: {self.name}"]for child in self.children:results.append(child.operation())return "\n".join(results)# 客户端代码
if __name__ == "__main__":file1 = File("file1.txt")file2 = File("file2.txt")folder1 = Folder("Folder 1")folder1.add(file1)folder1.add(file2)print(folder1.operation())
在构建模式中,我们将使用构建者模式逐步构建一个复杂的文件对象。
class File:def __init__(self, name):self.name = namedef __str__(self):return f"File: {self.name}"class Folder:def __init__(self, name):self.name = nameself.children = []def add(self, component):self.children.append(component)def remove(self, component):self.children.remove(component)def __str__(self):results = [f"Folder: {self.name}"]for child in self.children:results.append(str(child))return "\n".join(results)class FileBuilder:def __init__(self):self.folder = Nonedef create_folder(self, name):self.folder = Folder(name)def add_file(self, file_name):if self.folder:self.folder.add(File(file_name))def build(self):return self.folder# 客户端代码
if __name__ == "__main__":builder = FileBuilder()builder.create_folder("Folder 1")builder.add_file("file1.txt")builder.add_file("file2.txt")folder = builder.build()print(folder) # 输出: Folder: Folder 1\nFile: file1.txt\nFile: file2.txt
2. 构建模式的结构
构建模式通常包含以下几个角色:
- 产品(Product):表示被构建的复杂对象。
- 构建者(Builder):定义了创建产品的抽象接口,包含构建产品的各个部分的方法。
- 具体构建者(ConcreteBuilder):实现了构建者接口,负责构建产品的具体部分。
- 指挥者(Director):负责管理构建过程,使用构建者来构建产品。
# 产品类
class Car:def __init__(self):self.make = Noneself.model = Noneself.year = Noneself.color = Nonedef __str__(self):return f"{self.year} {self.color} {self.make} {self.model}"# 构建者接口
class CarBuilder:def set_make(self, make):passdef set_model(self, model):passdef set_year(self, year):passdef set_color(self, color):passdef build(self):pass# 具体构建者
class ConcreteCarBuilder(CarBuilder):def __init__(self):self.car = Car()def set_make(self, make):self.car.make = makedef set_model(self, model):self.car.model = modeldef set_year(self, year):self.car.year = yeardef set_color(self, color):self.car.color = colordef build(self):return self.car# 指挥者
class Director:def __init__(self, builder):self.builder = builderdef construct_car(self, make, model, year, color):self.builder.set_make(make)self.builder.set_model(model)self.builder.set_year(year)self.builder.set_color(color)return self.builder.build()# 客户端代码
if __name__ == "__main__":builder = ConcreteCarBuilder()director = Director(builder)# 构建一辆车car = director.construct_car("Toyota", "Camry", 2022, "Blue")print(car) # 输出: 2022 Blue Toyota Camry
-
产品类(Car):表示被构建的复杂对象,包含多个属性(如品牌、型号、年份和颜色),并实现了一个
__str__
方法用于输出对象的字符串表示。 -
构建者接口(CarBuilder):定义了创建产品的抽象接口,包含设置汽车各个属性的方法。
-
具体构建者(ConcreteCarBuilder):实现了构建者接口,负责实现构建汽车的具体部分。它创建一个
Car
对象并逐步设置其属性,最后返回构建好的Car
对象。 -
指挥者(Director):负责管理构建过程,使用构建者来构建产品。它接受一个构建者对象,并通过调用构建者的方法来构建一个完整的
Car
对象。 -
客户端代码:创建了一个
ConcreteCarBuilder
实例和一个Director
实例。通过指挥者的construct_car
方法,逐步构建了一辆汽车,并最终输出了构建好的汽车对象。
3. 示例 1:构建复杂的餐厅订单系统
在日常开发中,构建模式常用于构建复杂对象的场景。一个典型的例子是餐厅订单系统。在这个系统中,顾客可以选择不同的菜品、饮料和配餐,最终生成一个完整的订单。使用构建模式可以有效地管理这个复杂的构建过程。
在这个示例中,我们将创建一个订单对象,顾客可以通过不同的步骤来构建这个订单。我们将定义以下角色:
- 产品(Order):表示顾客的订单,包含多个菜品和饮料。
- 构建者(OrderBuilder):定义了创建订单的抽象接口,包含添加菜品和饮料的方法。
- 具体构建者(ConcreteOrderBuilder):实现了构建者接口,负责构建订单的具体部分。
- 指挥者(Director):负责管理构建过程,使用构建者来构建订单。
# 产品类
class Order:def __init__(self):self.dishes = []self.drinks = []def add_dish(self, dish):self.dishes.append(dish)def add_drink(self, drink):self.drinks.append(drink)def __str__(self):order_details = "Order Details:\n"order_details += "Dishes:\n" + "\n".join(self.dishes) + "\n"order_details += "Drinks:\n" + "\n".join(self.drinks)return order_details# 构建者接口
class OrderBuilder:def add_dish(self, dish):passdef add_drink(self, drink):passdef build(self):pass# 具体构建者
class ConcreteOrderBuilder(OrderBuilder):def __init__(self):self.order = Order()def add_dish(self, dish):self.order.add_dish(dish)def add_drink(self, drink):self.order.add_drink(drink)def build(self):return self.order# 指挥者
class Director:def __init__(self, builder):self.builder = builderdef construct_order(self, dishes, drinks):for dish in dishes:self.builder.add_dish(dish)for drink in drinks:self.builder.add_drink(drink)return self.builder.build()# 客户端代码
if __name__ == "__main__":builder = ConcreteOrderBuilder()director = Director(builder)# 构建一个订单dishes = ["Spaghetti", "Caesar Salad", "Grilled Chicken"]drinks = ["Coke", "Water"]order = director.construct_order(dishes, drinks)print(order) # 输出订单详情
Order Details:
Dishes:
Spaghetti
Caesar Salad
Grilled Chicken
Drinks:
Coke
Water
-
产品类(Order):表示顾客的订单,包含多个菜品和饮料。它提供了添加菜品和饮料的方法,并实现了一个
__str__
方法用于输出订单的详细信息。 -
构建者接口(OrderBuilder):定义了创建订单的抽象接口,包含添加菜品和饮料的方法。
-
具体构建者(ConcreteOrderBuilder):实现了构建者接口,负责构建订单的具体部分。它创建一个
Order
对象并逐步添加菜品和饮料,最后返回构建好的订单对象。 -
指挥者(Director):负责管理构建过程,使用构建者来构建订单。它接受一个构建者对象,并通过调用构建者的方法来构建一个完整的订单对象。
-
客户端代码:创建了一个
ConcreteOrderBuilder
实例和一个Director
实例。通过指挥者的construct_order
方法,逐步构建了一个订单,并最终输出了订单的详细信息。
相关文章:
Python设计模式:构建模式
1. 什么是构建模式 构建模式(Builder Pattern)是一种创建型设计模式,它允许使用多个简单的对象一步步构建一个复杂的对象。构建模式通过将构建过程与表示分离,使得同样的构建过程可以创建不同的表示。换句话说,构建模…...
C++类间的 “接力棒“ 传递:继承(下)
文章目录 5. 继承与友元6.继承与静态成员7.菱形继承8.继承和组合希望读者们多多三连支持小编会继续更新你们的鼓励就是我前进的动力! 本篇接着补充继承方面的内容,同时本篇的菱形继承尤为重要 5. 继承与友元 class Student; class Person { public:fri…...
C++11QT复习 (十六)
文章目录 Day11 移动语义回顾一、移动语义基础概念二、自定义 String 类的移动语义实现输出运算符重载: 三、测试函数:验证移动与拷贝行为四、左值与右值的补充说明右值引用作为函数返回值 五、知识总结如何区分左值与右值? 六、附加说明&…...
Redis客户端命令到服务器底层对象机制的完整流程?什么是Redis对象机制?为什么要有Redis对象机制?
Redis客户端命令到服务器底层对象机制的完整流程 客户端 → RESP协议封装 → TCP传输 → 服务器事件循环 → 协议解析 → 命令表查找 → 对象机制 → 动态编码 → 数据结构操作 → 响应编码 → 网络回传 Redis客户端命令到服务器底层对象机制的完整流程可分为协议封装、命令解…...
鸿蒙NEXT开发节流、防抖工具类(ArkTs)
import { CacheUtil } from ./CacheUtil; import { DateUtil } from ./DateUtil;/*** 节流、防抖工具类(用于点击事件,防止按钮被重复点击)** author 鸿蒙布道师* since 2025/04/07*/ export class ClickUtil {private static throttleTimeou…...
Qt程序 Windows打包
目的 运行Qt的程序,遇上如下问题: 显然是少很多Qt库,那就把Qt库放到这里,Qt提供这一个命令windeployqt.exe. windeployqt windeployqt是Qt框架提供的一个工具,主要用于自动打包Windows平台上的Qt应用程序及其依赖项…...
2025-04-07(DS复习):Databricks DLT 详解
Databricks Delta Live Tables (DLT) 详解 Delta Live Tables (DLT) 是 Databricks 提供的一个智能框架,用于构建可靠、可扩展的数据处理管道。它简化了ETL(提取、转换、加载)和ELT(提取、加载、转换)流程的开发和管理,特别适合在数据湖house架构中实现…...
音视频入门基础:RTCP专题(3)——RTCP协议简介(中)
本文接着《音视频入门基础:RTCP专题(2)——RTCP协议简介(上)》,继续对RTCP协议进行简介。本文的一级标题从“九”开始。 九、Sender and Receiver Reports 本段内容对应《RFC 3550》的第6.4节。根据《RFC …...
嵌入式工程师多线程编程(二)生产者-消费者模式
生产者-消费者模式详解:多线程编程的核心范式 生产者-消费者模式(Producer-Consumer Pattern)是多线程编程中最经典的设计模式之一,它通过解耦生产者和消费者的工作流程,实现了线程间的高效协作与资源管理。本文将深入剖析这一模式的原理、实…...
秒杀系统的性能优化
秒杀任务总体QPS预期是每秒几十万,对tomcat、redis、JVM参数进行优化。 tomcat线程数 4核8G的机器,一般就是开200-300个工作线程,这是个经验值。每秒一个线程处理3-5个请求,200多个线程的QPS可以达到1000左右。线程不能太多&…...
MySQL学习笔记集--索引
索引 索引是数据库中用于提高查询效率的一种数据结构。 它类似于书籍的目录,通过索引可以快速定位到表中的特定行,而无需扫描整个表。 索引的类型 主键索引(Primary Key Index) 自动创建,用于唯一标识表中的每一行。…...
深入理解重排(Reflow)与重绘(Repaint),写出高性能 CSS 动画
在前端开发中,CSS 动画是提升用户体验的重要手段,但很多开发者在使用动画时并不了解浏览器背后的渲染机制,导致动画卡顿甚至影响整体性能。本文将带你深入理解 CSS 中的两大核心概念 —— 重排(Reflow) 与 重绘&#x…...
Elasticsearch 从入门到实战:文档聚合操作及总结
四、文档操作:数据的增删改查 4.1 添加文档 文档(Document)是索引中的最小数据单元,使用 POST 或 PUT 添加: json POST /products/_doc/1 { "name": "华为Mate50 Pro", "price": 6…...
前缀和和差分笔记
前缀和和差分笔记 一维前缀和 示意图如下: 代码: **核心公式:sum[i]sum[i-1]a[i];(计算前缀和的)**#include<bits/stdc.h> using namespace std; const int N10000; #define ll long long int a[N],sum[N]; i…...
SSRF漏洞利用的小点总结和实战演练
含义理解: SSRF(Server-Side Request Forgery,服务器请求伪造)是一种由攻击者构造请求,由服务端发起请求的安全漏洞,一般情况下,SSRF攻击的目标是外网无法访问的内网系统。 攻击者通过篡改URL…...
IAR推动嵌入式开发:云就绪、可扩展的CI/CD和可持续自动化
全球领先的嵌入式系统开发软件解决方案供应商IAR正式发布全新云就绪平台,为嵌入式开发团队提供企业级的可扩展性、安全性和自动化能力。该平台于在德国纽伦堡举办的embedded world 2025展会上正式亮相,标志着将现代DevSecOps工作流集成到嵌入式软件开发中…...
瓦片数据合并方法
影像数据 假如有两份影像数据 1.全球底层影像0-5级别如下: 2.局部高清影像数据级别9-14如下: 合并方法 将9-14文件夹复制到全球底层0-5的目录下 如下: 然后合并xml文件 使得Tileset设置到最高级(包含所有级别)&…...
RISC-V AIA学习---IPI 处理器间中断
对于有多个hart的机器,必须为每个 hart 提供一个由具体实现定义的内存地址。向这个地址写入数据,就能向该 hart 发送一个机器级软件中断(主代码为 3)。换句话说,机器级的 IPI 可以通过这种方式,以机器级软件…...
Automattic 裁员16%,Matt Mullenweg称此举旨在提升盈利能力并增强投资实力
2025年4月3日,Automattic——这家以 WordPress.com、Tumblr 和 WooCommerce 等产品闻名的公司,宣布裁减其全球员工队伍的16%。这一决定是在周三通过公司博客文章和 Slack 内部消息向员工透露的。根据裁员前 Automattic 官网显示的员工人数(1,…...
图解AUTOSAR_SWS_FlexRayInterface
AUTOSAR FlexRay Interface 模块分析 本文档基于AUTOSAR SWS FlexRayInterface规范,对FlexRay Interface模块进行详细分析。 1. FlexRay Interface 模块架构 1.1 模块架构概览 1.2 架构说明 FlexRay Interface模块是AUTOSAR中的ECU抽象层组件,为上层模块提供统一的抽象接…...
AI赋能ArcGIS Pro——水系网络AI智能提取 | GIS人工智能制图技术解析
我们之前做了做了几期的AIGIS的分享。我们今天要再次做一个分享。 AI赋能ArcGIS Pro——水系网络智能提取全解析 DeepSeek结合ArcGIS Pro制作一个批量建库的脚本工具(代码一字未改,直接运行) 看老外如何玩DeepSeek!15分钟快速创…...
STM32江科大----IIC
声明:本人跟随b站江科大学习,本文章是观看完视频后的一些个人总结和经验分享,也同时为了方便日后的复习,如果有错误请各位大佬指出,如果对你有帮助可以点个赞小小鼓励一下,本文章建议配合原视频使用❤️ 如…...
RAG(检索增强生成)系统,提示词(Prompt)表现测试(数据说话)
在RAG(检索增强生成)系统中,评价提示词(Prompt)设计是否优秀,必须通过量化测试数据来验证,而非主观判断。以下是系统化的评估方法、测试指标和具体实现方案: 一、提示词优秀的核心标准 优秀的提示词应显著提升以下指标: 维度量化指标测试方法事实一致性Faithfulness …...
【leetcode hot 100 763】划分字母区间
解法一:用map记录<字母,字母出现的次数>,循环取出value-1,每次判断已经取出的字母(Set记录)是否还在后面存在(value>1),若存在继续循环,若不存在开启…...
PCB工艺:现代电子产品的核心制造技术
引言 PCB(Printed Circuit Board,印刷电路板)是电子设备的核心组成部分,几乎所有现代电子产品,从智能手机到航天设备,都依赖于PCB实现电路连接。PCB制造工艺的进步直接影响电子产品的性能、可靠性和成本。…...
【UE5 C++课程系列笔记】34——结构体与Json的相互转化
目录 准备工作 一、结构体转Json 二、Json转结构体 三、复杂结构体与Json的转换 主要通过借助FJsonObjectConverter类实现结构体和 JSON 之间的相互转换。 准备工作 首先新建一个结构体如下 添加两个方法分别用于将Struct转为Json、Json转为Struct 一、结构体转Json FStri…...
2025最新系统 Git 教程(二)
第2章 Git基础 2.1 Git 基础 - 获取 Git 仓库 如果你只想通过阅读一章来学习 Git,那么本章将是你的不二选择。 本章涵盖了你在使用 Git 完成各种工作时将会用到的各种基本命令。 在学习完本章之后,你应该能够配置并初始化一个仓库(reposito…...
力扣hot100_动态规划
动态规划 hot100_198. 打家劫舍 你是一个专业的小偷,计划偷窃沿街的房屋。每间房内都藏有一定的现金,影响你偷窃的唯一制约因素就是相邻的房屋装有相互连通的防盗系统,如果两间相邻的房屋在同一晚上被小偷闯入,系统会自动报警。…...
玄机-第六章-哥斯拉4.0流量分析的测试报告
目录 一、测试环境 二、测试目的 三、操作过程 Flag1 Flag2 Flag3 Flag4 Flag5 Flag6 Flag7 Flag8 Flag9 Flag10 Flag11 Flag12 Flag13 pam_unix.so关键代码 四、结论 一、测试环境 靶场介绍:国内厂商设置的玄机靶场,以应急响应题目著…...
【Hadoop入门】Hadoop生态圈概述:核心组件与应用场景概述
1 Hadoop生态圈概述 Hadoop生态圈是以 HDFS(分布式存储) 和 YARN(资源调度) 为核心,围绕大数据存储、计算、管理、分析等需求发展出的一系列开源工具集合。 核心特点: 模块化:各组件专注解决特定…...
深度学习实战电力设备缺陷检测
本文采用YOLOv11作为核心算法框架,结合PyQt5构建用户界面,使用Python3进行开发。YOLOv11以其高效的实时检测能力,在多个目标检测任务中展现出卓越性能。本研究针对电力设备缺陷数据集进行训练和优化,该数据集包含丰富的电力设备缺…...
随机产生4位随机码(java)
Random类: 用于生成随机数 import java.util.Random; 导入必要的类 generateVerificationCode()方法: 这是一个静态方法,可以直接通过类名调用 返回一个6位数字的字符串,首位不为0 生成首位数字: random.nextInt…...
音视频入门基础:RTCP专题(4)——RTCP协议简介(下)
本文接着《音视频入门基础:RTCP专题(3)——RTCP协议简介(中)》,继续对RTCP协议进行简介。本文的一级标题从“十四”开始。 十四、SDES: Source Description RTCP Packet 本段内容对应《RFC 3550》的第6.5节…...
PyCharm2024.3.5专业版解决Conda executable is not found问题
项目场景: pycharm使用anaconda 内的虚拟环境 pycharm 2024.3.5 专业版 C:\Users\Administrator>conda infoactive environment : transmute_recipe_generatoractive env location : D:\anaconda3\envs\transmute_recipe_generatorshell level : 1user config…...
滑动窗口思想 面试算法高频题
基本思想 滑动窗口思想其实就是快慢型的特例 计算机网络中滑动窗口协议(Sliding Window Protocol),该协议是TCP实现流量控制等的核心策略之一。事实上在与流量控制、熔断、限流、超时等场景下都会首先从滑动窗口的角度来思考问题࿰…...
Linux中特殊的变量
1.$# 含义:表示传入脚本或函数的参数数量。 用法:用于检查用户是否提供了足够的参数。 示例: #!/bin/bash echo "参数数量: $#"2.$? 含义:表示上一条命令的退出状态。如果命令成功执行,值为 0;…...
Linux文件系统与日志分析
目录 一.日志 1.1日志的定义 1.2日志的功能 1.3日志的分类 1.4日志的文件格式 1.5用户日志 1.6一些常见的日志 1.7日志消息的级别 二.系统日志管理 rsyslog 2.1rsyslog的定义 2.2rsyslog 配置文件 2.3rsyslog的实际应用----单独显示某一服务的日志 1.编辑rsyslog配…...
从传统物流到智能调度的全链路升级
一、TMS系统升级的核心目标与整体框架 (一)为什么要升级?传统物流管理的三大痛点 调度效率低下:过去依赖人工分单、手动匹配承运商,订单量大时容易出错,比如不同区域的订单混排导致运输路线绕路ÿ…...
UE5中如何修复后处理动画蓝图带来的自然状态下的metablriger身体绑定形变(如耸肩)问题
【[metablriger] UE5中如何修复后处理动画蓝图带来的自然状态下的metablriger身体绑定形变(如耸肩)问题】 UE5中如何修复后处理动画蓝图带来的自然状态下的metablriger身体绑定形变(如耸肩)问题...
STL_vector_01_基本用法
👋 Hi, I’m liubo👀 I’m interested in harmony🌱 I’m currently learning harmony💞️ I’m looking to collaborate on …📫 How to reach me …📇 sssssdsdsdsdsdsdasd🎃 dsdsdsdsdsddfsg…...
css2学习总结之尚品汇静态页面
css2总结之尚品汇 一、布局 在 PC 端网页中,一般都会有一个固定宽度且水平居中的盒子,来显示网页的主要内容,这是网页 的版心。 版心的宽度一般是 960 ~ 1200 像素之间。 版心可以是一个,也可以是多个。 二、布局相关名词 我…...
Lua 第5部分 表
表( Table )是 Lua 语言中最主要(事实上也是唯一的)和强大的数据结构。 使用表,Lua语言可以以一种简单、统一且高效的方式表示数组、集合、记录和其他很多数据结构。 Lua语言也使用表来表示包( package &am…...
01分数规划
https://ac.nowcoder.com/acm/contest/22353/1011 并不需要高级数据结构,对答案二分即可。 假定当前二分的答案为 x x x,则 ∑ v i ∑ w i ≥ x \frac{ \sum_{v_i} }{\sum_{w_i}} ≥ x ∑wi∑vi≥x 成立时 x x x 才可能是最后的答案。 化简式…...
无人机动力系统全维度解析:技术演进、选型策略与未来趋势
一、动力系统技术理念与设计逻辑 (一)核心技术指标 能量密度:决定续航能力的关键参数,单位为 Wh/kg。当前主流锂聚合物电池能量密度约 250-300Wh/kg,氢燃料电池可达 500-800Wh/kg,航空燃油则高达 12,000W…...
重新审视中国的GB标准(44495 – 44497)
此前,我们深入探讨了中国新推出的智能互联汽车(ICV)网络安全标准GB Standard 44495-2024。我们探讨了该标准对汽车制造商的影响、与UNECE R155和ISO/SAE 21434等全球标准的一致性,以及该标准对未来汽车网络安全的意义。 然而,GB 44495-2024并…...
Linux进程控制(五)之做一个简易的shell
文章目录 做一个简易的shell预备知识代码实现运行结果 做一个简易的shell 重谈Shell shell是操作系统的一层外壳程序,帮我们用户执行指令, 获取到指令后,交给操作系统,操作系统执行完后,把执行结果通过shell交给用户…...
Apache Kafka全栈技术解析
目录 第一章 Kafka概述与核心价值 1.1 消息队列的演进与Kafka的诞生 1.2 Kafka的核心应用场景 1.3 Kafka生态全景图 第二章 Kafka核心概念与架构解析 2.1 核心概念深度剖析 2.2 Kafka架构设计精要 第三章 Kafka环境搭建与配置 3.1 单机部署实战 3.2 集群部署最佳实践 …...
结合 Flink/Spark 进行 AI 大数据处理(实时数据 + AI 推理的应用场景)
随着企业对实时智能决策的需求日益增强,将 Flink / Spark 等流批计算框架 与 大模型推理能力相结合,正在成为 AI 工业化落地的重要实践路径。本篇文章将深入介绍如何将 AI 模型集成到大数据流处理系统中,实现实时感知、智能判断与自动反馈。 1. 为什么需要“实时数据 + AI 推…...
开发PDF时,如何比较 PDF 文件
在 PDF 论坛上,“如何比较 PDF 文件”是一个经常被提到的问题。在开始之前,重要的是要明确你想要比较的内容是什么。 不同的 PDF 文件可能看起来一样吗? 是的,可能。不同的 PDF 创建工具可能会生成在视觉上完全相同的页面&#x…...
自动提取pdf公式 ➕ 输出 LaTeX
# 创建打包脚本的主内容 script_content """ from doc2x.extract_formula import extract_formula_imgs from pix2text import Pix2Text from PIL import Image import osdef main():pdf_path "your_file.pdf" # 将你的PDF命名为 your_file.pdf 并…...