基于 Flink 的车辆超速监测与数据存储的小实战
基于 Flink 的车辆超速监测与数据存储的小实战
一、实战背景与目标
在智能交通管理领域,实时监控车辆行驶速度并精准识别超速行为对于保障道路交通安全和维护交通秩序具有至关重要的意义。本项目旨在构建一个高效的数据处理系统,能够从 Kafka 的 topic-car
主题中读取卡口车辆数据,依据卡口对应的限速信息,精确判断车辆是否超速(当车速超过卡口限速的 1.2 倍时认定为超速),并将超速车辆的详细信息实时写入 MySQL 的 t_speeding_info
表中,以便后续交通管理部门进行统计分析与违规处理。
二、技术选型与环境搭建
- 技术选型
- Apache Flink:作为核心的分布式流处理框架,具备强大的实时数据处理能力,能够高效地处理来自 Kafka 的海量卡口数据,进行复杂的转换和分析操作。
- Apache Kafka:作为高性能的分布式消息队列,负责稳定地接收和传输卡口数据,确保数据的可靠性和高可用性,实现数据的解耦与缓冲。
- MySQL:用于存储监控设备信息以及超速车辆数据,提供持久化的数据存储服务,方便数据的管理与查询。
- FastJSON:一款快速的 JSON 处理库,用于在 Java 程序中便捷地解析和序列化 JSON 格式的卡口数据。
- 环境搭建
- 首先启动 Hadoop 相关服务:执行
start-dfs.sh
启动分布式文件系统。 - 启动 ZooKeeper 服务:
zk.sh start
,为 Kafka 提供分布式协调服务。 - 启动 Kafka 服务:
kf.sh start
,确保消息队列正常运行。 - 启动 Flink 集群:
start-cluster.sh
,创建 Flink 执行环境。 - 启动 Flink 的历史服务器:
historyserver.sh start
,方便查看作业执行历史信息。 - 创建用于接收卡口数据的 Kafka 主题
topic-car
:kafka-topics.sh --bootstrap-server bigdata01:9092 --create --partitions 1 --replication-factor 3 --topic topic-car
,其中bigdata01
为 Kafka 服务器地址,--partitions 1
表示主题分区数为 1,--replication-factor 3
表示每个分区的副本数为 3。
- 首先启动 Hadoop 相关服务:执行
三、数据格式与数据库表结构
- Kafka 卡口数据格式
action_time
:long
类型,表示摄像头拍摄时间戳,精确到秒,用于记录车辆通过卡口的具体时间。monitor_id
:string
类型,代表卡口号,是识别车辆通过哪个卡口的关键标识。camera_id
:string
类型,摄像头编号,由于一个卡口可能配备多个摄像头,此编号用于区分不同摄像头拍摄的数据。car
:string
类型,车牌号码,用于唯一标识车辆。speed
:double
类型,车辆通过卡口时的速度,是判断车辆是否超速的核心数据。road_id
:string
类型,道路 ID,代表城市中每条道路的唯一编号,有助于关联道路相关信息。area_id
:string
类型,区域 ID,标识车辆所在的城市行政区域,方便进行区域交通数据统计分析。- 示例数据:
{"action_time":1682219447,"monitor_id":"0001","camera_id":"1","car":"豫A12345","speed":34.5,"road_id":"01","area_id":"20"}
- MySQL 表结构
t_speeding_info
表:id
:int(11)
类型,自增长主键,用于唯一标识每条超速记录。car
:varchar(255)
类型,存储车辆的车牌号码。monitor_id
:varchar(255)
类型,记录车辆超速时经过的卡口号。road_id
:varchar(255)
类型,对应的道路 ID。real_speed
:double
类型,车辆实际行驶速度。limit_speed
:int(11)
类型,该卡口的限速值。action_time
:bigint(20)
类型,车辆超速的时间戳。
t_monitor_info
表:monitor_id
:varchar(255)
类型,主键,卡口的唯一标识。road_id
:varchar(255)
类型,卡口所在道路的 ID。speed_limit
:int(11)
类型,该卡口的限速信息。area_id
:varchar(255)
类型,卡口所在的区域 ID。
四、代码实现详解
以下是使用 Java 结合 Flink 实现的核心代码逻辑:
import com.alibaba.fastjson.JSON;
import org.apache.flink.api.common.RuntimeExecutionMode;
import org.apache.flink.api.common.functions.FilterFunction;
import org.apache.flink.api.common.serialization.SimpleStringSchema;
import org.apache.flink.connector.jdbc.JdbcConnectionOptions;
import org.apache.flink.connector.jdbc.JdbcExecutionOptions;
import org.apache.flink.connector.jdbc.JdbcSink;
import org.apache.flink.connector.jdbc.JdbcStatementBuilder;
import org.apache.flink.streaming.api.datastream.DataStreamSource;
import org.apache.flink.streaming.api.datastream.SingleOutputStreamOperator;
import org.apache.flink.streaming.api.environment.StreamExecutionEnvironment;
import org.apache.flink.streaming.api.functions.ProcessFunction;
import org.apache.flink.streaming.connectors.kafka.FlinkKafkaConsumer;
import org.apache.flink.util.Collector;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.Statement;
import java.util.ArrayList;
import java.util.Objects;
import java.util.Properties;/*** @基本功能: 从 Kafka 读取卡口数据,判断超速并写入 MySQL 超速表* @program:FlinkProject* @author: BJ* @create:2024-11-23 09:09:06**/
public class CarSpeedDemo {public static void main(String[] args) throws Exception {// 1. env - 准备环境StreamExecutionEnvironment env = StreamExecutionEnvironment.getExecutionEnvironment();env.setRuntimeMode(RuntimeExecutionMode.AUTOMATIC);// 2. source - 加载数据// 加载 MySQL 中的监控设备信息ArrayList<MonitorInfo> monitorInfos = loadMonitorInfoFromMySQL();// 加载 Kafka 中的车辆信息数据Properties properties = new Properties();properties.setProperty("bootstrap.servers", "bigdata01:9092");properties.setProperty("group.id", "fD1");FlinkKafkaConsumer<String> kafkaSource = new FlinkKafkaConsumer<String>("topic-car", new SimpleStringSchema(), properties);DataStreamSource<String> dataStreamSource = env.addSource(kafkaSource);// 3. transformation - 数据处理转换SingleOutputStreamOperator<CarInfo> filter = dataStreamSource.process(new ProcessFunction<String, CarInfo>() {@Overridepublic void processElement(String msg, ProcessFunction<String, CarInfo>.Context context, Collector<CarInfo> collector) throws Exception {CarInfo carInfo = JSON.parseObject(msg, CarInfo.class);System.out.println(carInfo);// 根据监控设备信息设置车辆的限速for (MonitorInfo monitorInfo : monitorInfos) {if (Objects.equals(monitorInfo.getMonitor_id(), carInfo.getMonitorId())) {carInfo.setLimitSpeed(monitorInfo.getSpeed_limit());}}collector.collect(carInfo);System.out.println(carInfo);}}).filter(new FilterFunction<CarInfo>() {@Overridepublic boolean filter(CarInfo carInfo) throws Exception {// 判断车辆是否超速(速度超过限速的 1.2 倍)return carInfo.getSpeed() > carInfo.getLimitSpeed() * 1.2;}});filter.print();// 4. sink - 数据输出JdbcConnectionOptions jdbcConnectionOptions = new JdbcConnectionOptions.JdbcConnectionOptionsBuilder().withUrl("jdbc:mysql://localhost:3306/zuoye").withDriverName("com.mysql.jdbc.Driver").withUsername("root").withPassword("123456").build();filter.addSink(JdbcSink.sink("insert into t_speeding_info values(null,?,?,?,?,?,?)",new JdbcStatementBuilder<CarInfo>() {@Overridepublic void accept(PreparedStatement preparedStatement, CarInfo student) throws SQLException {preparedStatement.setString(1, student.getCar());preparedStatement.setString(2, student.getMonitorId());preparedStatement.setString(3, student.getRoadId());preparedStatement.setDouble(4, student.getSpeed());preparedStatement.setDouble(5, student.getLimitSpeed());preparedStatement.setLong(6, student.getActionTime());}}, JdbcExecutionOptions.builder().withBatchSize(1).build(), jdbcConnectionOptions));// 5. execute - 执行env.execute();}// 从 MySQL 加载监控设备信息的方法private static ArrayList<MonitorInfo> loadMonitorInfoFromMySQL() throws Exception {ArrayList<MonitorInfo> monitorInfos = new ArrayList<>();Connection connection = DriverManager.getConnection("jdbc:mysql://localhost:3306/zuoye", "root", "123456");Statement statement = connection.createStatement();ResultSet resultSet = statement.executeQuery("select monitor_id, road_id, speed_limit,area_id FROM t_monitor_info");while (resultSet.next()) {String monitor_id = resultSet.getString("monitor_id");String road_id = resultSet.getString("road_id");Integer speed_limit = resultSet.getInt("speed_limit");String area_id = resultSet.getString("area_id");MonitorInfo monitorInfo = new MonitorInfo(monitor_id, road_id, speed_limit.doubleValue(), area_id);System.out.println(monitorInfo);monitorInfos.add(monitorInfo);}statement.close();connection.close();return monitorInfos;}
}// 车辆信息类
import lombok.AllArgsConstructor;
import lombok.Data;
import lombok.NoArgsConstructor;import java.io.Serializable;@Data
@NoArgsConstructor
@AllArgsConstructor
public class CarInfo implements Serializable {private long actionTime;private String monitorId;private String cameraId;private String car;private double speed;private String roadId;private String areaId;// 用于存储车辆对应的限速信息private double limitSpeed;
}// 监控设备信息类
import lombok.AllArgsConstructor;
import lombok.Data;
import lombok.NoArgsConstructor;import java.io.Serializable;@Data
@NoArgsConstructor
@AllArgsConstructor
public class MonitorInfo implements Serializable {private String monitor_id;private String road_id;private Double speed_limit;private String area_id;
}
- 环境配置与数据加载:
- 首先创建 Flink 的流执行环境
StreamExecutionEnvironment
,并设置运行模式为自动模式,让 Flink 根据数据特性自动选择合适的执行模式。 - 从 MySQL 的
t_monitor_info
表中加载监控设备信息,通过 JDBC 连接数据库,执行查询语句获取监控设备的相关数据,如卡口号、道路 ID、限速信息和区域 ID,将这些信息封装成MonitorInfo
对象并存储在ArrayList
中,以便后续在数据处理过程中为车辆信息匹配对应的限速。 - 配置 Kafka 消费者属性,创建
FlinkKafkaConsumer
连接到topic-car
主题,获取卡口车辆数据的流dataStreamSource
。
- 首先创建 Flink 的流执行环境
- 数据处理与转换:
- 使用
process
函数对从 Kafka 读取的车辆信息数据进行处理。在processElement
方法中,先使用FastJSON
将 JSON 格式的车辆数据字符串转换为CarInfo
对象。然后遍历之前加载的监控设备信息列表,根据卡口号匹配车辆对应的监控设备,将限速信息设置到CarInfo
对象的limitSpeed
属性中。最后将处理后的CarInfo
对象收集输出。 - 通过自定义的
FilterFunction
对车辆信息进行过滤,只保留速度超过限速 1.2 倍的超速车辆信息。
- 使用
- 数据输出:
- 配置 JDBC 连接选项,构建
JdbcSink
,将超速车辆信息插入到 MySQL 的t_speeding_info
表中。在JdbcStatementBuilder
中指定了插入语句的参数设置,将车辆的相关信息逐个设置到PreparedStatement
中,准备插入数据库。
- 配置 JDBC 连接选项,构建
- 任务执行:
- 最后启动 Flink 任务执行,整个系统开始运行,从数据加载、处理到输出的流程将持续进行,实时监测和处理车辆超速信息。
五、总结与展望
本项目成功地利用 Flink、Kafka 和 MySQL 构建了一个车辆超速监测与数据存储系统,实现了从 Kafka 读取卡口数据、判断车辆超速并将超速信息写入 MySQL 的完整流程。通过实时处理卡口数据,交通管理部门能够及时获取超速车辆信息,有助于加强交通监管力度,提高道路交通安全水平。
然而,在实际应用场景中,还可以对该系统进行进一步的优化与扩展。例如,可以增加数据质量监控模块,确保从 Kafka 读取的数据准确性和完整性;优化 Flink 任务的性能,根据集群资源和数据流量调整并行度等参数;还可以考虑将超速数据进行可视化展示,以便更直观地分析交通超速情况的分布与趋势。未来,随着智能交通技术的不断发展,本系统也可以与其他交通管理系统进行集成,如车辆轨迹分析系统、交通流量预测系统等,为构建更加智能、高效的交通管理平台奠定坚实的基础。
希望通过本文的详细介绍,能够帮助读者深入理解基于 Flink 的实时数据处理在智能交通领域的应用,为相关领域的开发与研究提供有益的参考。
相关文章:
基于 Flink 的车辆超速监测与数据存储的小实战
基于 Flink 的车辆超速监测与数据存储的小实战 一、实战背景与目标 在智能交通管理领域,实时监控车辆行驶速度并精准识别超速行为对于保障道路交通安全和维护交通秩序具有至关重要的意义。本项目旨在构建一个高效的数据处理系统,能够从 Kafka 的 topic…...
Shell 脚本基础(7):重定向详解
内容预览 ≧∀≦ゞ Shell 脚本基础(7):重定向详解声明1. 重定向基础概念1.1 输出重定向(> 和 >>)覆盖写入(>)追加写入(>>)输出到终端和文件࿰…...
04. 流程控制
一、流程控制 流程控制就是用来控制程序运行中各语句执行顺序的语句。基本的流程结构为:顺序结构,分支结构(或称选择结构),循环结构。 顺序结构:程序自上到下执行,中间没有任何判断和跳转&…...
基于卡尔曼滤波器的 PID 控制
基于卡尔曼滤波器的PID控制算法结合了经典控制理论和现代信号处理技术。卡尔曼滤波器(Kalman Filter, KF)可以对噪声数据进行平滑处理,从而改善PID控制器的性能,特别是在处理具有噪声和不确定性的系统时。以下是详细的设计过程&am…...
基于信创环境的信息化系统运行监控及运维需求及策略
随着信息技术的快速发展和国家对信息安全的日益重视,信创环境(信息技术应用创新环境)的建设已成为行业发展的重要趋势。本指南旨在为运维团队在基于信创环境的系统建设及运维过程中提供参考,确保项目顺利实施并满足各项技术指标和…...
leetCode 283.移动零
题目 给定一个数组 nums,编写一个函数将所有 0 移动到数组的末尾,同时保持非零元素的相对顺序。 请注意 ,必须在不复制数组的情况下原地对数组进行操作。示例 1: 输入: nums [0,1,0,3,12] 输出: [1,3,12,0,0]示例 2: 输入: nums [0] 输出:…...
Kali Linux语言设置成中文
要将Kali Linux设置成中国地区(简体中文),可以按照以下步骤进行操作: 一、更新软件包列表 打开Kali Linux的终端。 输入以下命令来更新软件包列表: sudo apt-get update 二、安装语言包(如果有就不用安装了…...
c#窗体列表框(combobox)应用——省市区列表选择实例
效果如下: designer.cs代码如下: using System.Collections.Generic;namespace 删除 {public partial class 省市区选择{private Dictionary<string, List<string>> provinceCityDictionary;private Dictionary<string,List<string&…...
kali中信息收集的一些常用工具
这里只是代表个人所见,所以肯定会有其他的没提到,希望大家体谅 前言 信息收集分为主动和被动的 主动就是通过自己的机器去和对方比如通信后获得的数据 被动是指不是在自己这里获取的,可以是第三方平台获取到的,与目标没有通信 …...
【CS61A 2024秋】Python入门课,全过程记录P2(Week3开始,更新中2024/11/24)
文章目录 关于基本介绍👋Week 3Mon Environments阅读材料Lab 02: Higher-Order Functions, Lambda ExpressionsQ1: WWPD: The Truth Will PrevailQ2: WWPD: Higher-Order FunctionsQ3: WWPD: Lambda 关于 个人博客,里面偶尔更新,最近比较忙。…...
python学习笔记(8)算法(1)数组
一、数组 数组是存储于一个连续空间且具有相同数据类型的元素集合。若将有限个类型相同的变量的集合命名,那么这个名称为数组名。组成数组的各个变量称为数组的分量,也称为数组的元素,有时也称为下标变量。用于区分数组的各个元素的数字编号…...
C++(进阶) 第1章 继承
C(进阶) 第1章 继承 文章目录 前言一、继承1.什么是继承2.继承的使用 二、继承方式1.private成员变量的(3种继承方式)继承2. private继承方式3.继承基类成员访问⽅式的变化 三、基类和派生类间的转换1.切片 四、 继承中的作⽤域1.隐藏规则&am…...
【Linux | 计网】TCP协议详解:从定义到连接管理机制
目录 1.TCP协议的定义: 2.TCP 协议段格式 3.TCP两种通信方式 4.确认应答(ACK)机制 解决“后发先至”问题 5.超时重传机制 那么, 超时的时间如何确定? 6.连接管理机制: 6.1.三次握手: 为什么需要3次握手,一次两次不行吗…...
SElinux学习
一、SElinux简介 SELinux是Security-Enhanced Linux的缩写,意思是安全强化的linux,传统的访问控制在我们开启权限后,系统进程可以直接访问.当我们对权限设置不严谨时,这种访问方式就是系统的安全漏洞。 所以在开启SElinux后 会…...
Spark核心组件解析:Executor、RDD与缓存优化
Spark核心组件解析:Executor、RDD与缓存优化 Spark Executor Executor 是 Spark 中用于执行任务(task)的执行单元,运行在 worker 上,但并不等同于 worker。实际上,Executor 是一组计算资源(如…...
阿里云cdn配置记录和nodejs手动安装
cdn 登录阿里云 域名解析权限 开启cdn,接引导流程, 源可以设置 域名或者ip等 配置好域名解析 上传https证书 图片不显示,后端开发需要配置 回源配置的回源协议 ,配置跟随客服端【如果浏览器多次重定向错误,客服或者改…...
【实战】基于urllib和BeautifulSoup爬取jsp网站的数据
文章目录 前言目标网站分析目标网页爬取数据解析导出数据其他问题处理分页检索及多关键字搜索去重cookie问题工具封装经验总结前言 网络数据爬取大致分为两类: 静态爬取:该种方式针对那种架构比较老的网站,使用模版方式,通过浏览器F12只能找到静态页面,找不到返回json数…...
cpp-httplib 框架
cpp-httplib 概述 主要特点 单文件库:cpp-httplib 是一个单文件头文件库,易于集成到现有项目中。你只需将 httplib.h 包含到项目中即可开始使用支持 HTTP 客户端和服务器:它不仅支持作为 HTTP 客户端发送请求,也支持构建 HTTP 服…...
GEE 案例——TVDI(Temperature Vegetation Dryness Index)指数
目录 简介 方法论 代码解释 函数 案例代码 单景影像的TVDI 影像集合批量计算TVDI 引用 结果 简介 本文中代码包含两个可用于计算 TVDI 的主要函数。其中一个函数用于仅根据一幅 NDVI 和一幅 LST 图像生成 TVDI(singleTVDI),另一个函数用于为多幅 NDVI 和多幅 LST …...
Java语言程序设计 选填题知识点总结
第一章 javac.exe是JDK提供的编译器public static void main (String args[])是Java应用程序主类中正确的main方法Java源文件是由若干个书写形式互相独立的类组成的Java语言的名字是印度尼西亚一个盛产咖啡的岛名Java源文件中可以有一个或多个类Java源文件的扩展名是.java如果…...
基于Springboot+Vue社区养老服务管理系统(源码+lw+讲解部署+PPT)
前言 详细视频演示 论文参考 系统介绍 系统概述 核心功能 用户角色与功能 具体实现截图 1. 服务信息查看功能 主要代码实现 截图: 2. 服务申请功能 主要代码实现 截图: 3. 公告信息查看功能 主要代码实现 截图: 4. 服务信息…...
Linux基本指令的使用
当然可以!以下是一些常用的Linux指令及其示例: 1. ls 列出目录内容。 ls 显示当前目录下的文件和文件夹。 ls -l 以详细格式列出文件和文件夹的信息(如权限、拥有者、大小等)。 2. cd 改变当前目录。 cd /path/to/dire…...
Momenta C++面试题及参考答案
vtable 的创建时机 在 C 中,vtable(虚函数表)是在编译阶段创建的。当一个类包含虚函数时,编译器会为这个类生成一个 vtable。vtable 本质上是一个函数指针数组,其中每个元素指向一个虚函数的实现。这个表的布局是由编译…...
AI 在软件开发流程中的优势、挑战及应对策略
AI 在软件开发流程中的优势、挑战及应对策略 随着人工智能技术的飞速发展,AI大模型正在逐步渗透到软件开发的各个环节,从代码自动生成到智能测试,AI的应用正在重塑传统的软件开发流程。本篇文章将分析AI在软件开发流程中带来的优势࿰…...
langchain runnable
LangChain 文档详细解析 LangChain 是一个用于构建与语言模型(如GPT-4)交互的框架。本文档介绍了LangChain v0.1版本中的Runnable接口及其相关功能。 目录 Runnable接口输入和输出模式使用示例异步方法事件流并行处理 1. Runnable接口 为了简化自定义…...
nginx配置不缓存资源
方法1 location / {index index.html index.htm;add_header Cache-Control no-cache,no-store;try_files $uri $uri/ /index.html;#include mime.types;if ($request_filename ~* .*\.(htm|html)$) {add_header Cache-Control "private, no-store, no-cache, must-revali…...
Linux系统程序设计--4.进程
程序与进程 内核中的进程结构 task_struct(进程表项和进程控制块) 位于/usr/src/linux-headers-4.15.0-213-generic/include/linux/sched.h C程序启动过程 进程终止方式 进程终止函数 atexit 小案例 #include<stdio.h> #include<string.h> #include<stdlib…...
springboot/ssm网购平台管理系统Java在线购物商城管理平台web电商源码
springboot/ssm网购平台管理系统Java在线购物商城管理平台web电商源码 基于springboot(可改ssm)vue项目 开发语言:Java 框架:springboot/可改ssm vue JDK版本:JDK1.8(或11) 服务器:tomcat 数据库&…...
2024年Android面试总结
2024年Android面试总结 1.动画类型有哪些?插值器原理? 2.StringBuffer和StringBuilder区别? 3.jvm内存模型? 4.线程池7大核心参数及原理? 5.Android多进程通信方式有哪些?各自的优缺点? 6…...
UE5 slate BlankProgram独立程序系列
源码版Engine\Source\Programs\中copy BlankProgram文件夹,重命名为ASlateLearning,修改所有文件命名及内部名称。 ASlateLearning.Target.cs // Copyright Epic Games, Inc. All Rights Reserved.using UnrealBuildTool; using System.Collections.Ge…...
小米PC电脑手机互联互通,小米妙享,小米电脑管家,老款小米笔记本怎么使用,其他品牌笔记本怎么使用,一分钟教会你
说在前面 之前我们体验过妙享中心,里面就有互联互通的全部能力,现在有了小米电脑管家,老款的笔记本竟然用不了,也可以理解,毕竟老款笔记本做系统研发的时候没有预留适配的文件补丁,至于其他品牌的winPC小米…...
家庭智慧工程师:如何通过科技提升家居生活质量
在今天的数字化时代,家居生活已经不再只是简单的“住”的地方。随着物联网(IoT)、人工智能(AI)以及自动化技术的快速发展,越来越多的家庭开始拥抱智慧家居技术,将他们的家变得更加智能化、便捷和…...
云计算-华为HCIA-学习笔记
笔者今年7月底考取了华为云计算方向的HCIE认证,回顾从IA到IE的学习和项目实战,想整合和分享自己的学习历程,欢迎志同道合的朋友们一起讨论! 第二章:服务器基础 服务器是什么? 服务器本质上就是个性能超强的…...
webgl threejs 云渲染(服务器渲染、后端渲染)解决方案
云渲染和流式传输共享三维模型场景 1、本地无需高端GPU设备即可提供三维项目渲染 云渲染和云流化媒体都可以让3D模型共享变得简单便捷。配备强大GPU的远程服务器早就可以处理密集的处理工作,而专有应用程序,用户也可以从任何个人设备查看全保真模型并与…...
【中间件】Redis
一、什么是Redis Redis是一个开源(BSD许可),内存存储的数据结构服务器,可用作数据库,高速缓存和消息队列代理。它支持字符串、哈希表、列表、集合、有序集合,位图,hyperloglogs等数据类型。内置…...
请结合给定资料中的具体事例,谈谈你对“海洋的污染将毁灭鱼儿的家园,但让人类不寒而栗的毁灭绝非仅此而已!”这句话的理解。(10分)
题目 【2010年国考省级以上(含副省级)申论真题】2.请结合给定资料中的具体事例,谈谈你对“海洋的污染将毁灭鱼儿的家园,但让人类不寒而栗的毁灭绝非仅此而已!”这句话的理解。(10分)…...
Java SE 与 Java EE:基础与进阶的探索之旅
在编程世界中,Java语言以其跨平台、面向对象、丰富的类库等特点,成为了众多开发者和企业的首选编程语言。而Java SE与Java EE,作为Java平台的两个重要组成部分,各自承载着不同的使命,同时又紧密相连,共同构…...
PH热榜 | 2024-11-24
DevNow 是一个精简的开源技术博客项目模版,支持 Vercel 一键部署,支持评论、搜索等功能,欢迎大家体验。 在线预览 1. AutoFlow Studio 标语:借助简化的AI质检,更快发布产品,更聪明地进行测试。 介绍&…...
LLM 系列学习教程
LLM101 检查 Tokenizer 词表大小与 LLM 的 Embedding 和 LM_head 输入大小是否匹配对 SBert 进行训练、预测、评估使其进行相似度计算对 BERT 进行训练、预测、评估使其进行文本分类使用 CLIP 模型进行文本图像匹配对 JoinBERT 进行训练、预测使其进行对话意图和槽位联合识别对…...
基于yolov8、yolov5的茶叶等级检测识别系统(含UI界面、训练好的模型、Python代码、数据集)
摘要:茶叶等级检测在茶叶生产、质量控制和市场销售中起着至关重要的作用,不仅能帮助相关部门实时监测茶叶质量,还为智能化检测系统提供了可靠的数据支撑。本文介绍了一款基于YOLOv8、YOLOv5等深度学习框架的茶叶等级检测模型,该模…...
Excel求和如何过滤错误值
一、问题的提出 平时,我们在使用Excel时,最常用的功能就是求和了,一说到求和你可能想到用sum函数,但是如果sum的求和区域有#value #Div等错误值怎么办?如下图,记算C列中工资的总和。 直接用肯定会报错&…...
头文件包含
大家好,今天我们来聊聊头文件包含这方面的知识,并且在这里提出几个问题,头文件多次包含有什么影响吗?“”和〈〉这两种方式都能包含标准头文件吗? 一.文件包含 #include指令可以使另外一个文件被编译。就像它实际出现…...
37_U-Net网络详解
1.U-Net 网络概述 U-Net 是一种深度学习模型,广泛用于图像的语义分割任务。U-Net 网络的结构特别适合医学影像分割,尤其在少量训练数据的情况下表现优异。该网络由一个编码器-解码器架构组成,具有对称的“U”形结构,因此得名为 U…...
fastapi入门
好的,我将为您生成一个更详细、易于理解的 FastAPI 入门学习文档,特别是对复杂概念(如依赖注入)进行深入解释,帮助您在没有太多基础的情况下也能顺利学习和掌握 FastAPI。 FastAPI 入门学习文档 目录 简介环境搭建 2…...
RabbitMQ 之 死信队列
一、死信的概念 先从概念解释上搞清楚这个定义,死信,顾名思义就是无法被消费的消息,字面意思可以这样理 解,一般来说,producer 将消息投递到 broker 或者直接到 queue 里了,consumer 从 queue 取出消息进行…...
Android-如何实现Apng动画播放
01 Apng是什么 Apng(Animated Portable Network Graphics)顾名思义是基于 PNG 格式扩展的一种动画格式,增加了对动画图像的支持,同时加入了 24 位图像和8位 Alpha 透明度的支持,并且向下兼容 PNG。 Google封面图 02 A…...
微服务系统架构图
微服务架构是一种将单一应用程序开发为一组小型服务的架构风格。每个服务都在自己的进程中运行,它们之间采用轻量级的通信机制(如 HTTP/REST 或消息队列)进行相互协作。以下是关于微服务系统架构的简要介绍:一、核心特点独立部署 …...
04 —— Webpack打包CSS代码
加载器css-loader :解析css代码 webpack 中文文档 | webpack中文文档 | webpack中文网 加载器style-loader:把解析后的css代码插入到DOM style-loader | webpack 中文文档 | webpack中文文档 | webpack中文网 准备css代码,放到src/login目…...
【数据结构专栏】二叉搜索树(Binary Search Tree)的剖析?
文章目录 🧨前言1、二叉搜索树的基本概念?2、二叉搜索树的节点结构组成?3、二叉搜索树的插入操作?4、二叉搜索树的删除操作?5、二叉搜索树的遍历? 6、二叉搜索树的性能分析? 🎉完整代…...
SSM全家桶 1.Maven
或许总要彻彻底底地绝望一次 才能重新再活一次 —— 24.11.20 maven在如今的idea中已经实现自动配置,不需要我们手动下载 一、Maven的简介和快速入门 Maven 是一款为 Java 项目构建管理、依赖管理的工具(软件),使用 Maven 可以自动化构建测试、打包和发…...