首页
学习
活动
专区
圈层
工具
发布

初识指针(指针和指针变量、如何理解地址、指针类型的意义、void*指针、野指针、空指针)(笔记)

四、指针类型的意义(为什么不用ptr_t p代表所有指针) 1.指针解引用的时候有多大权限 (如果一个指针代替所有的话,解引用时的字节与变量定义类型不同) 2.指针类型决定了指针向前或向后走一步有多大...:无具体指针(泛型指针) 这种类型的指针可以用来接受任意类型的地址,但也有局限性, void*类型的指针,局限性在于他不能直接进行指针的+-整数和解引用的运算 有什么用: 一般void*类型的指针是使用在函数参数的部分...,用来接收不同数据类型的地址, 这样可以实现泛型编程的效果,使得一个函数来处理多种类型的数据 注意: void*类型的指针不能直接进行解引用的操作 void* 类型的指针也不能进行指针计算的操作...//pv++;//err void* 类型的指针也不能加减一的操作 return 0; } 六、野指针: 指针指向的位置是不可知的(随机的,不正确的,没有明确限制的) 使用完指针后未将其置为NULL...七、空指针 空指针是一个特殊的数据类型,它的值定义为NULL。空指针不同于NULL的整数表示,它是一个指针变量的特殊值,表示该指针变量不指向任何有效的内存地址。

71610
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    【C语言指针超详解(一)】--指针变量和地址,指针变量类型的意义,指针运算

    2.2.2--如何理解指针类型 我们看到指针变量的类型是int*,我们该如何理解指针的类型呢?...三.指针变量类型的意义 --在上面的学习中我们知道了指针变量的大小和类型无关,那为什么还有各种各样的指针类型呢,其实指针类型是有其特殊意义的,我们接着往下看把。...这就是指针变量类型差异带来的变化。指针+1,其实就是跳过1个指针指向的元素。指针可以+1,那也可以-1。 结论:指针的类型决定了指针向前或者向后走一步有多大(距离)。...3.3--void * 指针 --在指针类型中有一种特殊的类型是void*类型的,可以理解为无具体类型的指针(或者叫泛型指针),这种类型的指针可以用来接受任意类型地址。...那void*指针到底有啥用呢,一般void*类型的指针是使用在函数参数的部分,用来接受不同类型数据的地址,这样的设计可以实现泛型编程的效果,使得一个函数来处理多种类型的数据,这个在后续的指针超详解篇中会给大家分享

    24410

    【C 语言】数组 ( 数组指针 | 数组指针定义 | 使用 数组指针类型 定义数组指针 )

    // 然后 , 声明一个 数组指针类型 变量 ArrayPointer p = NULL; 一、使用 数组指针类型 定义数组指针 ---- 使用 数组指针类型 定义数组指针 , 首先 , 使用...typedef 定义一个数组指针类型 , typedef int(*ArrayPointer)[3]; 然后 , 定义一个普通数组 , 之后的 数组指针 指向该数组 , int array2...[3] = {0}; 最后 , 声明一个 数组指针类型 变量 , 将 array2 变量地址赋值给该 数组指针类型 变量 , 指针指向的数据类型为 int[3] 数组类型的变量 array2 ;...// 首先 , 定义 数组指针类型 别名 typedef int(*ArrayPointer)[3]; // 然后 , 定义一个普通数组 , 之后的 数组指针 指向该数组...int array2[3] = {0}; // 最后 , 声明一个 数组指针类型 变量 // 将 array2 变量地址赋值给该 数组指针类型 变量 // 指针指向的数据类型为

    4K10

    【C 语言】指针数据类型 ( 指针步长 | 复杂指针阅读技巧 )

    文章目录 一、指针步长 二、复杂指针阅读技巧 一、指针步长 ---- 指针 也是一种 数据类型 , 其 类型 是 指针 指向的 内存空间 的 数据类型 ; 指针步长 : 根据 指针 指向的 内存空间 数据类型...就在 栈内存 中 , 为其 分配 4 字节数据 ; 使用 : 当在 函数 中 , 使用该指针指向的数据时 , 才关心该指针指向的数据结构 ; 二、复杂指针阅读技巧 ---- 如果遇到复杂指针类型 ,...int) 类型函数的指针, 其指针变量名称写在中间的括号中 ; 3.数组指针混合函数指针 : 如果出现了 数组指针 指向一个函数, 这个指针可读性很差, 理解需要一定的功力 ; 复杂指针阅读技巧 ( 主要是...int* , 即 int 类型指针类型 ( 3 ) 函数类型的 第二个参数是 int (*f)(int*) 也是一个函数类型指针 3....类型, 参数是 int* 指针类型 和 int (*)(int*) 函数指针 类型 指针 f 是一个指向 int(int*) 类型函数的指针, 其返回值是 int 类型, 参数是 int* 指针类型

    63610

    c语言进阶指南(9)(指针与指针类型)

    虽然其他变量也能存储地址值相同的数,但是地址的取值范围和一般的变量取值范围不一样。所以C语言用一个专用来存储地址值的类型的变量,称为指针变量。...指针的声明指针变量的声明与普通变量的声明类似,只是变量类型不同。...这些变量的类型是由存储的地址的变量来决定的char c;int i;long l;float f;double d;char *pc=&c;int *pi=&i;long*pl=&l;float* f=...&f;double* d=&d;指针的类型需要和存储地址变量一致才能完整的对该地址的数据进行操作(后面会介绍不一致时会导致的事情)指针的初始化如果指针只声明不初始化,指针会指向一个随机的区域int *pi.../NULL的值是0,但是地址的最小值都是从1开始的野指针指针指向的是系统中的地址,所以对这些没有初始化的指针(随机地址)进行数据修改是一个很危险的事(特别是对操作系统的数据进行修改)。

    17210

    【C 语言】指针数据类型 ( 野指针 | 避免野指针推荐方案 )

    文章目录 一、野指针 二、避免野指针推荐方案 一、野指针 ---- 参考 【C 语言】内存管理 ( 动态内存分配 | 栈 | 堆 | 静态存储区 | 内存布局 | 野指针 ) 四....野指针 ( 程序BUG根源 ) 博客章节 ; 野指针产生原因 : 指针变量 指向的 内存空间 被释放 , 但是 指针变量 还保存着一个地址值 , 此时不能随便修改该地址值 中的数据 ; 指针变量 与 指针指向的内存空间数据值...是不同的概念 ; 二、避免野指针推荐方案 ---- 避免野指针方法 : 定义指针变量 置空 : 声明 指针变量 时 , 为其设置初始值 NULL ; char *p = NULL; p = (char...*)malloc(10); 释放内存后 指针变量 置空 : 释放 指针变量 指向的内存后 , 立刻将指针变量设置为 NULL ; free(p); p = NULL; 只要 声明指针 , 一律给 指针变量...设置 NULL 初始值 ; 只要 释放指针 , 一律将指针变量设置 NULL ; 这样 使用指针 前 , 判断该 指针变量 是否为 NULL , 就可以判断该指针是否是有效指针 ;

    31820

    以指针进阶:空类型指针与qsort函数

    今天,我们将通过一个具体的题目,深入探讨空类型指针(void*)和C标准库中的qsort函数,帮助大家更好地理解和应用指针的高级特性。...二、知识点分析 (一)空类型指针: void* void*是一种特殊的指针类型,它表示“没有类型”的指针。...void*指针时,通常需要将其转换为具体的类型指针,以便进行解引用或其他操作。...} return 0; } 输出结果 程序的输出结果为: 1 2 3 5 8 9 三、注意事项 (一)void*的类型转换 必须进行类型转换 void*指针不能直接解引用,必须先转换为具体的类型指针...(二)qsort的比较函数 参数类型 比较函数的参数类型为const void*,表示指向数组元素的指针。在比较函数中,需要将void*转换为具体的类型指针。

    22400

    【C 语言】指针数据类型 ( 指针类型变量 | 使用 * 操作内存 )

    文章目录 一、指针类型变量 二、使用 * 操作内存 一、指针类型变量 ---- 指针 也是 变量 , 也占用内存空间 , 可以用于保存 内存地址 ; 测试 指针 变量占用的内存空间大小 : 定义一个 int...* 指针类型变量 , 使用 sizeof 函数 获取该变量的大小 ; 代码示例 : #include #include int main() { int...a = 8; // 声明指针类型变量 int *p = 888; // 声明二级指针类型变量 int **p2 = 8888; // 打印 变量 a , b...: 声明 指针 时 , * 表示声明的变量是指针变量 ; 使用指针 : 使用 指针 时 , * 表示操作 指针 指向的 内存空间 的数据 ; 操作内存 : *p 相当于 通过 指针地址 ( p 变量值...) 找到对应内存首地址 , 根据数据类型大小操作 这块指定大小 的内存 ; 内存赋值 : *p 放在等号左边 , 是给 内存 赋值 ; 内存取值 : *p 放在等号右边 , 是从 内存 取值

    88210

    【C++】函数重载 ④ ( 函数指针定义的三种方式 | 直接定义函数指针 | 通过 函数类型 定义 函数指针 | 通过 函数指针类型 定义 函数指针 )

    的 返回值 不是 " 函数重载 " 的 判断标准 ; 二义性 : 如果 函数重载 与 默认参数 结合使用 , 出现了二义性 , 编译直接失败 ; 函数指针赋值重载函数 : 根据 函数指针 类型中的 参数列表类型...); return_type : 函数指针 指向的函数 的 返回值类型 ; func_ptr : 函数指针 名称 , 使用该 名称 也可以调用函数 , 用法与函数名相同 ; parameter_list..., 定义函数指针 , 直接根据指针的定义语法 指针类型* 指针名称 定义函数指针 , 同时将 add 函数 的 地址 赋值给 函数指针 ; // 根据 函数类型 定义 函数指针 func* func1...= add; 3、通过 函数指针类型 定义 函数指针 首先 , 通过 typedef 关键字, 定义 函数指针 类型 , 类型名称为 func_ptr , 对应的函数的 参数列表是 2 个 int 参数...); 然后 , 通过 func_ptr 函数指针类型 , 定义 函数指针 , 直接使用 变量类型 变量名称 的方式定义 函数指针 ; // 根据 函数指针类型 定义 函数指针 func_ptr func2

    88730

    【C++】函数重载 ④ ( 函数指针定义的三种方式 | 直接定义函数指针 | 通过 函数类型 定义 函数指针 | 通过 函数指针类型 定义 函数指针 )

    的 返回值 不是 " 函数重载 " 的 判断标准 ; 二义性 : 如果 函数重载 与 默认参数 结合使用 , 出现了二义性 , 编译直接失败 ; 函数指针赋值重载函数 : 根据 函数指针 类型中的 参数列表类型...); return_type : 函数指针 指向的函数 的 返回值类型 ; func_ptr : 函数指针 名称 , 使用该 名称 也可以调用函数 , 用法与函数名相同 ; parameter_list..., 定义函数指针 , 直接根据指针的定义语法 指针类型* 指针名称 定义函数指针 , 同时将 add 函数 的 地址 赋值给 函数指针 ; // 根据 函数类型 定义 函数指针 func* func1...= add; 3、通过 函数指针类型 定义 函数指针 首先 , 通过 typedef 关键字, 定义 函数指针 类型 , 类型名称为 func_ptr , 对应的函数的 参数列表是 2 个 int 参数...); 然后 , 通过 func_ptr 函数指针类型 , 定义 函数指针 , 直接使用 变量类型 变量名称 的方式定义 函数指针 ; // 根据 函数指针类型 定义 函数指针 func_ptr func2

    87230

    【C 语言】数组 ( 数组指针 | 数组指针定义 | 使用 数组类型* 定义数组指针 )

    文章目录 总结 一、使用 数组类型* 定义数组指针 二、完整代码示例 总结 typedef int(ArrayType)[3]; ArrayType *p = NULL; 一、使用 数组类型...* 定义数组指针 ---- 数组类型指针 就是 定义一个指针 , 指向数组首地址 ; 使用 数组类型* 定义数组指针 , 首先 , 定义数组类型 别名 , typedef int(ArrayType...)[3]; 然后 , 使用别名类型 , 声明数组变量 , ArrayType array2 = {0}; 最后 , 声明一个指针 , 将 array2 变量地址赋值给该指针 , 指针指向的数据类型为...int[3] 数组类型的变量 array2 ; ArrayType *p = NULL; p = &array2; 验证上述 定义的数组指针 : 为 数组元素 赋值 , //...// 最后 , 声明一个指针 , 将 array2 变量地址赋值给该指针 // 指针指向的数据类型为 int[3] 数组类型的变量 array2 ArrayType *p = NULL;

    4.4K20

    指针+数组指针+字符指针+指针数组

    指针 指针作为C语言的核心部分,相比较其他的内容相对比较难懂一下,应用的方式多样,变化较多,导致很多的同学非常苦恼,那么接下来,我将陪你来共同揭开指针的神秘面纱; 指针的含义 大家不要把指针想的太难,指针其实就是通过地址找到对应的变量的位置...,然后我们可以对地址进行解引用来访问变量的内存,来获取值的一种间接方法;我们通常说指针指向哪里哪里,就是指针变量里面存的其他变量(或者常量)的地址;即  指针->地址->内存; 普通变量指针 首先,我们现来看看指针的构成以及表达形式...,而前面的 int 是指针变量p 要指向的变量的类型; 例如: #include int main() { int *p,i;//定义整形指针变量p,和普通变量i; p=...(这里的+1是将地址向后移动一位)数组名的地址+1后,我们发现增加了4个字节也就是一个整形的大小,而此时确实是指向了数组内第二个元素的地址,步长是一个元素类型所占字节数,也就是指向了下一个元素; 2.我们看后面两行...,(3个地址),p的前面加上一个*,就是指针,那就是指针数组啦, 总结:1.指针数组的形如*p[n]的数组,而数组指针是指针指向的是数组,形如(*p)[n],里面存的不是数组首元素的地址,而是整个数组的地址

    51410

    【C 语言】指针数据类型 ( 指针类型变量 与 指针指向的内存块 概念区别 | 指针赋值 | 指针运算 | 内存赋值 | 内存取值 | 内存修改注意事项 )

    文章目录 一、指针类型变量 与 指针指向的内存块 概念区别 1、指针赋值 2、指针运算 3、内存赋值 4、内存取值 5、内存修改注意事项 一、指针类型变量 与 指针指向的内存块 概念区别 ---- 指针类型变量...与 指针指向的内存块 概念区别 : 给定一个指针类型变量 : // 定义一个普通整型变量 int a = 888; // 声明 指针类型变量 // 将整型变量地址赋值给指针类型变量 int *p =..., p + 1 与 p++ 的计算结果是指针的地址值加上指针类型对应的字节大小值 , 如果是 int 类型的指针 , 则增加 4 字节 ; 3、内存赋值 ** 给指针指向的内存赋值 * 给上述指针变量...p 指向的内存 进行赋值操作 , 如 *p = 0x7F451D12 , 不会改变指针变量 p 的值 , 只会改变指针变量 p 原来指向的 内存块 中存储的值 ; 4、内存取值 指针指向的内存赋值与取值...修改内存注意事项 : 给指针赋值时 , 要 确保指针指向的 内存 可以修改 , 全局数据区 中的 常量区 的值 不能修改 , 代码区 中的值不能修改 , 堆区 和 栈区 中的值 , 即使能修改 , 也要确保指针是正确的

    3.2K20

    【C++】函数指针 ④ ( 函数指针做函数参数 | 使用函数指针间接调用函数 | 函数指针做参数 | 函数指针类型的本质 | 函数指针做参数意义 )

    , 调用的函数可以动态指定 ; 2、函数指针做参数 定义了 如下 函数指针类型 pFun_add , 其类型为 int (*)(int, int) , 该指针指向一个 类型为 int (int, int..., int); 定义函数 接收 pFun_add 类型的形参作为参数 , 该类型是 函数指针类型 , 也就是 函数接收一个 函数指针类型参数 , 在该函数中调用 函数指针 指向的 函数 ; // 传入函数指针...动态传入 ; 函数指针类型 的该用法 是框架的基础 , 将 函数执行逻辑 与 软件框架 进行解耦 ; 也就是 将 任务调用者 与 任务实现者 进行了隔离 , 解耦合 ; 下面的示例中 , 可以将 函数指针类型变量...函数名 ( 函数地址 ) 作为 函数指针 参数 // 传递给函数 caculate(add, 11, 12); 3、函数指针类型的本质 函数指针类型 本质 : 提前对任务 格式 进行约定 ; 函数参数类型...约定了 函数的 参与者 ; 函数返回值类型 约定了 函数的 执行结果 ; 只要 将 子任务 按照 上述 " 函数指针类型 " 的约定 , 开发出 符合要求 的 函数 , 就可以将其作为一个 子任务 传递到

    3.4K50

    【Android FFMPEG 开发】FFMPEG 方法中指针类型参数说明 ( 一维指针类型参数 | 二维指针类型参数 )

    一维指针类型参数 II . 二维指针类型参数 I . 一维指针类型参数 ---- 1 ....) 结构体指针是不能造成影响的 , 这种操作无意义 ; ③ 传入的一维指针要求 : 这种情况下传入的指针必须经过初始化才行 , 在方法中只修改指针指向结构体的元素的值 ; 3 ....: 对传入的 AVPacket *pkt 指针参数的地址进行修改没有意义 , 在方法中如果修改了传入的指针的地址 , 仅仅是将传入的副本的值改变了 , 之后的一系列修改都是针对一个副本的值进行的 ;...*pkt 参数的一维指针 ( 副本值 ) 修改该内存中的值 , 那么该内存中的值会被改变 , 此时外部指针 AVPacket *avPacket 指针指向的内存的值也会被改变 ; 5 ....二维指针类型参数 ---- 1 .

    62630

    CCPP 指针变量 | 数组指针 | 指针数组 | 野指针 | 空指针

    普通变量和指针变量 共性 PS: 可见这4个函数的汇编指令完全一致,无论是什么类型的指针变量,对指针变量的读写跟普通变量没有任何区别,所谓的指向只是描述指针变量的值时多少而已,就读写而言,指针变量跟普通变量没有任何区别...,这样很危险,但如果养成将指针初始化为空指针的习惯,我们就能判断出这个指针是不是有效的(判断是不是NULL就可以了)通用指针一般都用在函数传参,实现所谓的“多态”,但到函数里面使用时,一般还是被转换成具体类型的指针...指针变量的+-运算 指针变量的加减运算:也就是做地址偏移,不同 的指针类型偏移的步长不同。...*类型的实体。...p是一个指针a是一个二维数组,需要用数组指针接收。 详细分析: int *p: p的类型是int*一级指针,大小4个字节,p存放的是一个整形地址。

    2.2K30
    领券