杭州有实力的网站开发,wordpress 导出,微信开发者工具代码,钢铁行业公司网站模板指针定义#xff1a;
指针是一种数据类型#xff0c;使用它可以用来定义指针变量#xff0c;指针变量中存储的其实是整数#xff0c;这种整数代表了内存的编号。指针的使用#xff1a;
1、函数之间相独立#xff0c;但有些时候需要共享变量。传参是值传递全局变量容易命…指针定义
指针是一种数据类型使用它可以用来定义指针变量指针变量中存储的其实是整数这种整数代表了内存的编号。指针的使用
1、函数之间相独立但有些时候需要共享变量。传参是值传递全局变量容易命名冲突使用数组还需要传递长度命名空间是独立的但地址空间是同一个所有指针可以解决这个问题。
2、由于函数之间传参是值传递(内存拷贝)对于字节数比较多的变量值传递效率较低如果传递变量的地址只需要传递4|8字节。3、堆内存无法取名字它不能像data、bss、stack让变量名与内存建立联系只能使用指针记录堆内存的地址来使用堆内存。指针使用方法
定义类型* 变量名_p;1、指针变量与普通变量的用法有很大区别建议在取名以p结尾加心区分。2、指针变量与普通变量一样默认值是随机的一般初始为 NULL。3、指针的类型决定了它可以访问多少个字节。4、一个*只能定义一个指针变量。int* p1,p2,p3; // 只有p1 是指针变量p2,p3都是int类型变量int *p1,*p2,*p3; // p1 p2 p3都是指针变量
赋值变量名_p 地址;指向栈内存:int* p num;指向堆内存:int* p malloc(4);
解引用*p空指针变量中记录的内存编号去访问内存该过程可能产生段错误原因是里面存储的内存编号是非法的。注意访问的字节数由指针变量的类型决定。练习1、实现一个变量交换函数调用它对一个数组进行排序。void swap(int* p1,int* p2);练习2、实现个函数计算两个整数的最大公约数和最小公倍数最大公约数用return返回最小公倍数使用指针处理。3 6 33 6 6要注意的问题
空指针值为NULL的指针变量叫空指针如果进行解引用就会产生段错误。NULL也是一种错误标志如果一个函数返回值是指针类型当函数执行出错返回值就是NULL。如何避免空指针带来的段错误使用来历不明的指针前做一判断。1、当函数的参数是指针别人传给你的就有可能是空指针。2、从函数获取的返回值也可能是空指针。if(NULL p)注意NULL在绝大多数系统中是0在个别系统中是1。野指针指向不确定的内存空间。解引用野指针的后果1、段错误2、脏数据3、一切正常野指针比空指针的危害更严重因它无法判断出来而且可能是隐藏型的错误短时间内不暴露出来。所有的野指针都是程序员自己制造出来的如何避免产生野指针1、定义指针变量时一定初始化。2、函数不返回栈内存的地址。3、指针指向的内存释放后指针变量要及时置空。指针运算
指针变量中存储的是整数理论上整型数据可以使用的运算符它都可以用但大多数运算都无意义的。
指针n 宽度*n指针 前面n个元素
指针-n 指针-宽度*n 后退n个元素
指针-指针 (指针-指针)/宽度 计算出两个指针之间相隔多少个元素const与指针
const int* p; 指针所指向的内存不可修改。当我们为了提高传参的效率而使用指针时传参的效率高了但变量也有被修改的风险这种写法可以保护指针所指向的内存。
int const *p; 同上
int * const p; 指针变量不可被修改
const int* const p; 指针变量和指针所指向的内存都不可修改。
int const * const p; 同上指针数组与数组指针
指针数组就是由指针组成的数组它的成员是指针变量。类型* arr[长度];
数组指针专门指针数组的指针。类型 (*arr)[长度];指针与数组名
数组名是一种特殊的指针它是常量不能修改它的值它与数组的内存是映射关系。数组名 数组名指针变量有自己的存储空间如果它存储是数组的首地址指针可以当数组使用数组名也可以当指针使用。数组名[i] *(数组名1)数组作为函数的参数时入脱变成了指针所以长度丢失。二级指针
二级指针就是指向指针的指针里面存储的是指针变量的地址。
定义类型** 变量名_pp;
赋值变量名 指针;
解引用*变量名 指针**变量名 *指针函数指针
函数名就个地址(整数)它代表函数在代码段中所处的位置。函数指针就是指向函数的指针它里面存储是函数在代码段中所处位置(函数名);typedef 返回值 (*函数指针)(类型1 参数名1,类型2 参数名2...);
函数指针 fp;使用了回调模式的库函数
// 快速排序
void qsort(void *base, size_t nmemb, size_t size,int(*compar)(const void *, const void *));// 二分查找
void *bsearch(const void *key, const void *base,size_t nmemb, size_t size,int (*compar)(const void *, const void *));