(C语言)超市管理系统(测试2版)(指针)(数据结构)(清屏操作)
目录
前言:
源代码:
product.h
product.c
fileio.h
fileio.c
main.c
代码解析:
一、程序结构概述
二、product.c 函数详解
1. 初始化商品列表 Init_products
2. 添加商品 add_product
3. 显示商品 display_products
4. 修改商品 mod_product
三、main.c 主函数详解
1. 主函数 main
2. 辅助函数 clear_screen
四、核心知识点总结
1. 动态内存管理
2. 结构体的使用
3. 输入输出安全
4. 文件操作
五、动手实践建议
前言:
当前这篇博客是测试版,教大家相关添加单个商品,显示所有商品,修改单个商品知识点;
看之前建议先看上篇博客:
(C语言)超市管理系统(测试版)(指针)(数据结构)(二进制文件读写)-CSDN博客
共6个文件(加上二进制文件);
源代码:
product.h
//product.h
#pragma once //防止头文件重复定义#define NAME_LEN 50 //商品名称最大容量//单个商品结构体
typedef struct {int id;//商品编号char name[NAME_LEN];//商品名字float price;//商品单价int stock;//商品库存
}Product;//商品列表表结构体
typedef struct {Product* Data;//指向单个商品数组的指针int count;//当前商品数量
}ProductList;// 函数原型
void Init_products(ProductList* list);//初始化商品列表结构体
void add_product(ProductList* list,Product* product);//添加单个商品
void display_products(ProductList* list);//显示所有商品
void mod_product(ProductList* list, Product* product);//修改单个商品
product.c
//product.c
#include "product.h"
#include <stdio.h>
#include <stdlib.h>
#include <string.h>//初始化商品列表结构体
void Init_products(ProductList* list) {list->Data = NULL;//指针置空,防止野指针list->count = 0;//商品数量归0
}//添加单个商品
void add_product(ProductList* list,Product* product) {//1.扩展空间Product* listnew_Data = realloc(list->Data, (list->count + 1) * sizeof(Product));if (listnew_Data==NULL) {printf("内存分配失败!\n");exit(EXIT_FAILURE);}list->count++;list->Data = listnew_Data;//依然用老数组表示描述//2.ID自动生成list->Data[list->count - 1].id = list->count;printf("商品ID:%d\n",list->count);//3.商品信息录入printf("请输入商品名称:");scanf("%49s", list->Data[list->count-1].name);printf("请输入单价:");scanf("%f", &list->Data[list->count-1].price);printf("请输入库存:");scanf("%d", &list->Data[list->count-1].stock);printf("添加成功!\n");
}//显示所有商品
void display_products(ProductList* list) {//1.判断列表是否为空if (list->count == 0) {printf("库存为空\n");return;}//2.打印表头printf("\n%5s %-20s %10s %6s\n", "ID", "名称", "单价", "库存");printf("--------------------------------------------\n");//3.打印商品信息for (int i = 0; i < list->count; i++) {printf("%5d %-20s %10.2f %5d\n",list->Data[i].id,list->Data[i].name,list->Data[i].price,list->Data[i].stock);}
}//修改单个商品
void mod_product(ProductList* list, Product* product) {//1.判断列表是否为空if (list->count == 0) {printf("库存为空\n");return;}//2.输入要修改的IDint id_0;printf("请输入要修改的ID:");scanf("%d", &id_0);//3.判断ID是否存在if (id_0 > list->count) {printf("ID不存在!\n");return;}//4.找要修改商品的IDint i=0;for (i; i < list->count; i++) {if (id_0 == list->Data[i].id) {break;}}//5.修改商品printf("\n%5s %-20s %10s %6s\n", "ID", "名称", "单价", "库存");printf("--------------------------------------------\n");printf("%5d %-20s %10.2f %5d\n",list->Data[i].id,list->Data[i].name,list->Data[i].price,list->Data[i].stock);printf("--------------------------------------------\n");printf("修改商品名称:");scanf("%49s", list->Data[i].name);printf("修改单价:");scanf("%f", &list->Data[i].price);printf("修改库存:");scanf("%d", &list->Data[i].stock);printf("修改成功!\n");
}
fileio.h
//fileio.h
#pragma once
#include "product.h"// 文件操作函数原型
void save_to_file(const char* filename, const ProductList* list);
void load_from_file(const char* filename, ProductList* list);
fileio.c
//fileio.c
//引用头文件
#include <stdio.h>
#include <stdlib.h>
#include "product.h"// 保存数据到文件(二进制写入)
void save_to_file(const char* filename, const ProductList* list) {//1.打开文件(二进制写入模式)FILE* fp = fopen(filename, "wb");// "wb":二进制写入模式,会清空原文件内容// 若文件不存在则创建新文件if (!fp) { // fp == NULL 表示打开失败perror("保存失败"); // 输出错误信息(包含具体原因,如权限不足)exit(EXIT_FAILURE); // 终止程序,EXIT_FAILURE 表示异常退出}//2.先写入商品数量(int 类型)fwrite(&list->count,sizeof(int),1,fp);// &list->count:取商品数量的内存地址// sizeof(int):每个元素的大小(4字节)// 1:写入1个元素// fp:文件指针//3.再写入所有商品数据(Product 结构体数组)fwrite(list->Data, sizeof(Product), list->count, fp);// list->Data:商品数组首地址// sizeof(Product):每个商品占用的字节数// list->count:要写入的商品数量//4.关闭文件fclose(fp);
}// 从文件加载数据(二进制读取)
void load_from_file(const char* filename, ProductList* list) {//1.初始化结构体(防御性编程)Init_products(&list);//初始化商品列表结构体//2.尝试打开文件(二进制读取模式)FILE* fp = fopen(filename, "rb");// "rb":二进制读取模式,文件不存在时返回 NULLif (!fp) {//文件打开失败处理return; // 保持 list 的初始状态(count=0, Data=NULL)}//3.读取商品数量(int 类型)fread(&list->count,sizeof(int),1,fp);// 从文件中读取4字节到 list->count//4.根据数量分配内存list->Data = malloc(list->count * sizeof(Product));// 计算总字节数 = 商品数量 × 单个商品大小//检查是否分配成功if (list->Data == NULL) { // list->Data == NULL 表示失败printf("内存分配失败\n");exit(EXIT_FAILURE); // 终止程序}//5.读取所有商品数据fread(list->Data, sizeof(Product), list->count, fp);// 将文件内容直接读入 Data 数组//6.关闭文件fclose(fp);
}
main.c
//mian.c#include <stdio.h>
#include <stdlib.h>
#include "product.h"
#include "fileio.h"#define FILENAME "products.dat"//宏定义文件名//清屏操作
void clear_screen() {//判断是否为Windows系统
#ifdef _WIN32system("cls");//其他系统
#elsesystem("clear");
#endif
}// 显示主菜单(用户界面)
void display_menu() {printf("\n超市管理系统\n");printf("1. 添加商品\n");printf("2. 显示所有商品\n");printf("3. 修改商品信息\n");printf("4. 删除商品\n");printf("5. 搜索商品\n");printf("6. 保存并退出\n");printf("请选择操作:");
}int main() {//1.创建结构体并初始化Product product;//创建单个商品结构体ProductList list;//创建商品列表结构体Init_products(&list);//初始化//2.读文件load_from_file(FILENAME, &list);//读文件//3.选择模块int choice;//选择选项while (1) {display_menu();//显示菜单scanf("%d", &choice);//输入选项switch (choice) {case 1:clear_screen();add_product(&list,&product);printf("--------------------------------------------\n");break;case 2:clear_screen();display_products(&list);printf("--------------------------------------------\n");break;case 3:clear_screen();mod_product(&list,&product);printf("--------------------------------------------\n");break;case 6:save_to_file(FILENAME, &list); // 保存数据free(list.Data); // 释放动态内存printf("系统已退出\n");return 0; // 正确退出default:printf("无效输入\n");}}
}
代码解析:
一、程序结构概述
整个程序分为三个核心模块:
数据管理模块 (
product.c
):处理商品的增删改查文件操作模块 (
fileio.c
):负责数据保存与加载主控模块 (
main.c
):协调程序流程和用户交互
二、product.c 函数详解
1. 初始化商品列表
Init_products
void Init_products(ProductList* list) {list->Data = NULL; // 指针置空,防止野指针list->count = 0; // 商品数量归0 }
功能:
初始化商品列表结构体,确保程序启动时处于干净状态。
实现步骤:
Data = NULL
:将动态数组指针置空,避免指向随机内存。
count = 0
:商品数量初始化为0。为什么这样写:
防御性编程:确保程序启动时没有残留数据。
动态内存安全:
Data
初始为NULL
,realloc
在首次调用时会自动分配内存。如何使用:
ProductList list; // 声明一个商品列表 Init_products(&list); // 初始化列表(必须调用)
2. 添加商品
add_product
void add_product(ProductList* list, Product* product) {// 1. 扩展内存Product* listnew_Data = realloc(list->Data, (list->count + 1) * sizeof(Product));if (listnew_Data == NULL) {printf("内存分配失败!\n");exit(EXIT_FAILURE);}list->count++;list->Data = listnew_Data;// 2. 自动生成IDlist->Data[list->count - 1].id = list->count;printf("商品ID:%d\n", list->count);// 3. 录入商品信息printf("请输入商品名称:");scanf("%49s", list->Data[list->count-1].name);printf("请输入单价:");scanf("%f", &list->Data[list->count-1].price);printf("请输入库存:");scanf("%d", &list->Data[list->count-1].stock);printf("添加成功!\n"); }
功能:
动态扩展内存,添加新商品并自动生成ID。
实现步骤:
内存扩展:使用
realloc
将数组大小增加1个商品位置。错误处理:检查内存是否分配成功,失败则终止程序。
生成ID:新商品ID = 当前商品总数 + 1(例如第一个商品ID=1)。
输入信息:依次输入名称、单价、库存。
为什么这样写:
动态内存管理:
realloc
自动处理内存扩展,无需手动复制数据。简单ID生成:直接使用
count
作为ID,但存在删除商品后ID不连续的问题(后续改进点)。如何使用:
ProductList list; Init_products(&list); add_product(&list, NULL); // 添加第一个商品
输入示例:
请输入商品名称:苹果 请输入单价:5.5 请输入库存:20
注意事项:
输入缓冲区问题:连续使用
scanf
可能导致残留换行符,需清空缓冲区(代码未处理)。名称输入限制:
%49s
防止溢出,但无法输入带空格的名称(如“红富士苹果”)。
3. 显示商品
display_products
void display_products(ProductList* list) {if (list->count == 0) {printf("库存为空\n");return;}printf("\n%5s %-20s %10s %6s\n", "ID", "名称", "单价", "库存");printf("--------------------------------------------\n");for (int i = 0; i < list->count; i++) {printf("%5d %-20s %10.2f %5d\n",list->Data[i].id,list->Data[i].name,list->Data[i].price,list->Data[i].stock);} }
功能:
以表格形式打印所有商品信息,处理空列表情况。
实现步骤:
空列表检查:直接返回提示信息。
打印表头:使用格式化字符串对齐标题。
遍历打印:循环输出每个商品的字段。
为什么这样写:
用户体验:清晰的表格布局提升可读性。
格式控制符:
%5d
:ID占5字符宽度,右对齐。
%-20s
:名称左对齐,占20字符。
%10.2f
:单价保留两位小数,总宽度10。如何使用:
display_products(&list); // 显示当前所有商品
输出示例:
ID 名称 单价 库存 --------------------------------------------1 苹果 5.50 202 香蕉 3.80 15
4. 修改商品
mod_product
void mod_product(ProductList* list, Product* product) {if (list->count == 0) {printf("库存为空\n");return;}int id_0;printf("请输入要修改的ID:");scanf("%d", &id_0);if (id_0 > list->count) {printf("ID不存在!\n");return;}int i=0;for (i; i < list->count; i++) {if (id_0 == list->Data[i].id) {break;}}// 显示原信息并修改printf("\n%5s %-20s %10s %6s\n", "ID", "名称", "单价", "库存");printf("--------------------------------------------\n");printf("%5d %-20s %10.2f %5d\n",list->Data[i].id,list->Data[i].name,list->Data[i].price,list->Data[i].stock);printf("--------------------------------------------\n");printf("修改商品名称:");scanf("%49s", list->Data[i].name);printf("修改单价:");scanf("%f", &list->Data[i].price);printf("修改库存:");scanf("%d", &list->Data[i].stock);printf("修改成功!\n"); }
功能:
根据用户输入的ID查找商品,修改其信息。
实现步骤:
空列表检查:直接返回提示。
输入目标ID:用户指定要修改的商品。
ID存在性检查:错误判断逻辑不严谨(
id_0 > count
可能漏判)。遍历查找:找到对应商品的数组索引。
显示并修改:打印原信息,逐项修改。
为什么这样写:
直观交互:先展示原信息再修改,减少误操作。
直接修改内存:通过指针直接修改数组元素。
问题与改进:
ID检查缺陷:
id_0 > list->count
假设ID连续且等于count,实际可能因删除操作导致ID大于count。未处理未找到ID:循环结束后未检查是否找到有效索引,可能导致越界访问。
如何使用:
mod_product(&list, NULL); // 修改ID为2的商品
输入示例:
请输入要修改的ID:2 ...(显示原信息)... 修改商品名称:香蕉 修改单价:4.5 修改库存:25
三、main.c 主函数详解
1. 主函数
main
int main() {Product product; // 单个商品(未实际使用)ProductList list; // 商品列表Init_products(&list); // 初始化列表load_from_file(FILENAME, &list); // 加载数据int choice;while (1) {display_menu(); // 显示菜单scanf("%d", &choice);switch (choice) {case 1: add_product(&list, &product); break;case 2: display_products(&list); break;case 3: mod_product(&list, &product); break;case 6: save_to_file(FILENAME, &list); // 保存数据free(list.Data); // 释放内存printf("系统已退出\n");return 0;default: printf("无效输入\n");}} }
功能:
程序入口,管理整个生命周期:初始化→加载数据→循环处理用户操作→退出保存。
实现步骤:
初始化:创建商品列表并初始化。
加载数据:从文件读取历史数据。
主循环:
显示菜单,获取用户选择。
调用对应功能函数。
退出处理:保存数据并释放内存。
关键设计:
循环结构:
while(1)
保持程序持续运行。内存释放:退出前必须
free(list.Data)
,否则内存泄漏。模块化调用:通过
switch-case
调用各功能函数。用户交互流程:
graph TD A[启动程序] --> B[加载数据] B --> C{显示菜单} C --> D[用户选择] D -->|1-5| E[执行操作] E --> C D -->|6| F[保存并退出]
2. 辅助函数
clear_screen
void clear_screen() { #ifdef _WIN32system("cls"); // Windows清屏 #elsesystem("clear"); // Linux/Mac清屏 #endif }
功能:
清空控制台屏幕,提升界面整洁度。
为什么这样写:
跨平台兼容:通过预编译指令区分系统。
简单调用:
system
函数直接执行系统命令。如何使用:
clear_screen(); // 清空屏幕后显示新内容
四、核心知识点总结
1. 动态内存管理
realloc
的作用:动态调整内存大小,首次调用时等效于malloc
。错误处理:必须检查返回值是否为
NULL
。内存释放:
free
必须与malloc/realloc
配对使用。
2. 结构体的使用
数据封装:将商品信息打包为
Product
结构体。列表管理:
ProductList
封装动态数组和长度,提升代码可维护性。
3. 输入输出安全
缓冲区溢出防护:
scanf("%49s")
限制输入长度。格式化输出:
printf
的格式控制符对齐数据。
4. 文件操作
二进制模式:
"wb"
和"rb"
确保数据精确存储。数据序列化:直接读写结构体内存,高效但需注意平台兼容性。
五、动手实践建议
添加删除功能:实现
delete_product
函数,练习内存缩减 (realloc
)。增强输入验证:检查价格是否为负数,库存是否为整数。
实现搜索功能:按名称或ID查找商品,练习字符串处理 (
strstr
)。
注:该代码是本人自己所写,可能不够好,不够简便,欢迎大家指出我的不足之处。如果遇见看不懂的地方,可以在评论区打出来,进行讨论,或者联系我。上述内容全是我自己理解的,如果你有别的想法,或者认为我的理解不对,欢迎指出!!!如果可以,可以点一个免费的赞支持一下吗?谢谢各位彦祖亦菲!!!!!
相关文章:

(C语言)超市管理系统(测试2版)(指针)(数据结构)(清屏操作)
目录 前言: 源代码: product.h product.c fileio.h fileio.c main.c 代码解析: 一、程序结构概述 二、product.c 函数详解 1. 初始化商品列表 Init_products 2. 添加商品 add_product 3. 显示商品 display_products 4. 修改商品 mo…...
什么是虚拟同步发电机
虚拟同步发电机(Virtual Synchronous Generator, VSG) 是一种基于电力电子技术的先进控制策略,通过模拟传统同步发电机的机电特性和动态行为,使逆变器或储能系统能够像传统发电机一样为电网提供惯性支撑、频率调节和电压稳定性支持…...
Python字符串全面指南:从基础到高级
文章目录 Python字符串全面指南:从基础到高级1. 字符串基础概念2. 字符串的基本操作2.1 字符串拼接2.2 字符串索引和切片 3. 字符串常用方法3.1 大小写转换3.2 字符串查找和替换3.3 字符串分割和连接3.4 字符串格式化3.5 字符串验证 4. 字符串的不可变性5. 字符串编…...
基于大模型的TIA诊疗全流程智能决策系统技术方案
目录 一、多模态数据融合与预处理系统1.1 数据接入模块1.2 数据预处理伪代码二、TIA智能预测模型系统2.1 模型训练流程2.2 混合模型架构伪代码三、术中智能监测系统3.1 实时监测流程3.2 实时预测伪代码四、智能诊疗决策系统4.1 手术方案推荐流程4.2 麻醉方案生成伪代码五、预后…...

编译openssl源码
openssl版本 1.1.1c windows 安装环境 perl 先安装perl,生成makefile需要 https://strawberryperl.com/releases.html nasm nasm 也是生成makefile需要 https://www.nasm.us/ 安装完perl输入一下nasm,看看能不能找到,找不到的话需要配…...
CMake入门与实践:现代C++项目的构建利器
文章目录 CMake入门与实践:现代C项目的构建利器引言什么是CMake?快速入门:从Hello World开始1. 安装CMake2. 最小项目示例3. 构建项目 核心概念详解1. 项目结构组织2. 常用指令3. 变量与条件控制 进阶技巧1. 多目录项目管理2. 集成第三方库3.…...

OpenCV实现数字水印的相关函数和示例代码
OpenCV计算机视觉开发实践:基于Qt C - 商品搜索 - 京东 实现数字水印的相关函数 用OpenCV来实现数字水印功能,需要使用一些位操作函数,我们需要先了解一下这些函数。 1. bitwise_and函数 bitwise_and函数是OpenCV中的位运算函数之一&…...
BMS工具箱用来执行贝叶斯模型平均(BMA)计算模块
贝叶斯模型平均(Bayesian Model Averaging,BMA)是一种用于处理模型不确定性的统计方法,通过结合多个模型的预测结果来提高预测的准确性和鲁棒性。在 MATLAB 中,可以使用专门的工具箱(如 BMS 工具箱…...

坐席业绩数据分析
豆包提示词: 使用papaparse.js,chart.js,tailwindcss和font-awesome,生成一个可以交互的简洁且可以运行的HTML代码,不要输出无关内容。 具体要求如下: 1、按坐席姓名输出业绩折线图。 2、系统导航区域&…...
国产大模型 “五强争霸”,决战 AGI
中国 AI 大模型市场正经历一场史无前例的洗牌!曾经 “百模混战” 的局面已落幕,字节、阿里、阶跃星辰、智谱和 DeepSeek 五大巨头强势崛起,形成 “基模五强” 新格局。这场竞争不仅是技术实力的较量,更是资源、人才与生态的全面博…...

怎样将MM模块常用报表设置为ALV默认格式(MB52、MB5B、ME2M、ME1M等)
【SAP系统研究】 对SAP系统中的报表,最方便的格式就是ALV了,可排序、可导出,非常友好。 但有些常见报表却不是默认ALV界面的,譬如MB52: 是不是有点别扭?但其实是可以后台配置进行调整的。 现将一些常用报表修改为默认ALV的方法进行总结,便于大家使用。 一、MB52、MB5…...
Spark 集群配置、启动与监控指南
Spark 集群的配置和启动需要几个关键步骤。以下是完整的操作流程,包含配置修改、集群启动、任务提交和常见错误排查方法。 1. 修改 Spark 配置文件 首先需要编辑 Spark 配置文件,设置集群参数: bash # 进入 Spark 配置目录 cd $SPARK_HOM…...
前端面试每日三题 - Day 34
这是我为准备前端/全栈开发工程师面试整理的第34天每日三题练习: ✅ 题目1:WebGPU图形编程实战指南 核心概念 // WebGPU初始化流程 const adapter await navigator.gpu.requestAdapter(); const device await adapter.requestDevice();// 渲染管线配…...
比亚迪固态电池突破:王传福的技术哲学与产业重构|创客匠人热点评述
合肥某车间凌晨两点依然灯火通明,工程师正在调试的银白色设备,即将颠覆整个电动车行业 —— 比亚迪全固态电池产线的曝光,标志着中国新能源汽车产业正式迈入 “技术定义市场” 的新纪元。 一、技术突破的底层逻辑 比亚迪全固态电池的核心竞…...

Arduino使用红外收发模块
目录 Arduino UNO连接红外发射模块: Arduino D1连接红外接收模块: 有一个Arduini UNO板子和一个Arduino D1板子,我想通过红外发射模块和红外接收模块让他们进行通信。 先看结果: Arduino UNO连接红外发射模块: 发射模…...
【强化学习】强化学习算法 - 马尔可夫决策过程
马尔可夫决策过程 (Markov Decision Process, MDP) 1. MDP 原理介绍 马尔可夫决策过程 (MDP) 是强化学习 (Reinforcement Learning, RL) 中用于对序贯决策 (Sequential Decision Making) 问题进行数学建模的标准框架。它描述了一个智能体 (Agent) 与环境 (Environment) 交互的…...

机器学习 Day16 聚类算法 ,数据降维
聚类算法 1.简介 1.1 聚类概念 无监督学习:聚类是一种无监督学习算法,不需要预先标记的训练数据 相似性分组:根据样本之间的相似性自动将样本归到不同类别 相似度度量:常用欧式距离作为相似度计算方法 1.2 聚类vs分类 聚类&…...
开源Heygem本地跑AI数字人视频教程
图文教程: 点击跳转 视频教程 资料包下载 点击下载:...

软件测试——面试八股文(入门篇)
今天给大家分享软件测试面试题入门篇,看看大家能答对几题 一、 请你说一说测试用例的边界 参考回答: 边界值分析法就是对输入或输出的边界值进行测试的一种黑盒测试方法。通常边界值分析法是作为对等价类划分法的补充,这种情况下ÿ…...

Yolov8的详解与实战-深度学习目标检测
Yolov8的详解与实战- 文章目录 摘要 模型详解 C2F模块 Loss head部分 模型实战 训练COCO数据集 下载数据集 COCO转yolo格式数据集(适用V4,V5,V6,V7,V8) 配置yolov8环境 训练 测试 训练自定义数据集 Labelme…...

Python(1) 做一个随机数的游戏
有关变量的,其实就是 可以直接打印对应变量。 并且最后倒数第二行就是可以让两个数进行交换。 Py快捷键“ALTP 就是显示上一句的代码。 —————————————————————————————— 字符串 用 双引号或者单引号 。 然后 保证成双出现即可 要是…...

【Bootstrap V4系列】学习入门教程之 组件-导航条(Navbar)
Bootstrap V4系列 学习入门教程之 组件-导航条(Navbar) 导航条(Navbar)一、How it works二、Supported content 支持的内容2.1 Brand 品牌2.2 Nav 导航2.3 Forms 表格 三、Color schemes 配色方案四、Containers 容器五、Placemen…...

[Java实战]Spring Security 添加验证码(二十三)
[Java实战]Spring Security 添加验证码(二十三) 在现代的 Web 应用中,验证码是防止恶意攻击(如暴力破解、自动注册等)的重要手段之一。Spring Security 是一个功能强大的安全框架,提供了用户认证、授权等功…...

万文c++继承
1、继承的概念与定义 1.1继承的概念 继承:是c代码复用的手段,允许在原有的基础上扩展,在此之前都是函数层次的复用,继承是类设计层次的复用。 下面有两个类Student和Teacher都有姓名/地址/电话/年龄等成员变量。都有identity身…...
HTTP GET报文解读
考虑当浏览器发送一个HTTP GET报文时,通过Wireshark 俘获到下列ASCII字符串: GET /cs453/index.html HTTP/1.1 Host: gaia.cs.umass.edu User-Agent: Mozilla/5.0 (Windows; U; Windows NT 5.1; en-US; rv:1.7.2) Gecko/20040804 Netscape/7.2 (ax) Acc…...

Linux grep -r 查找依赖包是否存在依赖类 Class
方法一:通过 Linux ,grep -r ClassPath 命令 grep -f org.apache.kafka.connect.source.SourceRecord在 jar 包所在 lib 或者 lib/plugins 目录下执行,grep -r, flink-sql-connector-sqlserver-cdc-3.3.0.jar 中此 kafka Source…...

41:像素坐标与实际坐标转化
采用上面的算子 将像素坐标点转换为实际坐标 image_points_to_world_plane(CamParam, Worldpose, Row, Column, m, X, Y) 第一个参数:标定得到的内参--根据标定助手得到的 第二个参数:标定得到的外参--根据标定助手得到的 第三个参数:计算…...

大某麦演唱会门票如何自动抢
引言 仅供学习研究,欢迎交流 抢票难,难于上青天!无论是演唱会、话剧还是体育赛事,大麦网的票总是秒光。大麦网是国内知名的票务平台,热门演出票往往一票难求。手动抢票不仅耗时,还容易错过机会。作为一名…...
人工智能外呼系统:重构智能交互的全维度进化
在数字化浪潮席卷全球的今天,人工智能外呼系统正以其颠覆性的技术革新,重新定义企业与客户的沟通范式。这一融合语音识别、自然语言处理与机器学习的智能系统,不仅实现了从 “机械应答” 到 “智慧交互” 的跨越,更在金融、医疗、…...

LVS负载均衡群集和keepalive
目录 一. 集群概述 1.1 集群的定义 1.2 集群的分类 1. 高可用集群 HA 2. 高性能运输群集 HPC 3.负载均衡群集 LB 4. 分布式存储集群 二. LVS概述 2.1 LVS的定义 2.2 LVS的工作原理 2.3 LVS 的三种工作模式 2.4 LVS 三种工作模式的对比 2.5 LVS 调度算法 1. 静态…...