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

指针的进阶2

六、函数指针数组

字符指针数组 - 存放字符指针的数组 char* arr[10]

整型指针数组 - 存放整型指针的数组 int* arr[10]

函数指针数组 - 存放函数指针的数组

void my_strlen()
{}
int main()
{//指针数组char* ch[5];int arr[10] = {0};//pa是是数组指针int (*pa)[10] = &arr;//pf是函数指针int (*pf)(const void*) = &my_strlen;//函数指针数组int (*pf[10])(const void*) = {&my_strlen};//pf的类型是int (*[10])(const void*)return 0;
}

解释pf 先和 [ ] 结合,说明 pf是数组,数组的内容是 int (*)() 类型的函数指针。

6.1转移表

函数指针数组的用途:转移表

举例:写一个计算器实现整数的加、减、乘、除

计算器的一般实现:

void menu()
{printf("********************\n");printf("***1. add  2. sub***\n");printf("***3. mul  4. div***\n");printf("***0. exit       ***\n");printf("********************\n");
}int Add(int x,int y)
{return x + y;
}int Sub(int x,int y)
{return x - y;
}int Mui(int x,int y)
{return x * y;
}int Div(int x,int y)
{return x / y;
}int main()
{int input = 0;int x = 0;int y =0;int ret = 0;do{menu();printf("请选择:>");scanf("%d",&input);switch(input){case 1:printf("请输入两个操作数:>");scanf("%d %d",&x,&y);ret = Add(x,y);printf("%d\n",ret);break;case 2:printf("请输入两个操作数:>");scanf("%d %d",&x,&y);ret = Sub(x,y);printf("%d\n",ret);break;case 3:printf("请输入两个操作数:>");scanf("%d %d",&x,&y);ret = Mul(x,y);printf("%d\n",ret);break;case 4:printf("请输入两个操作数:>");scanf("%d %d",&x,&y);ret = Div(x,y);printf("%d\n",ret);break;case 0:printf("退出计算器\n");break;default:printf("选择错误\n");break;}}while(input);return 0;
}

使用函数指针数组实现:

void menu()
{printf("********************\n");printf("***1. add  2. sub***\n");printf("***3. mul  4. div***\n");printf("***0. exit       ***\n");printf("********************\n");
}int Add(int x,int y)
{return x + y;
}int Sub(int x,int y)
{return x - y;
}int Mui(int x,int y)
{return x * y;
}int Div(int x,int y)
{return x / y;
}//用函数指针数组存放上述函数的地址
//转移表
int (*pf[5])(int,int) = {NULL,Add,Sub,Mul,Div};//第一个元素是NULL(0),是为了使得函数与菜单中的选项数字一致int main()
{int input = 0;int x = 0;int y =0;int ret = 0;do{menu();printf("请选择:>");scanf("%d",&input);if(input == 0){printf("退出计算器\n");break;}else if(input >= 1 && innput <=4){printf("请输入两个操作数:>");scanf("%d %d",&x,&y);ret = pf[input](x,y);printf("%d\n",ret);}else{printf("选择错误\n");}}while(input);    return 0;
}

七、指向函数指针数组的指针

指向函数指针数组的指针是一个指针,指针指向一个数组,数组的元素都是函数指针

int main()
{//数组指针int arr[10];int (*pa)[10] = &arr;//函数指针int (*pf)(int,int) = &test;//函数指针数组int (*pf[5])(int ,int) = {test};pf[0] = test;//ppf是指向函数指针数组的指针int (*(*ppf)[5])(int,int) = &pf//ppf的类型是int (*(*)[5])(int,int)return 0;
}

八、回调函数

回调函数就是⼀个通过函数指针调用的函数。
如果你把函数的指针(地址)作为参数传递给另⼀个函数,当这个指针被用来调用其所指向的函数
时,被调用的函数就是回调函数。回调函数不是由该函数的实现方直接调用,而是在特定的事件或条件发生时由另外的一方调用的,用于对该事件或条件进行响应。

可以使用回调函数来实现计算器,使其更加简化:

void menu()
{printf("********************\n");printf("***1. add  2. sub***\n");printf("***3. mul  4. div***\n");printf("***0. exit       ***\n");printf("********************\n");
}int Add(int x,int y)
{return x + y;
}int Sub(int x,int y)
{return x - y;
}int Mui(int x,int y)
{return x * y;
}int Div(int x,int y)
{return x / y;
}//以上都称为回调函数void calc(int (*pf)(int ,int))
{int x = 0;int y =0;int ret = 0;printf("请输入两个操作数:>");scanf("%d %d",&x,&y);ret = pf(x,y);printf("%d\n",ret);
}int main()
{int input = 0;do{menu();printf("请选择:>");scanf("%d",&input);switch(input){case 1:calc(Add);break;case 2:calc(Sub);break;case 3:calc(Mul);break;case 4:calc(Div);break;case 0:printf("退出计算器\n");break;default:printf("选择错误\n");break;}}while(input);return 0;
}
把调用的函数的地址以参数的形式传递过去,使⽤函数指针接收,函数指针指向什么函数就调⽤什么函数,这⾥其实使⽤的就是回调函数的功能

8.1qsort函数的使用

首先回顾一下冒泡排序:思想:两两相邻的元素进行比较

例如进行升序排序:

void bubble_sort(int arr[],int sz)
{//趟数int i = 0;for(i = 0;i < sz-1; i++){//一趟冒泡排序的过程(一趟冒泡泡排序的对数是变化的)int j = 0;for(j = 0;j < sz-1-i; j++){if(arr[j] > arr[j+1]){int tmp = arr[j];arr[j] = arr[j+1];arr[j+1] = tmp;}}}
}
int main()
{//对数组进行排序,升序int arr[10] = {9,8,7,6,5,4,3,2,1,0};int sz = sizeof(arr) / sizeof(arr[0]);bubble_sort(arr,sz);//0 1 2 3 4 5 6 7 8 9//打印int i = 0;for(i = 0;i <sz; i++){printf("%d ",arr[i]);}return 0;
}

冒泡排序是有缺点的:只能排序整数,结构体、浮点型等不可以

qsort函数的使用

库函数中有一个排序函数:qsort(快速排序)

void* base - 待排序的数组的起始位置(地址) 
size_t num - 数组元素个数
size_t size - 数组中每一个元素的大小(一个元素是几个字节)
int (*compar)(const void*, const void*) - 两个元素的比较函数(函数指针),第一个参数是进行比较的两个元素中第一个的地址,第二个参数是另一个元素地址
比较函数的参数是void*类型的原因:因为无法确定想要比较的类型是int、结构体等类型中的哪一种,所以设置成void(无具体类型)类型

int main()
{int a = 10;float f = 5.5f;int* p = &a;//p = &f;//如果把f的地址取出来赋给p,浮点型的地址赋给整型的指针,编译器会报警告:类型不兼容//如果写成void*的指针类型void* pp = &f;//void*的指针可以接收float类型的地址,且不会报警告pp = &a;//用void*的指针接收整型地址也不会警告//pp - 垃圾桶(可以接受任何类型的地址,因为pp是void*类型的指针变量,无具体类型)printf("%f\n", *pp);//不能直接打印,会报错,void*的指针不能直接解引用pp++;//进行++也不行,因为不知道具体类型,不知道具体加一步要走多远(大小不知道)return 0;
}

但是也有缺点:没有办法直接使用,因为void*的指针不能直接解引用,不知道具体类型,如果想要使用,要进行强制类型转换,就可以使用了

---------------------------------------------------------------------------------------------------------------------------------

进一步解析比较函数:当比较函数接收的两个元素进行比较时,p1>p2 - 返回大于0的数字

p1<p2 - 返回小于0的数字;p1=p2 - 等于0

前面我们说过要对数组进行升序排序,那么我们就可以根据以上的信息,转化为两个元素相减的结果,再根据此结果来判断是否需要进行交换 ,如果相减的结果大于0,说明p1>p2,要进行交换

qsort函数的使用需要包含头文件 #include <stdlib.h>

8.1.1使用qsort函数排序整型数据

#include <stdio.h>
#include <stdlib.h>int cmp_int(const void* p1,const void* p2)
{return *(int*)p1 - *(int*)p2;//升序return *(int*)p2 - *(int*)p1;//降序
}
int main()
{//对数组进行排序,升序int arr[10] = {9,8,7,6,5,4,3,2,1,0};int sz = sizeof(arr) / sizeof(arr[0]);qsort(arr,sz,sizeof(arr[0]),cmp_int);int i = 0;for(i = 0;i <sz; i++){printf("%d ",arr[i]);}return 0;
}

8.1.2使用qsort函数排序结构体数据

按照年龄排序:

#include <stdio.h>
#include <stdlib.h>struct Stu
{char name[20];int age;
};//按照学生的年龄来排序
int cmp_stu_by_age(const void* p1,const void* p2)
{return ((struct Stu*)p1)->age - ((struct Stu*)p2)->age;
}int main()
{struct Stu s[3] = {{"zhangsan",20},{"lisi",50},{"wangwu",33}};int sz = sizeof(s) / sizeof(s[0]);qsort(s,sz,sizeof(s[0]),cmp_stu_by_age);int i = 0;for(i = 0;i < sz; i++){printf("姓名:%s 年龄:%d\n",s[i].name,s[i].age);}return 0;
}

按照姓名排序:

#include <stdio.h>
#include <stdlib.h>
#include <string.h>struct Stu
{char name[20];int age;
};//按照学生的姓名来排序
int cmp_stu_by_name(const void* p1,const void* p2)
{return strcmp(((struct Stu*)p1)->name,((struct Stu*)p2)->name);
}int main()
{struct Stu s[3] = {{"zhangsan",20},{"lisi",50},{"wangwu",33}};int sz = sizeof(s) / sizeof(s[0]);qsort(s,sz,sizeof(s[0]),cmp_stu_by_name);int i = 0;for(i = 0;i < sz; i++){printf("姓名:%s 年龄:%d\n",s[i].name,s[i].age);}return 0;
}

字符串是按照字典序排序的:
字典序是一种基于字母或字符顺序的排列方式,类似于字典中单词的排列规则。在C语言中,常用于字符串或字符数组的比较和排序。

字典序的核心规则‌
逐字符比较‌从左到右逐个比较字符的ASCII。若字符不同,ASCII值较小的字符所在的字符串更小。若字符相同,继续比较下一个字符。
长度优先‌:若所有字符相同,则较短的字符串更小。
‌示例‌:"apple" < "banana"(因为 'a' < 'b')
"app" < "apple"(前三个字符相同,但前者更短)
‌C语言中的字典序实现‌:
使用标准库函数 strcmp
strcmp 是C语言标准库(<string.h>)中用于比较字符串的函数,按字典序返回结果:

‌返回值‌:
< 0:第一个字符串小于第二个。
= 0:两个字符串相等。
> 0:第一个字符串大于第二个。

注意事项:字符编码默认基于ASCII值,大写字母(A-Z,ASCII 65~90)比小写字母(a-z,ASCII 97~122)小

字符串以终止符\0结尾,比较时会自动处理

8.2qsort函数的模拟实现

根据qsort函数,改造冒泡排序,使得这个函数可以排序任意指定的数组(以冒泡排序的思维实现qsort函数)

8.2.1排序整型数组

//使用我们自己写的bubble_sort函数排序整型数组void Swap(char* a,char* b,int size)
{int i = 0;for(i = 0;i < size; i++){char tmp = *a;*a = *b;*b = tmp;a++;b++;}
}
int cmp_int(const void* p1,const void* p2)
{return *(int*)p1 - *(int*)p2;
}
void bubble_sort(void* base,size_t num,size_t size,int (*cmp)(const void* p1,const void* p2))
{//趟数size_t i = 0;for(i = 0;i < num-1; i++){size_t j = 0;for(j = 0;j < num-1-i; j++){if(cmp((char*)base+j*size,(char*)base+(j+1)*size) > 0){Swap((char*)base+j*size,(char*)base+(j+1)*size,size);//实现两个元素的比较}}}
}
int main()
{int arr[10] = {9,8,7,6,5,4,3,2,1,0};int sz = sizeof(arr) / sizeof(arr[0]);bubble_sort(arr,sz,sizeof(arr[0]),cmp_int);int i = 0;for(i = 0;i < sz; i++){printf("%d ",arr[i]);}return 0;
}

8.2.2排序结构体数组

按照年龄排序:

struct Stu
{char name[20];int age;
};
void Swap(char* a,char* b,int size)
{int i = 0;for (i = 0; i < size; i++){char tmp = *a;*a = *b;*b = tmp;a++;b++;}
}
//按照年龄排序
int cmp_stu_by_age(const void* p1,const void* p2)
{return ((struct Stu*)p1)->age - ((struct Stu*)p2)->age;
}
void bubble_sort(void* base,size_t num,size_t size,int (*cmp)(const void* p1,const void* p2))
{//趟数int i = 0;for(i = 0;i < num -1; i++){int j = 0;for(j = 0;j < num-1-i; j++){if(cmp((char*)base+j*size,(char*)base+(j+1)*size) > 0){Swap(cmp((char*)base+j*size,(char*)base+(j+1)*size,size);}}}
}
int main()
{struct Stu s[3] = {{"zhangsan",20},{"lisi",50},{"wangwu",33}};int sz = sizeof(s) / sizeof(s[0]);bubble_sort(s,sz,sizeof(s[0]),cmp_stu_by_age);int i = 0;for(i = 0;i < sz; i++){printf("姓名:%s 年龄:%d\n",s[i].name,s[i].age);}return 0;
}

按照姓名排序:

struct Stu
{char name[20];int age;
};
void Swap(char* a,char* b,int size)
{int i = 0;for (i = 0; i < size; i++){char tmp = *a;*a = *b;*b = tmp;a++;b++;}
}
//按照姓名排序
int cmp_stu_by_name(const void* p1,const void* p2)
{return strcmp(((struct Stu*)p1)->name,((struct Stu*)p2)->name);
}
void bubble_sort(void* base,size_t num,size_t size,int (*cmp)(const void* p1,const void* p2))
{//趟数int i = 0;for(i = 0;i < num -1; i++){int j = 0;for(j = 0;j < num-1-i; j++){if(cmp((char*)base+j*size,(char*)base+(j+1)*size) > 0){Swap(cmp((char*)base+j*size,(char*)base+(j+1)*size,size);}}}
}
int main()
{struct Stu s[3] = {{"zhangsan",20},{"lisi",50},{"wangwu",33}};int sz = sizeof(s) / sizeof(s[0]);bubble_sort(s,sz,sizeof(s[0]),cmp_stu_by_name);int i = 0;for(i = 0;i < sz; i++){printf("姓名:%s 年龄:%d\n",s[i].name,s[i].age);}return 0;
}

相关文章:

指针的进阶2

六、函数指针数组 字符指针数组 - 存放字符指针的数组 char* arr[10] 整型指针数组 - 存放整型指针的数组 int* arr[10] 函数指针数组 - 存放函数指针的数组 void my_strlen() {} int main() {//指针数组char* ch[5];int arr[10] {0};//pa是是数组指针int (*pa)[10] &…...

Java学习——day28(Java并发工具类与线程池)

文章目录 1. 并发工具类简介1.1 ExecutorService1.2 Callable 和 Future1.3 Executors 工具类1.4 线程池优势 2. 实践&#xff1a;线程池执行任务并收集结果示例2.1 示例代码 3. 代码详解3.1 线程池的创建3.2 定义任务列表3.3 提交任务并收集 Future3.4 获取任务执行结果3.5 关…...

2021第十二届蓝桥杯大赛软件赛省赛C/C++ 大学 B 组

记录刷题的过程、感悟、题解。 希望能帮到&#xff0c;那些与我一同前行的&#xff0c;来自远方的朋友&#x1f609; 大纲&#xff1a; 1、空间-&#xff08;题解&#xff09;-字节单位转换 2、卡片-&#xff08;题解&#xff09;-可以不用当组合来写&#xff0c;思维题 3、直…...

【数据结构】之二叉树

二叉树是我们在数据结构中学到的第一个非线性结构&#xff0c;是后续学习更为复杂的树、图结构的基础。本文整理了二叉树的概念定义、基本操作、遍历算法、伪代码与代码实现以及实例说明&#xff0c;方便大家随时查找对应。 一、定义与基本术语 二叉树是一种树形结构&#xf…...

电感、互感器、变压器和磁珠综合对比——《器件手册--电感/线圈/变压器/磁珠篇》

三、电感/线圈/变压器/磁珠 名称 定义 特点...

CLIP中的Zero-Shot Learning原理

CLIP&#xff08;Contrastive Language-Image Pretraining&#xff09;是一种由OpenAI提出的多模态模型&#xff0c;它通过对比学习的方式同时学习图像和文本的表示&#xff0c;并且能在多种任务中进行零样本学习&#xff08;Zero-Shot Learning&#xff09;。CLIP模型的核心创…...

基于 Redis 实现一套动态配置中心 DCC 服务与反射基础知识讲解

目录 动态配置中心核心价值 轻量级 Redis 方案与 ZooKeeper 的对比分析 为什么选择自定义 Redis 方案&#xff1f; 1. 技术决策背景 一、活动降级拦截 1. 定义与作用 2. 实现原理 二、活动切量拦截 1. 定义与作用 2. 实现原理 三、两者的核心区别 四、实际应用案例 1. 电商大促…...

vue 前端遇到问题 样式不展示

vue 前端遇到问题 样式不展示 先看接口返回有数据没 如果有数据看下 是不是 输入赋值给其他 字段 没有赋值上导致报错 所以页面没展示数据...

基于 Spring Boot + Vue 的 [业务场景] 管理系统设计与实现

技术范围&#xff1a;SpringBoot、Vue、SSM、HLMT、Jsp、PHP、Nodejs、Python、爬虫、数据可视化、小程序、安卓app、大数据、物联网、机器学习等设计与开发。 主要内容&#xff1a;免费功能设计、开题报告、任务书、中期检查PPT、系统功能实现、代码编写、论文编写和辅导、论文…...

2025蓝桥杯JavaB组

说明 博主自己水平有限&#xff0c;而且答案也不一定对&#xff0c;下面代码和思路仅作分享。我只把我考场上做了的写出来了&#xff0c;有什么问题欢迎评论区交流。 A&#xff1a;逃离高塔 思路&#xff1a; 由于有了去年的经验&#xff0c;所以一上来我就是找规律&#xf…...

HDF5文件格式:数据类型与读写功能详解

HDF5文件格式&#xff1a;数据类型与读写功能详解 HDF5简介 HDF5&#xff08;Hierarchical Data Format version 5&#xff09;是一种用于存储和管理大量科学数据的文件格式和库。它由美国国家高级计算应用中心&#xff08;NCSA&#xff09;开发&#xff0c;具有以下特点&…...

探索 Python 的 functools 模块:缓存、属性缓存与 LRU 缓存

李升伟 编译 Python 的 functools 模块是函数式编程爱好者的宝库&#xff0c;提供了许多工具来提升代码的效率和优雅性。本文将深入探讨三个强大的函数——cache、cached_property 和 lru_cache&#xff0c;它们通过存储昂贵计算的结果来优化性能。无论是加速递归算法还是简化…...

缓存与数据库一致性:从问题到解决方案全解析

一、⼀致性问题的由来&#xff1a;为什么会不一致&#xff1f; 我们先从现实例子出发&#xff0c;来看为什么会出现一致性问题&#xff1a; &#x1f4e6; 场景举例&#xff1a;电商下单业务 用户提交订单 → 服务写入数据库订单表&#xff1b;同时更新缓存&#xff08;比如用…...

【android bluetooth 框架分析 02】【Module详解 2】【gd_shim_module 模块介绍】

1. 背景 上一章节 我们介绍了 module_t 的 大体框架 &#xff0c;本节内容我们就选择 我们的 gd_shim_module 模块为例子&#xff0c;具体剖析一下&#xff0c;它里面的逻辑。 static const char GD_SHIM_MODULE[] "gd_shim_module";// system/main/shim/shim.cc …...

dbt:新一代数据转换工具

dbt&#xff08;Data Build Tool&#xff09;一款专为数据分析和工程师设计的开源工具&#xff0c;专注于 ETL/ELT 流程的数据转换&#xff08;Transform&#xff09;环节&#xff0c;帮助用户以高效、可维护的方式将原始数据转换为适合分析的数据模型。 用户只需要编写查询&am…...

Linux-内核驱动-makemenu,make modules,make uImage,杂项

动态生成设备节点设备号...

linux 内存踩踏导致的空指针问题分析纪要

1&#xff0c;查看日志信息打印 我们看到日志发现发包的skb模块有NULL pointer情况&#xff0c;我们看代码分析skb指针不可能出现是空指针&#xff0c;这个时候我们怀疑可能是出现了踩内存导致的空指针情况&#xff0c;所以我们首先需要找到系统PANIC的条件&#xff0c;也就是…...

【C++】 —— 笔试刷题day_14

一、乒乓球筐 题目解析 题目输入两个字符串A和B&#xff0c;分别代表A和B中的乒乓球&#xff0c;不同的大写字母就表示不同的乒乓球&#xff1b; 如果判断B中的所有乒乓球在A中都有&#xff0c;且A中每种乒乓球的数量大于等于B中的。&#xff08;简单来说就是B是A的子集&#…...

在WPS中通过JavaScript宏(JSA)调用DeepSeek官方API自动识别标题级别和目录

我们希望通过AI&#xff0c;能够自动识别像“一”、“&#xff08;一&#xff09;”、“1”、“&#xff08;1&#xff09;” 这类常见标题序号。做一个规则&#xff0c;如果存在“一”时&#xff0c;则“一”、“&#xff08;一&#xff09;”、“1”分别识别为H1、H2、H3&…...

修复 WPS 编译错误:缺少:Sub或Function 且出现两个MathType加载项

问题首次出现于2025.4.12。 同时使用了Word和WPS&#xff0c;在里面都使用了MathType&#xff0c;在Microsoft的Word中&#xff0c;加载项能正常加载且显示&#xff0c;这也是我们要的效果。 而在WPS中&#xff0c;却出现了两个MathType&#xff0c;且在启动时会弹窗报错&…...

HTTP协议

目录 1 Fiddler工具 2 HTTP协议 2.1 HTTP请求和响应格式 2.2 URL 2.3 方法method 2.3.1 GET 2.3.2 POST 2.4 请求报头Header 2.5 请求正文body 2.6 http响应状态码 2.7 响应报头header HTTP协议是应用层的协议&#xff0c;基于传输层的TCP协议来传输&#xff0c;数据…...

拓扑排序 —— 2. 力扣刷题207. 课程表

题目链接&#xff1a;https://leetcode.cn/problems/course-schedule/description/ 题目难度&#xff1a;中等 相关标签&#xff1a;拓扑排序 / 广度优先搜搜 BFS / 深度优先搜索 DFS 2.1 问题与分析 2.1.1 原题截图 2.1.2 题目分析 首先&#xff0c;理解题目后必须马上意识到…...

寻找峰值 --- 二分查找

目录 一&#xff1a;题目 二&#xff1a;算法原理 三&#xff1a;代码实现 一&#xff1a;题目 题目链接&#xff1a;162. 寻找峰值 - 力扣&#xff08;LeetCode&#xff09; 二&#xff1a;算法原理 三&#xff1a;代码实现 class Solution { public:int findPeakElemen…...

SAP系统客户可回收包材库存管理

问题&#xff1a;客户可回收包材库存管理 现象&#xff1a;回收瓶无库存管理&#xff0c;在库数量以及在客户的库存数量没有统计&#xff0c;管理混乱。 解决方法&#xff1a; 客户可回收包装材料在SAP有标准的解决方案&#xff0c;在集团尚未启用该业务&#xff0c;首先…...

C++标识符:检查是否和保留字冲突

1. 基础知识 最基本的要求&#xff1a; 字母、数字、下划线组成&#xff0c; 并且不能是数字开头。 禁忌1&#xff1a; C 关键字不能用做标识符。 它们是&#xff1a; alignas alignof asm auto bool break case catch char char16_t char32_t class const constexpr const_…...

【Java多线程】告别线程混乱!深度解析Java多线程4大实现方式(附实战案例)

一、继承Thread类 实现步骤&#xff1a; 1.继承Thread类 2.重写run()方法 3.创建线程对象并调用start()方法 示例&#xff1a; class MyThread extends Thread {Overridepublic void run() {for (int i 0; i < 5; i) {System.out.println(Thread.currentThread().getNam…...

Linux安装yum和python

一、安装yum(CentOS) 查看yum版本 yum --version 如果未安装&#xff0c;执行以下部分&#xff1a; 1. 确保你的系统中已经安装了epel仓库&#xff0c;如果没有安装可以通过以下命令安装&#xff1a; sudo yum install epel-release 2.yum安装 – CentOS/RHEL系统&#…...

【数据结构】HashMap源码 —— 简单介绍

HashMap源码介绍 下面并非完整的源码&#xff0c;主要简单了解其流程。 1. 基本成员变量 哈希桶/开散列&#xff0c;链地址法/开链法是由&#xff1a;数组 链表(单链表) 红黑树&#xff08;当数组长度>64 && 链表长度>8以后&#xff0c;链表变成红黑树&#xf…...

149页研读——华为基于IPD全过程研发质量管理【附全文阅读】

本文介绍了IPD(集成产品开发)的全过程研发质量管理,强调了以客户需求为导向,通过跨部门协同、资源整合、快速响应等方式提高研发效率和成功率。文章详细阐述了IPD研发管理体系的精要,包括其核心思想、优势、框架以及核心理念。 其中,跨领域平台与技术研发、端到端流程与项…...

深入理解 v-for 指令及其使用方法

在 Vue.js 中&#xff0c;v-for 是用于渲染列表的核心指令&#xff0c;它允许你通过循环渲染数据源中的每一项。通过 v-for&#xff0c;你可以轻松地将数组、对象或其他可迭代的数据渲染成 HTML 元素。本文将详细介绍 v-for 的基本用法、常见的应用场景、最佳实践及性能优化&am…...

swift菜鸟教程24-25(可选链,自动引用计数)

一个朴实无华的目录 今日学习内容&#xff1a;1.Swift 可选链1.1定义1.2通过可选链调用方法1.3使用可选链调用下标脚本1.4通过可选链接调用来访问下标1.4访问可选类型的下标 2.Swift 自动引用计数&#xff08;ARC&#xff09;2.1实例之间的循环强引用会造成内存泄露2.2弱引用&a…...

使用 Visual Studio 2022 (VS2022) 编译 FreeCAD 1.0.0 的详细教程

一、环境准备 官方教程&#xff1a;在 Windows 上编译 - FreeCAD Documentation Windows 10/11&#xff08;推荐&#xff09; git vs2022 cmake 3.26.4 Doxygen1.12 二、获取源码与依赖 版本关系 打开Git Bash或CMD&#xff0c;执行以下命令 git clone --recurse-sub…...

机械臂只有位置信息是否可以进行手眼标定?

平常我在做手眼标定时&#xff0c;一般都是通过OpenCV的cv::calibrateHandEye函数进行求解&#xff0c;需要输入多组不同的机械臂位姿。今天遇到了一款舵机机器人&#xff0c;只能获取位置&#xff0c;得不到姿态信息&#xff0c;想着那就把姿态都设为0&#xff0c;结果求不出来…...

Unity入门

文章目录 Unity脚本基础大基础生命周期函数Inspector窗口显示常用特性辅助特性 MnonBehaviour基类成员变量成员方法 组件GameObject成员变量gameObject静态方法成员方法 组件Time静态成员变量 组件TransformVector3结构体基础基本概念常用向量表示常用方法 位置与位移位置posit…...

《汽车制造技术基础》第一次作业

作业内容 查阅相关资料&#xff0c;谈谈对汽车制造技术的发展的理解。 可以是关于汽车的先进制造技术 或 汽车先进制造技术 与 制造理念的发展趋势 或 汽车先进制造技术对环境与可持续发展的影响等。 以下从技术突破、制造理念转型及环境影响三个维度展开对汽车制造技…...

烟花爆竹储存作业安全要求

烟花爆竹储存作业证是从事相关作业的法定凭证&#xff0c;旨在确保操作人员具备专业知识和安全技能&#xff0c;防止因违规操作引发火灾、爆炸等事故。根据《烟花爆竹安全管理条例》及相关法规&#xff0c;未取得作业证的人员不得从事烟花爆竹储存、搬运、管理等作业。 仓库选址…...

Flask+Plotly结合动态加载图形页面实践

1. DeepSeek帮我实践 1.1. 我的提问既设计方案 原有如下主页:dashboard.html,现增加“预测模型学习”,对感知机神经网络描述如下: 1、输入与输出为固定值,例如输入层215,输出层48; 2、模型为回归神经网络; 3、中层是可动态调整的,例如定义如下:第二层,200,第三层…...

leetcode每日一题:统计好整数的数目

题目 给你两个 正 整数 n 和 k 。 如果一个整数 x 满足以下条件&#xff0c;那么它被称为 k 回文 整数 。 x 是一个 回文整数 。 x 能被 k 整除。 如果一个整数的数位重新排列后能得到一个 k 回文整数 &#xff0c;那么我们称这个整数为 好 整数。比方说&#xff0c;k 2 …...

《2025蓝桥杯C++B组:D:产值调整》

**作者的个人gitee**​​ 作者的算法讲解主页▶️ 每日一言&#xff1a;“泪眼问花花不语&#xff0c;乱红飞过秋千去&#x1f338;&#x1f338;” 题目 二.解题策略 本题比较简单&#xff0c;我的思路是写三个函数分别计算黄金白银铜一次新产值&#xff0c;通过k次循环即可获…...

【模块化拆解与多视角信息1】基础信息:隐藏的筛选规则——那些简历上没说出口的暗号

写在最前 作为一个中古程序猿,我有很多自己想做的事情,比如埋头苦干手搓一个低代码数据库设计平台(目前只针对写java的朋友),比如很喜欢帮身边的朋友看看简历,讲讲面试技巧,毕竟工作这么多年,也做到过高管,有很多面人经历,意见还算有用,大家基本都能拿到想要的offe…...

当Browser Use遇见A2A:浏览器自动化与智能体协作的“冰与火之歌“

——一场正在改写数字文明的技术奇遇 第一章 浏览器革命&#xff1a;从"手动挡"到"自动驾驶" 1.1 传统自动化工具的"中年危机" 还记得2023年那个抓狂的凌晨吗&#xff1f;你蹲守演唱会门票时&#xff0c;Selenium脚本因为验证码识别失败第108次…...

Python:开启自动化办公与游戏开发的无限可能

重要的事情放在前面 Python自动化办公和游戏 Python&#xff1a;开启自动化办公与游戏开发的无限可能 在数字化时代的浪潮中&#xff0c;Python以其强大的功能和简洁的语法&#xff0c;成为了众多开发者手中的得力工具&#xff0c;尤其在自动化办公与游戏开发领域&#xff0…...

腾讯后台开发 一面

一、手撕 合并升序链表 合并两个排序的链表_牛客题霸_牛客网 顺时针翻转矩阵 顺时针旋转矩阵_牛客题霸_牛客网 二、八股 1、静态变量和实例变量 public class House {public static String buildDate "2024-10-27"; // 静态变量public String color; // 实…...

基于生成对抗网络(GAN)的手写数字生成实践

基于生成对抗网络&#xff08;GAN&#xff09;的手写数字生成实践 一、图像生成的技术演进 在人工智能领域&#xff0c;图像生成技术经历了从传统算法到深度学习的革命性发展。其中&#xff0c;生成对抗网络&#xff08;Generative Adversarial Networks, GANs&#xff09;作…...

网络互连与互联网

1.在路由表中找不到目标网络时使用默认路由&#xff0c;默认路由通常指本地网关的地址。 2.OSPF最主要的特征是使用分布式链路状态协议&#xff0c;而RIP使用的是距离向量协议。 3.OSPF使用链路状态公告LSA扩散路由信息 4.内部网关路由协议IGRP是一种动态距离矢量路由协议&a…...

大模型常见面试题

大模型常见面试题 大模型相关的面试问题通常涉及模型的原理、应用、优化以及面试者对于该领域的理解和经验。以下是一些常见的 大模型面试问题以及建议的回答方式&#xff1a; 请简述什么是大模型&#xff0c;以及它与传统模型的主要区别是什么&#xff1f; 回答&#xff1a…...

python高级编程一(生成器与高级编程)

@TOC 生成器 生成器使用 通过列表⽣成式,我们可以直接创建⼀个列表。但是,受到内存限制,列表容量肯定是有限的。⽽且,创建⼀个包含100万个元素的列表,不仅占⽤很⼤的存储空间,如果我们仅仅需要访问前⾯⼏个元素,那后⾯绝⼤多数元素占 ⽤的空间都⽩⽩浪费了。所以,如果…...

Linux线程属性与多线程开发:API详解与实战代码解析

Linux 线程的属性 线程池 多线程的创建 线程的属性 引入 我们设想一个场景&#xff0c;使用pthread_detach时&#xff0c;发现线程早就已经结束了&#xff0c;这时候pthread_detach还能正常发挥清理线程的 独有空间 的作用吗&#xff1f; 答案是可以的&#xff0c;但是这难…...

Inkscape安装教程

Inkscape 是一款开源的矢量图形编辑软件&#xff0c;功能强大且免费&#xff0c;适用于 Windows、macOS 和 Linux 系统。以下是在不同操作系统上安装 Inkscape 的详细教程&#xff1a; 一、Windows 系统安装 Inkscape 1. 下载安装包 打开浏览器&#xff0c;访问 Inkscape 官方…...

危化品安全员岗位注意事项有哪些?

危化品安全员肩负着保障危化品生产、储存、运输和使用等环节安全的重要职责&#xff0c;其岗位注意事项涉及多个方面&#xff0c;以下是一些主要内容&#xff1a; 法规标准与制度执行 必须熟悉并严格遵守国家和地方有关危化品安全管理的法律法规、标准规范&#xff0c;如《危险…...