【c语言】指针 (完结)
一、sizeof和strlen的对比
1、sizeof
前面我们在学习操作符的时候,我们学习了sizeof,知道其是计算变量所占内存的大小的,单 位是字节,如果操作数是数据类型的话,计算的就是这个类型的变量所占的内存空间的大小单 位也是字节。其计算的结果只与该变量的类型有关,与其存放的集体数据无关。
还有就是对于要计算的是变量的大小,在语法的写法可以不写小括号,所以我们在阅读代码的 时候对于sizeof计算一个变量没有括号,这个写法也是可以的。当然我们在写代码的时候,建 议还是带上括号会更好一点,这样可以增加我们代码的可读性。
下面我们通过代码来感受一下:
运行结果如下:
2、strlen
strlens是C语言的库函数,功能是求字符串的长度。其函数原型如下:
统计的是从strlen函数的参数str中的这个地址开始往后,遇到" \0 " 就结束统计,然后返回 " \0 "前面的字符个数,strlen函数会一直向后找" \0 "字符,直到找到为止,所以其可能会存在 越界的可能。
下面我们通过代码来看其运行结果是咋样的:
我们来分析一下上面的代码,我们先看前面两个strlen库函数,我们前面说到其会从传入的地 址往后找,直到找到第一个" \0 ",我们看到数组arr1和arr2的区别就是数组arr1就只存放了 abc三个字符,并没有\0,那么strlen函数并不会停止,而是会往后找,直到找到\0为止,那么 其返回的值我们也不知道是啥。
而数组arr2是一个字符串,虽然其在代码上没有看到\0,但是其实际在末尾处是默认有一个\0 的,也就是arr2实际是这样的:"abc\0";所以strlen函数的返回值就是3。
下面我们来看后面两个sizieof,我们上面已经解释了两个数组之间的区别了,那么arr2数组就 是比arr1数组多了一个\0,所以对于arr1数组的结果是3,对于arr2数组的结果就是4.
运行结果如下:
3、sizeof和strlen对比
二、数组和指针笔试解析
1、一维数组
我们先看一段代码:
1、我们前面我们有说过这个情况,sizeof(数组名字),其中数组名代表整个数组,会计算整个 数组的大小,那么这个的计算结果就是16。
2、我们在前面的学习中知道数组名字可以是首元素地址,然后这里对首元素地址加上整数 0,还是首元素地址,所以其是一个地址,其大小有应该是4或者8个字节。
3、a在这边首先是首元素地址,我们讲过了只有第一种情况下才是整个数组的地址,然后这 里对a的首元素地址进行解引用,那么其就是数组的第一个元素,然后我们这个数组的元 素是整型类型,那么其大小为4字节。
4、a是首元素地址,对其进行加1操作就是跳到下一个元素的地址,但是其本质还是地址,那 么其大小还是4或8字节。
5、a[1]是数组的第二个元素,其是一个整型类型,那么其大小就为4个字节。
6、这个是取整个数组的地址,那么其本质还是地址,那么其大小就还是 4或8字节
7、对取数组地址,然后再解引用,那么可以这么理解。&和*号相互消除了,那么其可以化简 为sizeof(a)那么就是求整个数组的大小,那么其结果为16。
8、其是取数组的地址然后跳过整个数组,那么其本质就是地址,那么其大小就是 4或者8。
9、其是对数组的首元素进行取地址操作,那么其本质还是地址,所以其大小还是4或8字节。
10、其首先对数组首元素进行取地址操作,然后其再进行加1操作,此时为后一个元素的地 址,那么其本质还是个地址,那么其大小也还是4或8。
下面我们看一下其运行结果(在64位的环境下):
2、字符、字符串数组和字符指针
通过上面的练习我们对于这部分的知识应该有了一定的理解了,下面我们来看看在字符和字符 串中是咋回事
代码1
1、sizeof(数组名),此数组名表示的是整个数组,那么其算的是整个数组的大小,那么其结果 应该是6字节。
2、这里是对数组名+0操作,这里就不是代表整个数组了,其是代表数组首元素地址+0,那么 其本质是一个地址那么其结果是4或8字节。
3、arr是首元素地址,然后对其解引用,那么就是整个元素了,其是一个字符类型,那么其大 小为1字节。
4、arr[1]是数组的第二个元素,其也是一个字符类型,其大小也是1字节。
5、&arr其到的是整个数组的地址,其本质是地址,那么其大小还是4或8字节。
6、&arr+1就是跳过整个arr数组,但是其本质还是一个地址,那么其大小还是4或8字节。
7、&arr[0]是取首元素地址,然后对其+1操作,就是跳到下一元素的地址,其本质还是地址, 那么其大小还是4或8字节。
我们运行来看看:
代码2
这段代码和代码1的区别就是将sizeof换成了strlen,前面我们也知道了他们两个的区别。
1、strlen的计算方式是从传入的地址往后找字符串中的\0,没有遇到\0就会一直往后找,直到 碰到了\0,这里的arr数组是字符数组,并不是字符串,其结尾处是不会默认带\0的,那么 其就会一直往后面找,所以其计算的结果是啥我们也不知道。
2、其原理和1是一样的,其返回值也是随机的。
3、我们前面讲到strlen的时候,我们看到strlen函数的原型的从参数应该是一个字符指针,但 是现在的参数是对数组首元素地址解引用,得到的字符a,而不是一个地址,我们之前也 说过字符在存储的时候是它的ascll码,那么这里strlen就是将字符a的ascll码当做一个地 址,但是97这个编号的地址不一定是这个程序的,那么此时就造成了非法访问。
4、同3一样此时给strlen传入的是字符a的ascll码,此时也还是可能会造成非法访问。
5、这里的&arr得到的是一个类型为char(*)[6]的数组指针,但是strlen接收的是字符指针,所 以这里的数组指针会被强制类型转换为字符指针,那么这里强制类型转换后,就是首元素 的地址,然后就从这个地址往后找,那么此时就和1、2的情况一样了,此时返回的为随机 值了。
6、&arr+1还是一个数组指针,其作为strlen的参数后会强制类型转换为字符指针,然后从这 个位置开始往后找,直到碰到\0才结束,所以也是随机值。
7、这里其实给strlen传入的是第二个元素的地址,此时从第二个元素开始找,直到找到\0, 所以其也还是个随机值。
下面我们来看看其结果,这里要注意的是3和4可能会造成非法访问,所以我们不运行这两个:
代码3
后面就是对于字符串数组的练习:
1、由于字符串中默认会包含一个\0,所以我们在计算整个字符串的大小的时候,要把这个 \0也算上去,那么这个大小就是7。
2、arr+0那么这是对首元素的地址进行+0操作,那么其本质上还是地址,那么这个大小就 为4或8字节。
3、这里对arr进行解引用,那么其是对首元素的地址进行解引用,那么这里求的就是数组 首元素的大小,即为1。
4、这里求的是数组第二个元素的大小,那么结果就为1。
5 、这里对数组取地址,那么其本质就是是个地址,那么其大小就为4或8字节。
6、这里对数组取地址后进行+1操作,跳过整个数组,但是其本质还是地址,那么其大小 还是4或8。
7、这里对第一个元素取地址后+1,那么此时就是拿到第二个元素的地址,那么其大小就 还是4或8字节。
下面我们看看其计算结果(在64位环境下):
代码4
1、在字符串数组中,由于其在末尾处会默认加上\0,所以函数strlen可以正常计算字符串 数组的长度,结果为6。
2、arr+0,此时的地址还是在首元素的地址,那么此时strlen的结果还是6。
3、这里对数组解引用,此时给strlen传入的是字符a的ascll码,此时会造成非法访问。
4、同理,这里给strlen传入的是字符b,此时也是造成非法访问。
5、这里会把数组指针强制转换为字符指针,那么此时就会得到的是首元素的地址,那么 在这里也可以正常计算出6 。
6、这里对数组取地址再进行+1操作,此时就跳过了整个数组,那么此时不知道啥时候才 可以遇到\0了那么此时的返回值就是一个随机值了。
7、这里先对首元素取地址,再进行+1操作,得到的是第二个元素的地址,那么此时是从 第二个元素开始往后找\0,那么此时的返回值为5
下面我们来看看代码的运行结果(64位环境下):
代码5
下面我们开始对字符指针进行练习
1、我们前面刚刚开始学习指针的时候知道,把一个字符常量赋值给一个字符指针,实际 上是将整这个字符常量的第一个字符的地址传给这个指针,那么变量p实际上也是一个 地址,那么其大小就是4或 8字节。
2、p+1得到的就是这个字符串的第二个字符的地址,那么其本质还是一个地址,那么其 大小就是4或8字节。
3、这里传入的是对p解引用,由于p实际上是字符串的首个字符的地址,那么其解引用就 是第一个元素字符a那么其大小就是1。
4、p[0]就表示拿到的是这个字符串的第一个字符,和字符数组类似,那么其大小就为1。
5、p本身就是一个指针变量,再对其取地址就是二级指针,但是其本质上还是一个地址, 那么其大小就还是 4或8字节。
6、和上面的类似,对一个指针变量取地址为二级指针,再进行+1操作,此时还是个地 址,那么大小还是4或8。
7、这里就很简单了,这里首先是得到了字符串的第一个字符,然后对其取地址,然后进 行+1操作,此时就到了第二个元素的地址了。
下面我们来看看其运行结果
代码6
1、这里的p是字符串的第一个字符的地址,那么strlen函数就会从这个位置开始往后找,然 后字符串在末尾处是会自带\0的那么其到末尾处就结束计算,返回字符串的长度,为6。
2、p+1那么此时是在字符串的第二个字符的地址,那么此时是从第二个字符的位置出发往 后找,那么此时的长度就是5。
3、对p进行解引用,p是字符串的首字符的地址,那么此时对其解引用就是字符a了,那么 此时给strlen函数传的是其的acsll码97,那么此时就可能造成非法访问了。
4、和上面3的情况差不多,不一样的是这里是直接取的字符串的第一个字符,同样造成非 法访问。
5、这里是对指针p进行取地址,此时给strlen函数传入的是一个二级指针,这个二级指针指 向的是一级指针p,但是这个p的地址我们也不知道在哪里,那么我们啥时候碰到\0也不 确定,那么strlen在哪里停止也是不知道的,那么这次的计算值也是随机值。
6、这里是对二级指针跳过一个一级指针p后面是啥我们也不知道,那么其啥时候碰到\0也 是不情况的,那么此时也是返回一个随机值。
7、这里的&p[0]相当于拿到了第一个字符的地址,那么再+1后就是第二个字符的地址,那 么其计算的结果就是5了。
下面我们来看看其运行结果:
3、二维数组
下面我们来进行对二维数组的练习
1、 二维数组也是如此,sizeof(数组名)这里就是代表整个数组,计算的是整个数组的大小,那 么其大小就应该为3*4*4,结果为48字节。
2、这里求的是整个数组的首个元素,那么其大小就为 4字节。
3、这里的a[0]就相当于这个二维数组的第一行,那么这里就是求第一行的大小,那么其结果为 4*4=16字节。
4、a[0]相当于第一行的数组名,那么其+1后就相当于第二个元素的地址了,那么其大小就为4 或8字节。
5、这里先取得第一行第二个元素的地址,然后对其解引用,那么得到的就是第二个 元素了,那 么其大小就为4字节。
6、这里的数字名字没有和sizeof单独放在一起,而是对数组名+1操作,那么此时得到的数组第 二行的地址,那么其大小为4或8字节
7、这里就是先取到第二行的地址,然后对其解引用,那么就是求整个第二行的大小,那么结果 为16字节。
8、这里先取得第一行的地址,然后对其进行+1操作,此时就跳过第一行到第二行,得到的是第 二行的地址,那么其本质就是地址,那么其大小就为4或8字节。
9、这里先是取得第一行的地址,然后进行+1操作得到第二行的地址,然后对其解引用,那么其 就是求第二行的大小,那么其结果就是16。
10、这里的a相当于二维数组的第一行,那么再解引用,那么就是求的第一行的大小,那么其大 小就是16。
11、这里的话a[3]越界访问了,因为我们的二维数组是三行的,没有第四行,但是程序会帮我 们越界去访问,会计算出和第三行相同结构的数组,那么其计算出来的大小就和第三行一 样,那么其结果就为16。
下面我们来看看其运行结果(64位环境下):
总结:
1、sizeof(数组名),这里的数组名表示整个数组,计算的是整个数组的大小。
2、&数组名,这里的数组名表示整个数组,取得的是整个数组的地址
3、除此之外的数组名都表示的地址
三、指针运算的笔试题
代码1
我们看整个代码主要是prt的部分比较难,那么我们先看这个指针到底是啥,首先其是先对a 取地址,然后进行+1操作,然后将其强制类型转换位(int*)类型,这个强制类型转换的目的 是啥呢?一开始其没转换类型的话,对其进行 +1操作的话是跳过整个数组的大小,现在对其 强制类型转换后,其+1操作跳过的空间就是一个int类型的空间了。
然后我们看看*(a+1)a是首元素地址,那么对其+1就是第二个元素的地址了,再对其解引用那 么就是第二个元素了,那么第一个输出的就是第二个元素2。
然后就是*(prt-1),此时的prt是指向的数组的后一个地址,也就是数组最后一个元素的下一个地 址,然后此时的prt的指针类型为(int*)型,那么其-1的话是往前移动一个int的位置,那么此 时其指向的地址就是数组的最后一个元素了。那么其输出的结果就是5。
最后我们看看其运行结果:
代码2
我们先看第一个p+1,首先可以看到p是一个结构体指针,而且其给赋为100000,然后+1后就 会跳过整个结构体,那么其结果就为100020。
然后我们看第二个(unsigned long+1)p+1,这里先对p进行了强制类型转换,其被转换为了无 符号长整型,那么此时p就是一个数字了,+1就是对其进行数字的加减法,此时就是100001 了。
我们来看最后一个,其将p强制转换为(unsigned int *)类型的,这里其实就是将其转换为整 型指针了,那么对其+1就是跳过4个字节,那么结果就是100004。
下面我们来看看其运行结果:
代码3
这里我们先看看这个数组中存放的是啥,一开始我们很多人可能会以为这是个点坐标,或 者是一行的两个元素,其实都不是,一行的元素我们也是用一个大括号{}放在一起的,其实 小括号里面的是一个逗号表达式,第一个的结果是1,第二个的结果是3,第三个的结果是 5。
那么其二维数组是第一行的元素是1,3。第二行的是5,后面的元素是空的。
然后再将a[0]也就是数组的第一行的数组名赋个指针变量p,那么此时的指针变量p就相当于 二维数组第一行的数组名 ,那么p[0]就相当于第一行的第一个元素1。
下面我们看看其运行结果:
代码4
这里的p是一个元素个数为4个的整型数组指针,然后a是a这个数组的首元素地址,这里 将a赋给p会发生强制类型转换。相当于p接收了a存放的地址,不过它的类型强制转换 了,使得其一次只能跳过四个元素,,而我们的a可以一次跳过五个元素,下面我们通过 画图来理解:
可以看到p[4][2]要比a[4][2]要前四个位置所以其减出来是-4,然后第一个我们是用的p占 位符,所以其输出的是补码。,然后后面的那个就是-4了。
下面为其运行结果:
相关文章:
【c语言】指针 (完结)
一、sizeof和strlen的对比 1、sizeof 前面我们在学习操作符的时候,我们学习了sizeof,知道其是计算变量所占内存的大小的,单 位是字节,如果操作数是数据类型的话,计算的就是这个类型的变量所占的内存空间的大…...
vue使用自动化导入api插件unplugin-auto-import,避免频繁手动导入
unplugin-auto-import是一个现代的自动导入插件,旨在简化前端开发中的导入过程,减少手动导入的繁琐工作,提升开发效率。它支持多种构建工具,包括Vite、Webpack、Rollup和esbuild,并且可以与TypeScript配合使用&…...
matlab函数讲解——randsample
在MATLAB中,randsample函数用于从一个给定的集合中随机选择样本。函数的基本用法是从指定范围内随机选择元素,具体用法如下: 用法 y randsample(n, k, true, w)参数说明 n: 整数,表示从1到n的集合中进行抽样。例如,…...
50_Lua垃圾回收
1.Lua垃圾回收机制概述 Lua采用了一种自动内存管理机制,称为垃圾回收(Garbage Collection, GC)。垃圾回收的主要目的是回收程序中不再被使用的内存,从而避免内存泄漏。Lua的垃圾回收器负责回收动态分配的对象,如函数、用户数据、表、字符串、线程、内部结构等。Lua的垃圾…...
【Python】数据容器:列表,元组,字符串,集合字典及通用操作
文章目录 一.序列1.1list列表定义常用操作列表的遍历 1.2tuple元组定义常见操作元组的遍历 1.3str字符串定义常见操作字符串的遍历 1.4序列常用操作——切片 二.set集合定义常见操作集合的遍历 三.dict字典定义常用操作字典的嵌套 *数据容器对比总结四.数据容器的通用操作4.1通…...
Wi-Fi Direct (P2P)原理及功能介绍
目录 Wi-Fi Direct (P2P)介绍Wi-Fi Direct P2P 概述P2P-GO(P2P Group Owner)工作流程 wifi-Direct使用windows11 wifi-directOpenwrtwifi的concurrent mode Linux环境下的配置工具必联wifi芯片P2P支持REF Wi-Fi Direct ÿ…...
系统看门狗配置--以ubuntu为例
linux系统配置看门狗 以 ubuntu 系统配置看门狗为例 配置看门狗使用的脚本文件,需要使用管理员权限来执行: 配置是:系统每 30S 喂一次狗,超过 60S 不进行投喂,就会自动重启。 1. 系统脚本内容: #!/bin/b…...
Mysql--基础篇--多表查询(JOIN,笛卡尔积)
在MySQL中,多表查询(也称为联表查询或JOIN操作)是数据库操作中非常常见的需求。通过多表查询,你可以从多个表中获取相关数据,并根据一定的条件将它们组合在一起。MySQL支持多种类型的JOIN操作,每种JOIN都有…...
44_Lua迭代器
在Lua中,迭代器是一种用于遍历集合元素的重要工具。掌握迭代器的使用方法,对于提高Lua编程的效率和代码的可读性具有重要意义。 1.迭代器概述 1.1 迭代器介绍 迭代器是一种设计模式,它提供了一种访问集合元素的方法,而不需要暴露其底层结构。在Lua中,迭代器通常以一个函…...
网络原理(三)—— 传输层 之 UDP 和 TCP协议
传输层 在传输层两大关键的协议就是UDP和TCP协议了,除此之外,还有别的传输层协议,本文章将介绍UDP和TCP协议,重点介绍TCP协议。 首先回顾TCP和UDP 的特点: UDP:不可靠传输,面向数据包…...
Swin Transformer模型详解(附pytorch实现)
写在前面 Swin Transformer(Shifted Window Transformer)是一种新颖的视觉Transformer模型,在2021年由微软亚洲研究院提出。这一模型提出了一种基于局部窗口的自注意力机制,显著改善了Vision Transformer(ViT…...
opencv进行人脸识别环境搭建
1. 构建人脸识别环境 1) 下载安装opencv 下载地址:Releases - OpenCV 参考博文:OpenCV下载安装教程(Windows)-CSDN博客 下载对应系统的opencv,如windows版,opencv-4.5.5-vc14_vc15.exe 2) 然后解压缩到…...
java小灶课详解:关于char和string的区别和对应的详细操作
char和string的区别与操作详解 在编程语言中,char和string是用于处理字符和字符串的两种重要数据类型。它们在存储、操作和应用场景上存在显著差异。本文将从以下几个方面详细解析两者的区别及常见操作。 1. 基本定义与存储差异 char: 定义:…...
计算机网络之---RIP协议
RIP协议的作用 RIP (Routing Information Protocol) 协议是一个基于距离矢量的路由协议,它在网络中用来动态地交换路由信息。RIP 是最早的路由协议之一,通常用于小型和中型网络中。它的工作原理简单,易于实现,但在一些大型网络中效…...
F#语言的文件操作
F#语言的文件操作 F#是一种功能性编程语言,运行在.NET平台上,特别适合处理并发和复杂的数据处理任务。在这篇文章中,我们将介绍F#语言中的文件操作,包括读取、写入和管理文件的基本方法。通过实例来帮助理解,适合初学…...
微信小程序开发设置支持scss文件
在微信小程序开发中,默认是不支持scss文件的,创建文件的时候,css文件默认创建的是wxss后缀结尾的,但是用习惯了scss的怎么办呢? 首先找到project.config.json文件,打开文件在setting下设置useCompilerPlug…...
【Excel笔记_3】execl的单元格是#DIV/0!,判断如果是这个,则该单元格等于空
在 Excel 中,可以使用 IF 函数来判断单元格是否是 #DIV/0! 错误,并将其替换为空值(即空字符串 "")。具体公式如下: IF(ISERROR(A1), "", A1)或者,如果只想判断 #DIV/0! 错误ÿ…...
51单片机入门基础
目录 一、基础知识储备 (一)了解51单片机的基本概念 (二)掌握数字电路基础 (三)学习C语言编程基础 二、开发环境搭建 (一)硬件准备 (二)软件准备 三、…...
设计模式 行为型 访问者模式(Visitor Pattern)与 常见技术框架应用 解析
访问者模式(Visitor Pattern)是一种行为设计模式,它允许你在不改变元素类的前提下定义作用于这些元素的新操作。这种模式将算法与对象结构分离,使得可以独立地变化那些保存在复杂对象结构中的元素的操作。 假设我们有一个复杂的对…...
stable diffusion 量化学习笔记
文章目录 一、一些tensorRT背景及使用介绍1)深度学习介绍2)TensorRT优化策略介绍3)TensorRT基础使用流程4)dynamic shape 模式5)TensorRT模型转换 二、TensorRT转onnx模型1)onnx介绍2)背景知识&…...
金融项目实战 04|JMeter实现自动化脚本接口测试及持续集成
目录 一、⾃动化测试理论 二、自动化脚本 1、添加断言 1️⃣注册、登录 2️⃣认证、充值、开户、投资 2、可重复执行:清除测试数据脚本按指定顺序执行 1️⃣如何可以做到可重复执⾏? 2️⃣清除测试数据:连接数据库setup线程组 ①明确…...
无需昂贵GPU:本地部署开源AI项目LocalAI在消费级硬件上运行大模型
无需昂贵GPU:本地部署开源AI项目LocalAI在消费级硬件上运行大模型 随着人工智能技术的快速发展,越来越多的AI模型被广泛应用于各个领域。然而,运行这些模型通常需要高性能的硬件支持,特别是GPU(图形处理器)…...
selenium学习笔记
一.搭建环境 1.安装chrome #下载chrome wget https://dl.google.com/linux/direct/google-chrome-stable_current_amd64.deb#安装chrome apt --fix-broken install ./google-chrome-stable_current_amd64.deb2.安装chromedriver 首先先查看版本:google-chrome --…...
SOME/IP协议详解 基础解读 涵盖SOME/IP协议解析 SOME/IP通讯机制 协议特点 错误处理机制
车载以太网协议栈总共可划分为五层,分别为物理层,数据链路层,网络层,传输层,应用层,其中今天所要介绍的内容SOME/IP就是一种应用层协议。 SOME/IP协议内容按照AUTOSAR中的描述,我们可以更进一步…...
nginx 实现 正向代理、反向代理 、SSL(证书配置)、负载均衡 、虚拟域名 ,使用其他中间件监控
我们可以详细地配置 Nginx 来实现正向代理、反向代理、SSL、负载均衡和虚拟域名。同时,我会介绍如何使用一些中间件来监控 Nginx 的状态和性能。 1. 安装 Nginx 如果你还没有安装 Nginx,可以通过以下命令进行安装(以 Ubuntu 为例࿰…...
基于单片机的智能花卉浇水系统的设计与实现
摘要: 随着人们生活水平的不断提高,生活节奏也越来越快。人们经常忽视办公室或者家居的花卉,忘记浇水。本文设计了一种基于单片机的智能浇水系统。目的是解决养殖花卉的人忘记浇水的问题。本系统以单片机AT89S52为控制芯片,能够按…...
《使用 YOLOV8 和 KerasCV 进行高效目标检测》
《使用 YOLOV8 和 KerasCV 进行高效目标检测》 作者:Gitesh Chawda创建日期:2023/06/26最后修改时间:2023/06/26描述:使用 KerasCV 训练自定义 YOLOV8 对象检测模型。 (i) 此示例使用 Keras 2 在 Colab 中…...
【Domain Generalization(3)】领域泛化与文生图之 -- QUOTA 任意领域中的生成物体的数量可控
系列文章目录 【Domain Generalization(1)】增量学习/在线学习/持续学习/迁移学习/多任务学习/元学习/领域适应/领域泛化概念理解第一篇了解了 DG 的概念,那么接下来将介绍 DG 近年在文生图中的相关应用/代表性工作。【Domain Generalization(2)】领域泛化在文生图…...
qml XmlListModel详解
1、概述 XmlListModel是QtQuick用于从XML数据创建只读模型的组件。它可以作为各种view元素的数据源,比如ListView、GridView、PathView等;也可以作为其他和model交互的元素的数据源。通过XmlRole定义角色,如name、age和height,并…...
CAPL如何设置TCP/IP传输层动态端口范围
在TCP/IP协议中,应用程序通过传输层协议TCP/UDP传输数据,接收方传输层收到数据后,根据传输层端口号把接收的数据上交给正确的应用程序。我们可以简单地认为传输层端口号是应用程序的标识,这就是为什么我们说应用程序在使用TCP/IP协议通信时要打开传输层端口号或者绑定端口号…...
Pandas常用数据类型
扩展库pandas常用的数据结构如下: (1)Series:带标签的一维数组 (2)DatetimeIndes:时间序列 (3)DateFrame:带标签且大小可变的二维表格结构 (4…...
【AI大模型】BERT GPT ELMo模型的对比
目录 🍔 BERT, GPT, ELMo之间的不同点 🍔 BERT, GPT, ELMo各自的优点和缺点 🍔 小结 学习目标 理解BERT, GPT, ELMo相互间的不同点理解BERT, GPT, ELMo相互比较下的各自优点和缺点 🍔 BERT, GPT, ELMo之间的不同点 关于特征提取…...
探索AGI:智能助手与自我赋能的新时代
目录 1 AGI1.1 DeepMind Levels(2023年11月)1.2 OpenAI Levels(2024年7月)1.3 对比与总结1.4 AGI可能诞生哪里 2 基于AI的智能自动化助手2.1 通用型大模型2.2 专业的Agent和模型工具开发框架2.3 编程与代码生成助手2.4 视频和多模态生成2.5 商…...
Oracle Dataguard(主库为双节点集群)配置详解(5):将主库复制到备库并启动同步
Oracle Dataguard(主库为双节点集群)配置详解(5):将主库复制到备库并启动同步 目录 Oracle Dataguard(主库为双节点集群)配置详解(5):将主库复制到备库并启动…...
webrtc自适应分辨率的设置
DegradationPreference 是一个枚举类,用于在视频编码或实时通信(如 WebRTC)中指定系统资源不足时如何处理质量下降的策略。以下是该枚举类的中文解释: enum class DegradationPreference {// 禁用:不根据资源过载信号…...
提供的 IP 地址 10.0.0.5 和子网掩码位 /26 来计算相关的网络信息
网络和IP地址计算器 https://www.sojson.com/convert/subnetmask.html提供的 IP 地址 10.0.0.5 和子网掩码位 /26 来计算相关的网络信息。 子网掩码转换 子网掩码 /26 的含义二进制表示:/26 表示前 26 位是网络部分,剩下的 6 位是主机部分。对应的子网掩码为 255…...
WPF系列八:图形控件Path
简介 Path控件支持一种称为路径迷你语言(Path Mini-Language)的紧凑字符串格式,用于描述复杂的几何图形。这种语言通过一系列命令字母和坐标来定义路径上的点和线段,最终绘制出想要的图形。 绘制任意形状:可以用来绘…...
如何移除git中被跟踪的commit文件
忽略已被跟踪的文件 问题描述 如果某个文件已经被 Git 跟踪(即已被提交到仓库),即使后来将其添加到 .gitignore 文件中,Git 仍会继续跟踪它。 解决方案 更新 .gitignore 文件 将需要忽略的文件加入 .gitignore: .env…...
15. C语言 函数指针与回调函数
本章目录: 前言什么是函数指针?定义声明方式 函数指针的基本用法示例:最大值函数输出示例: 回调函数与函数指针什么是回调函数?通俗解释 示例:回调函数实现动态数组填充输出示例: 进一步探索:带…...
tomcat12启动流程源码分析
信息: Server.服务器版本: Apache Tomcat/12.0.x-dev 信息: Java虚拟机版本: 21下载源码https://github.com/apache/tomcat,并用idea打开,配置ant编译插件,或者使用我的代码 启动脚本是/bin/startup.bat,内部又执行了bin\cata…...
Pycharm 使用教程
一、基本配置 1. 切换Python解释器 pycharm切换解释器版本 2. pycharm虚拟环境配置 虚拟环境的目的:创建适用于该项目的环境,与系统环境隔离,防止污染系统环境(包括需要的库)虚拟环境配置存放在项目根目录下的 ven…...
数据仓库: 9- 数据仓库数据治理
目录 9- 数据治理9.1 数据标准化9.1.1 数据标准化的定义9.1.2 数据标准化的重要性9.1.3 数据标准化的主要内容9.1.4 数据标准化的实施步骤9.1.5 数据标准化常用工具9.1.6 数据标准化的挑战与应对策略9.1.7 案例分析9.1.8 总结 9.2 主数据管理(MDM)9.2.1 主数据管理的核心目标9.…...
Kutools for Excel 简体中文版 - 官方正版授权
Kutools for Excel 是一款超棒的 Excel 插件,就像给你的 Excel 加了个超能助手。它有 300 多种实用功能,现在还有 AI 帮忙,能把复杂的任务变简单,重复的事儿也能自动搞定,不管是新手还是老手都能用得顺手。有了它&…...
回归预测 | MATLAB实MLR多元线性回归多输入单输出回归预测
回归预测 | MATLAB实MLR多元线性回归多输入单输出回归预测 目录 回归预测 | MATLAB实MLR多元线性回归多输入单输出回归预测预测效果基本介绍程序设计参考资料 预测效果 基本介绍 回归预测 | MATLAB实MLR多元线性回归多输入单输出回归预测。 程序设计 完整代码:回…...
lerna使用指南
lerna版本 以下所有配置命令都是基于v8.1.9,lerna v5 v7版本差别较大,在使用时,注意自身的lerna版本。 lerna开启缓存及缓存配置 nx缓存是v5版本以后才有的,小于该版本的无法使用该功能。 初始化配置 缓存配置文件nx.json&am…...
LightGCN:为推荐系统简化图卷积网络的创新之作
LightGCN: Simplifying and Powering Graph Convolution Network for RecommendationSIGIR2020Collaborative Filtering, Recommendation, Embedding Propagation, Graph Neural Network 🌟 研究背景 在信息爆炸的互联网时代,个性化推荐系统成为缓解信…...
【图像去噪】论文精读:High-Quality Self-Supervised Deep Image Denoising(HQ-SSL)
请先看【专栏介绍文章】:【图像去噪(Image Denoising)】关于【图像去噪】专栏的相关说明,包含适配人群、专栏简介、专栏亮点、阅读方法、定价理由、品质承诺、关于更新、去噪概述、文章目录、资料汇总、问题汇总(更新中) 文章目录 前言Abstract1 Introduction2 Convoluti…...
Elasticsarch:使用全文搜索在 ES|QL 中进行过滤 - 8.17
8.17 在 ES|QL 中引入了 match 和 qstr 函数,可用于执行全文过滤。本文介绍了它们的作用、使用方法、与现有文本过滤方法的区别、当前的限制以及未来的改进。 ES|QL 现在包含全文函数,可用于使用文本查询过滤数据。我们将回顾可用的文本过滤方法…...
17.C语言输入输出函数详解:从缓存原理到常用函数用法
目录 1.前言2.缓存和字节流3.printf4.scanf5.sscanf6.getchar与putchar7.puts与gets 1.前言 本篇原文为:C语言输入输出函数详解:从缓存原理到常用函数用法。 更多C进阶、rust、python、逆向等等教程,可点击此链接查看:酷程网 C…...
高等数学学习笔记 ☞ 不定积分与积分公式
1. 不定积分的定义 1. 原函数与导函数的定义: 若函数可导,且,则称函数是函数的一个原函数,函数是函数的导函数。 备注: ①:若函数是连续的,则函数一定存在原函数,反之不对。 ②&…...