当前位置: 首页 > news >正文

AI图像处理工具:开发者高阶用法与最佳实践

引言

随着人工智能技术的迅猛发展,AI图像处理工具正日益成为开发者工作流程中不可或缺的一部分。这些工具不仅能有效处理图像,还能通过深度学习模型实现复杂的图像理解和生成任务。本文将深入探讨开发者在使用AI图像处理工具时的高阶用法,提供关键代码示例,并分析如何最大化利用这些工具的功能。

1. 高阶图像处理技术

1.1 自定义数据预处理与增强

数据预处理和增强在深度学习中是提高模型性能的关键步骤。通过合理的处理和增强,开发者可以生成更多的训练样本,从而提升模型的泛化能力。

1.1.1 数据预处理的重要性

数据预处理是将原始数据转换为适合模型训练的格式和范围。常见的预处理步骤包括:

  • 归一化:将数据缩放到特定范围内,通常是[0, 1]或[-1, 1]。
  • 去噪声:使用滤波器减少图像噪声,提高图像质量。
  • 裁剪与缩放:统一图像大小,确保模型输入一致性。
1.1.2 数据增强的技术

数据增强通过对训练数据进行变换生成新的样本,常见的增强技术包括:

  • 随机旋转
  • 随机平移
  • 镜像翻转
  • 随机缩放
  • 添加噪声

示例代码:使用Keras进行图像数据增强

from tensorflow.keras.preprocessing.image import ImageDataGenerator# 创建数据增强生成器
datagen = ImageDataGenerator(rotation_range=40,width_shift_range=0.2,height_shift_range=0.2,shear_range=0.2,zoom_range=0.2,horizontal_flip=True,fill_mode='nearest'
)# 加载图像并调整形状
img = load_img('image.jpg')
x = img_to_array(img)
x = np.expand_dims(x, axis=0)# 生成增强图像
i = 0
for batch in datagen.flow(x, batch_size=1):plt.imshow(array_to_img(batch[0]))plt.show()i += 1if i >= 5:  # 只生成5张图像break

1.2 迁移学习与模型微调

迁移学习允许开发者利用预训练的深度学习模型,快速实现高效的图像处理应用。通过微调这些模型,可以在小规模数据集上取得良好的效果。

1.2.1 迁移学习的原理

迁移学习的基本思想是将一个任务上学到的知识应用到另一个相关任务上。在图像处理领域,预训练模型如VGG16、ResNet等,能够为新任务提供良好的特征提取能力。

1.2.2 模型微调步骤
  1. 加载预训练模型,去掉顶部的全连接层。
  2. 冻结卷积层以保持预训练的权重。
  3. 添加新的全连接层以适应新的任务。
  4. 在新的数据集上进行训练。

示例代码:使用TensorFlow的迁移学习

from tensorflow.keras.applications import VGG16
from tensorflow.keras.models import Model
from tensorflow.keras.layers import Dense, Flatten# 加载预训练的VGG16模型
base_model = VGG16(weights='imagenet', include_top=False, input_shape=(224, 224, 3))# 冻结基础模型的卷积层
for layer in base_model.layers:layer.trainable = False# 添加自定义分类器
x = Flatten()(base_model.output)
x = Dense(256, activation='relu')(x)
predictions = Dense(10, activation='softmax')(x)# 创建新的模型
model = Model(inputs=base_model.input, outputs=predictions)# 编译模型
model.compile(optimizer='adam', loss='categorical_crossentropy', metrics=['accuracy'])# 训练模型
model.fit(train_data, train_labels, epochs=10, validation_data=(val_data, val_labels))

1.3 使用GAN进行图像生成

生成对抗网络(GAN)是一个强大的工具,能够生成逼真的图像。开发者可以利用GAN进行图像风格转换、超分辨率重建等任务。

1.3.1 GAN的基本结构

GAN由两个神经网络组成:生成器(Generator)和判别器(Discriminator)。生成器生成图像,而判别器则判断图像是真实的还是由生成器生成的。两者通过对抗训练来优化各自的性能。

1.3.2 GAN的训练过程
  1. 训练判别器:使用真实数据和生成数据训练判别器,以便它能识别生成的数据。
  2. 训练生成器:更新生成器的参数,使其生成的图像能迷惑判别器。

示例代码:使用PyTorch实现简单的GAN

import torch
import torch.nn as nn
import torch.optim as optim# 定义生成器和判别器
class Generator(nn.Module):def __init__(self):super(Generator, self).__init__()self.main = nn.Sequential(nn.Linear(100, 256),nn.ReLU(True),nn.Linear(256, 512),nn.ReLU(True),nn.Linear(512, 1024),nn.ReLU(True),nn.Linear(1024, 784),nn.Tanh()  # 输出范围在[-1, 1])def forward(self, input):return self.main(input)class Discriminator(nn.Module):def __init__(self):super(Discriminator, self).__init__()self.main = nn.Sequential(nn.Linear(784, 512),nn.LeakyReLU(0.2, inplace=True),nn.Linear(512, 256),nn.LeakyReLU(0.2, inplace=True),nn.Linear(256, 1),nn.Sigmoid()  # 输出范围在[0, 1])def forward(self, input):return self.main(input)# 初始化模型和优化器
generator = Generator()
discriminator = Discriminator()
criterion = nn.BCELoss()
optimizerG = optim.Adam(generator.parameters(), lr=0.0002, betas=(0.5, 0.999))
optimizerD = optim.Adam(discriminator.parameters(), lr=0.0002, betas=(0.5, 0.999))# 训练GAN
for epoch in range(num_epochs):for i, data in enumerate(dataloader):# 训练判别器discriminator.zero_grad()real_data = data[0]label = torch.full((batch_size,), 1)  # 真实数据标签为1output = discriminator(real_data)errD_real = criterion(output, label)errD_real.backward()noise = torch.randn(batch_size, 100)  # 生成器输入噪声fake_data = generator(noise)label.fill_(0)  # 假数据标签为0output = discriminator(fake_data.detach())errD_fake = criterion(output, label)errD_fake.backward()optimizerD.step()# 训练生成器generator.zero_grad()label.fill_(1)  # 生成器目标是将假数据判别为真实output = discriminator(fake_data)errG = criterion(output, label)errG.backward()optimizerG.step()

1.4 深度学习模型的可视化

可视化模型的训练过程可以帮助开发者更好地理解模型的表现。使用工具如TensorBoard可以实时监控训练过程。

1.4.1 使用TensorBoard进行可视化

TensorBoard可以提供训练过程中的损失、准确度等信息的可视化,帮助开发者直观地评估模型的性能。

示例代码:在TensorFlow中使用TensorBoard

import tensorflow as tf# 创建日志目录
log_dir = "logs/"
tensorboard_callback = tf.keras.callbacks.TensorBoard(log_dir=log_dir, histogram_freq=1)# 训练模型并记录日志
model.fit(train_data, train_labels, epochs=10, validation_data=(val_data, val_labels), callbacks=[tensorboard_callback])# 启动TensorBoard
# 在命令行中运行:
# tensorboard --logdir=logs/

2. 开发者的最佳实践

2.1 使用容器化技术

利用Docker容器化技术,可以简化开发和部署过程,确保环境的一致性。容器化可以避免因环境配置差异导致的运行错误,提升开发效率。

2.1.1 Docker的基本概念

Docker允许开发者将应用及其所有依赖打包到一个轻量级的容器中。容器可以在任何支持Docker的平台上运行,确保一致性。

2.1.2 Dockerfile的基本结构

Dockerfile是定义Docker镜像的脚本。以下是一个简单的Dockerfile示例:

# 使用官方Python镜像
FROM python:3.8-slim# 设置工作目录
WORKDIR /app# 复制项目文件
COPY . .# 安装依赖
RUN pip install -r requirements.txt# 运行应用
CMD ["python", "app.py"]

2.2 整合版本控制

版本控制系统(如Git)对于管理项目代码至关重要。它能记录代码的变化,便于协作开发。

2.2.1 使用Git进行版本控制
  • 初始化Git仓库git init
  • 添加文件git add .
  • 提交更改git commit -m "Initial commit"
  • 创建分支git checkout -b new-feature
  • 合并分支git merge new-feature

2.3 建立持续集成和持续部署(CI/CD)

持续集成(Continuous Integration, CI)和持续部署(Continuous Deployment, CD)是现代软件开发的重要实践。它们能够自动化构建、测试和部署过程,确保软件交付的快速和高质量。

2.3.1 CI/CD的关键组件

1. 版本控制系统(VCS)

版本控制是CI/CD的基础。它记录代码的历史变更,支持多开发者协作。常见的VCS有Git、SVN等。GitHub、GitLab和Bitbucket等平台提供了基于Git的托管服务,便于团队协作。

2. 构建工具

构建工具负责将源代码编译成可执行的应用程序。常用的构建工具包括Maven(Java)、Gradle(Java、Android)、npm(JavaScript)等。它们能够自动化依赖管理和构建过程。

3. 自动化测试

自动化测试用于确保代码的质量。测试可以分为单元测试、集成测试和系统测试。常用的测试框架包括JUnit(Java)、pytest(Python)、Jest(JavaScript)等。

4. CI/CD工具

CI/CD工具负责自动化整个流程,包括构建、测试和部署。常见的CI/CD工具有Jenkins、Travis CI、CircleCI、GitHub Actions等。这些工具支持配置文件(如Jenkinsfile)来定义CI/CD流程。

2.3.2 CI/CD流程详解

  1. 代码提交 开发者在完成某个功能后,将代码提交到版本控制系统的主分支或特性分支。

  2. 触发构建 版本控制系统检测到代码提交后,自动触发CI/CD工具开始构建过程。

  3. 代码检出 CI/CD工具从版本控制系统检出最新的代码,准备进行构建。

  4. 依赖管理与构建 CI/CD工具使用构建工具下载依赖并编译代码,生成可执行的应用程序或构建产物。

  5. 自动化测试 构建完成后,CI/CD工具会运行一系列自动化测试,以确保新代码没有引入错误。如果测试失败,构建会被标记为失败,开发者需修复问题。

  6. 部署 如果构建和测试均成功,CI/CD工具会将应用程序自动部署到预生产或生产环境。此过程可通过脚本或API实现。

  7. 监控与反馈 部署后,系统会实时监控应用的表现。如果发现异常,开发者会及时收到反馈,以便进行修复。

2.3.3 CI/CD最佳实践

  • 小步提交:频繁提交小的代码变更,便于快速发现和修复问题。
  • 确保测试覆盖率:通过编写充分的自动化测试,确保代码的稳定性。
  • 使用环境变量:通过环境变量管理不同环境的配置,提升灵活性。
  • 版本化构建产物:每次构建生成唯一的版本号,便于追踪和回滚。
  • 实施代码审查:在合并到主分支前进行代码审查,确保代码质量。

3. 未来的发展趋势

随着AI和DevOps的不断发展,CI/CD也在不断演进。以下是一些可能的发展趋势:

3.1 多模态学习

多模态学习旨在结合多种数据类型(如图像、文本、音频)进行模型训练。通过整合不同类型的数据,开发者能够构建更具智能化的应用,提升模型的泛化能力。

3.1.1 应用案例
  • 智能助手:结合语音识别和图像识别,开发出能够理解用户指令的智能助手。
  • 自动内容生成:根据输入文本生成相应的图像,提升创作效率。
3.1.2 技术实现

开发者可以使用TensorFlow、PyTorch等框架,结合多种模型进行训练。利用图像处理工具和自然语言处理工具,可以实现多模态数据的特征提取和学习。

示例代码:使用PyTorch进行多模态学习

import torch
import torch.nn as nn
import torchvision.models as modelsclass MultiModalModel(nn.Module):def __init__(self):super(MultiModalModel, self).__init__()self.text_model = models.bert.BertModel.from_pretrained('bert-base-uncased')self.image_model = models.resnet50(pretrained=True)self.fc = nn.Linear(768 + 2048, 256)  # 768 for BERT and 2048 for ResNetdef forward(self, text_input, image_input):text_features = self.text_model(text_input)[1]  # 获取文本特征image_features = self.image_model(image_input)  # 获取图像特征combined_features = torch.cat((text_features, image_features), dim=1)  # 特征拼接output = self.fc(combined_features)return output

3.2 自动化机器学习(AutoML)

自动化机器学习(AutoML)旨在简化机器学习模型的构建过程,使非专业开发者也能使用AI技术。它通过自动化数据预处理、模型选择和超参数优化等步骤,降低了AI应用的门槛。

3.2.1 AutoML的工作流程
  1. 数据预处理:自动识别并处理缺失值、异常值等。
  2. 特征工程:自动生成特征,进行特征选择。
  3. 模型选择:通过试验不同的算法,找到最佳模型。
  4. 超参数优化:自动调整模型超参数以提高性能。
  5. 模型评估与部署:评估模型性能并自动部署。
3.2.2 常见的AutoML工具
  • Google Cloud AutoML:提供一系列AutoML服务,支持图像、文本和表格数据的处理。
  • H2O.ai:开源的AutoML工具,支持多种机器学习算法的自动化训练。
  • AutoKeras:基于Keras的AutoML工具,简化深度学习模型的构建过程。

示例代码:使用AutoKeras进行图像分类

import autokeras as ak# 创建图像分类模型
model = ak.ImageClassifier(overwrite=True, max_trials=3)# 训练模型
model.fit(train_images, train_labels, epochs=10)# 评估模型
accuracy = model.evaluate(test_images, test_labels)
print('Test accuracy:', accuracy)

3.3 边缘计算

边缘计算是指在数据产生源头附近(如设备、传感器)进行数据处理,而不是将数据发送到远程云端。通过在边缘设备上进行图像处理,能够降低延迟、节省带宽,并提升响应速度。

3.3.1 边缘计算的优势
  • 减少延迟:在本地设备上处理数据,响应时间更短。
  • 节省带宽:减少数据传输至云端的需求,节省网络资源。
  • 增强隐私保护:数据在本地处理,减少敏感数据的外泄风险。
3.3.2 应用案例
  • 智能监控:在摄像头或边缘设备上实时分析视频流,检测异常活动。
  • 医疗监测:在可穿戴设备上实时处理生理数据,提供即时反馈。
3.3.3 技术实现

开发者可以使用边缘计算平台(如AWS IoT Greengrass、Azure IoT Edge)将AI模型部署到边缘设备。通过优化模型大小和计算需求,确保其能够在资源有限的环境中高效运行。

示例代码:使用TensorFlow Lite进行边缘设备部署

import tensorflow as tf# 将模型转换为TensorFlow Lite格式
converter = tf.lite.TFLiteConverter.from_keras_model(model)
tflite_model = converter.convert()# 将模型保存为.tflite文件
with open('model.tflite', 'wb') as f:f.write(tflite_model)# 在边缘设备上加载和推理
interpreter = tf.lite.Interpreter(model_path='model.tflite')
interpreter.allocate_tensors()# 进行推理
input_details = interpreter.get_input_details()
output_details = interpreter.get_output_details()
interpreter.set_tensor(input_details[0]['index'], input_data)
interpreter.invoke()
output_data = interpreter.get_tensor(output_details[0]['index'])

结论

通过深入分析CI/CD、未来的多模态学习、自动化机器学习和边缘计算,本文展示了AI图像处理工具在现代开发中的多样化应用和前景。随着技术的不断进步,开发者需要紧跟潮流,灵活应用这些新技术,以提升开发效率和应用质量。希望本文能为开发者在图像处理领域的

相关文章:

AI图像处理工具:开发者高阶用法与最佳实践

引言 随着人工智能技术的迅猛发展,AI图像处理工具正日益成为开发者工作流程中不可或缺的一部分。这些工具不仅能有效处理图像,还能通过深度学习模型实现复杂的图像理解和生成任务。本文将深入探讨开发者在使用AI图像处理工具时的高阶用法,提…...

Spring Boot 2.6=>2.7 升级整理

版本变更: 1、SpringBootTest 属性源优先级:使用 SpringBootTest 注解的测试现在将命令行属性源置于测试属性源之上 在 Spring Boot 2.7 及更高版本中,对 SpringBootTest 的属性源优先级进行了调整,使得通过命令行传递的属性&am…...

Race Track Generator Ultimate:Race Track Generator(赛车场赛道看台场景创建工具)

下载:​​Unity资源商店链接资源下载链接 效果图:...

数据结构7——二叉树的顺序结构以及堆的实现

在上篇文章数据结构6——树与二叉树中,我们了解了树和二叉树的概念,接着上篇文章,在本篇文章中我们学习二叉树顺序结构的实现。 目录 1. 二叉树的顺序存储结构 2. 堆的概念及结构 1. 堆的概念 2. 堆的结构 3. 堆的实现 1. 堆节点 2. 交…...

leetcode hot100 之【LeetCode 21. 合并两个有序链表】 java实现

LeetCode 21. 合并两个有序链表 题目描述 将两个升序链表合并为一个新的 升序 链表并返回。新链表是通过拼接两个链表的节点组成的。 示例 1: 输入:l1 [1,2,4], l2 [1,3,4] 输出:[1,1,2,3,4,4]示例 2: 输入:l1 …...

Android Camera系列(五):Camera2

Life was like a box of chocolates, you never know what you’re gonna get. 生命就像一盒巧克力,你永远无法知道下一个是什么味道的。 Android Camera系列(一):SurfaceViewCamera Android Camera系列(二&#xff0…...

从DexMV、VideoDex、MimicPlay到SeeDo:从人类视频中学习:机器人的主流训练方法之一

前言 在此文《UMI——斯坦福刷盘机器人:从手持夹持器到动作预测Diffusion Policy(含代码解读)》的1.1节开头有提到 机器人收集训练数据一般有多种方式,比如来自人类视频的视觉演示 有的工作致力于从视频数据——例如YouTube视频中进行策略学习 即最常见…...

如何在Docker中运行Squid

测试环境 VMware Rocky Linux 9.4 实现步骤 过程:写一个Dockerfile构建Squid镜像; 再写一个启动脚本start_squid.sh,在启动脚本中配置并运行Squid。 编写Dockerfile 以rockylinux9.3做基础镜像,通过yum安装Squid, 拷贝squid.conf FROM …...

Ubuntu22.04 加入AD域

Ubuntu22.04 加入AD域 要在Ubuntu 22.04上加入Active Directory (AD) 域,你可以使用realmd和sssd服务。以下是加入AD域的步骤和示例配置: 更新系统软件包列表: sudo apt update 下载安装必要的软件包: sudo apt install realm…...

Docker 构建 Miniconda3 Python 运行环境实战指南

Docker 构建 Miniconda3 Python 运行环境实战指南 文章目录 Docker 构建 Miniconda3 Python 运行环境实战指南一 准备 environment.yml二 获取项目 pip 信息三 Dockerfile 编写四 构建多平台镜像1 准备组件2 构建镜像3 导出镜像4 导入镜像 五 注意事项 本文详细介绍了如何通过 …...

029 elasticsearch文档管理(ElasticsearchRepository、ElasticsearchRestTemplate)

文章目录 BlogRepository.javaBlogRepositoryTest.javaBulkTest.java 文档的管理 ElasticSearchRepository接口 使用方法: 创建一个接口,继承于ElasticSearchRepository,指定使用的Entity类及对应主键数据类型 Springboot自动扫描接口并创建代…...

【Flutter】Dart:Isolate

在 Dart 和 Flutter 中,所有的代码默认都运行在单一的线程(即主线程)上,这个线程也叫做 UI 线程。当进行耗时操作(如复杂计算或网络请求)时,如果不使用多线程处理,主线程会被阻塞&am…...

​微信小程序 页面间传递数据

在小程序中,给页面传递参数通常有以下几种方法: 通过URL传递参数: 在小程序中,可以在页面的路径后面添加参数,然后在页面的 onLoad 函数中获取这些参数。 // 在app.json中配置页面路径 "pages": [{"pat…...

前端_005_Nodejs

文章目录 npm包管理器cjs和mjsYarn包管理器 1.Node.js 是js的一个运行环境,从nodejs诞生后js代码不局限于只在浏览器中执行,此外还能再nodejs里写服务端,用js可以前后端全栈开发 2.Node.js不跟浏览器一样默认含有document,window对象&#xf…...

SpringCache缓存介绍

1.为什么需要缓存 ​ 前台请求,后台先从缓存中取数据,取到直接返回结果,取不到时从数据库中取,数据库取到更新缓存,并返回结果,数据库也没取到,那直接返回空结果: 使用缓存是一个很…...

python实战(一)——iris鸢尾花数据集分类

一、任务背景 本文是python实战系列专栏的第一篇文章,我们将从分类开始由浅入深逐步学习如何使用python完成常规的机器学习/深度学习任务。iris数据集是经典的机器学习入门数据集,许多分类任务教程都会以这个数据集作为示例,它的数据量是150条…...

k8s-对命名空间资源配额

对k8s命名空间限制的方法有很多种,今天来演示一下很常用的一种 用的k8s对象就是ResourceQuota 一:创建命名空间 kubectl create ns test #namespace命名空间可以简写成ns 二: 对命名空间进行限制 创建resourcequota vim resourcequ…...

Failed to connect to github.com port 443

git push无法连接443端口 **问题1****方法一:取消代理设置**git命令 其他解决方案1. **设置 Git 使用 HTTP 而不是 HTTPS**2. **检查证书**3. **配置 Git 忽略 SSL 验证(不推荐)**4. **检查代理设置** 问题1 Failed to connect to github.com…...

【设计模式系列】简单工厂模式

一、什么是简单工厂模式 简单工厂模式(Simple Factory Pattern)是一种设计模式,其中包含一个工厂类,根据传入的参数不同,返回不同类的实例。这个工厂类封装了对象的创建逻辑,使得客户端代码可以从直接创建…...

给定一个正整数n随机生成n个字节即生成2n个十六进制数将其组成字符串返回secrets.token_hex(n)

【小白从小学Python、C、Java】 【考研初试复试毕业设计】 【Python基础AI数据分析】 给定一个正整数n 随机生成n个字节 即生成2n个十六进制数 将其组成字符串返回 secrets.token_hex(n) [太阳]选择题 根据题目代码,执行的结果错误的是? import secrets …...

Ubuntu系统下交叉编译openssl

一、参考资料 OpenSSL&&libcurl库的交叉编译 - hesetone - 博客园 二、准备工作 1. 编译环境 宿主机:Ubuntu 20.04.6 LTSHost:ARM32位交叉编译器:arm-linux-gnueabihf-gcc-11.1.0 2. 设置交叉编译工具链 在交叉编译之前&#x…...

数据库分批入库

今天在工作中,遇到一个问题,就是分批查询的时候,由于批次过大导致出现了一些问题,一下是问题描述和解决方案: 示例: // 假设已有数据列表 dataList 和 PreparedStatement pstmt int batchSize 1000; // …...

深度学习水论文:mamba+图像增强

🧀当前视觉领域对高效长序列建模需求激增,对Mamba图像增强这方向的研究自然也逐渐火热。原因在于其高效长程建模,以及动态计算优势,在图像质量提升和细节恢复方面有难以替代的作用。 🧀因此短时间内,就有不…...

莫兰迪高级灰总结计划简约商务通用PPT模版

莫兰迪高级灰总结计划简约商务通用PPT模版,莫兰迪调色板清新简约工作汇报PPT模版,莫兰迪时尚风极简设计PPT模版,大学生毕业论文答辩PPT模版,莫兰迪配色总结计划简约商务通用PPT模版,莫兰迪商务汇报PPT模版,…...

站群服务器的应用场景都有哪些?

站群服务器主要是为了多个网站的托管和管理所设计的,可以通过集中管理和高效资源的分配,来支持多个独立的网站同时运行,让每一个网站都可以分配到独立的IP地址,避免出现IP关联的风险,用户还可以通过控制面板进行管理功…...

jmeter聚合报告中参数详解

sample、average、min、max、90%line、95%line,99%line、Error错误率、吞吐量Thoughput、KB/sec每秒传输的数据量 sample(样本数) 表示测试中发送的请求数量,即测试执行了多少次请求。 单位,以个或者次数表示。 示例:…...

LOOI机器人的技术实现解析:从手势识别到边缘检测

LOOI机器人作为一款创新的AI硬件产品,通过将智能手机转变为具有情感交互能力的桌面机器人,展示了前沿AI技术与传统硬件设计的完美结合。作为AI与玩具领域的专家,我将全面解析LOOI的技术实现架构,特别是其手势识别、物体识别和环境…...

ubuntu22.04 安装docker 和docker-compose

首先你要确保没有docker环境或者使用命令删掉docker sudo apt-get remove docker docker-engine docker.io containerd runc安装docker 更新软件环境 sudo apt update sudo apt upgrade下载docker依赖和GPG 密钥 # 依赖 apt-get install ca-certificates curl gnupg lsb-rel…...

门静脉高压——表现

一、门静脉高压表现 00:01 1. 门静脉构成 00:13 组成结构:由肠系膜上静脉和脾静脉汇合构成,是肝脏血液供应的主要来源。淤血后果:门静脉淤血会同时导致脾静脉和肠系膜上静脉淤血,引发后续系列症状。 2. 脾大和脾功能亢进 00:46 …...

【51单片机】4. 模块化编程与LCD1602Debug

1. 什么是模块化编程 传统编程会将所有函数放在main.c中,如果使用的模块多,一个文件内会有很多代码,不利于组织和管理 模块化编程则是将各个模块的代码放在不同的.c文件里,在.h文件里提供外部可调用函数声明,其他.c文…...