C 指针

mac2026-03-01  7

参考连接:https://www.runoob.com/cprogramming/c-pointers.html 1.可以用来简化程序的执行 2.有一些功能如动态分配内存,指针是必不可少的

指针的声明

同其他数据类型一样,指针也是C中的一个数据类型,所以你必须在使用之前声明type *ip_name其中type是指针储存的地址中的数据类型的基类型,但是无数数据类型是什么,int、long、double、float、对应的指针类型都是一样的,都是一个代表内存地址长的16进制数。

指针的使用

1.声明一个指针类型 2.把变量地址赋给指针 3.访问指针变量中可用的地址的值 注意使用&变量来返回变量的地址,对于普通的变量,直接通过变量名来访问他的值,而对于指针变量也是这样,直接通过变量名会访问到他的变量值,即地址,如果想要访问他储存的地址的值,就通过 *ip

#include <stdio.h> int main () { int var = 20; /* 实际变量的声明 */ int *ip; /* 指针变量的声明 */ ip = &var; /* 在指针变量中存储 var 的地址 */ printf("Address of var variable: %p\n", &var ); /* 在指针变量中存储的地址 */ printf("Address stored in ip variable: %p\n", ip ); /* 使用指针访问值 */ printf("Value of *ip variable: %d\n", *ip ); return 0; }

空指针NULL

声明指针的时候,如果没有确切的地址去赋值,就将NULL赋给指针变量 空指针是一个定义在标准库中值为0的常量

指针的算术运算

参考链接:https://www.runoob.com/cprogramming/c-pointer-arithmetic.html C指针是一个用数值表示的地址,因此你可以对指针执行数学运算:++、--、+、- 假设ptr是一个指针,ptr++的结果根据ptr指向的数据类型的不同而有不同的结果 这个不同的结果是因为不同的数据类型的长度不同而造成的如int大小为4字节,char为1字节

//如果ptr指向int的一个变量,假设此时地址为1000 ptr++;//结果为1004,因为++会移动到下一个内存位置,而不是下一个内存地址 //如果ptr指向char一个变量,地址仍为1000 ptr++//结果为1001

递增一个指针

因为指针可以递增,而数组不能递增,所以使用指针代替数组 数组可以看作为一个指针常量,数组名为数组第一个元素的地址,数组中的元素是顺序存放的

递减一个指针

指针的比较

指针可以用关系运算符进行比较,如 ==、< 和 >,但是好像是比较地址的高低?

指针数组

普通的数组用来储存不同类型的值,如果需要定义储存指针的数组type *ptr[MAX]//定义个数为MAX个指向type类型的指针数组,

指向指针的指针

这种指向指针的指针称为间接寻址的方式,又被称为指针连,

声明

必须在指针面前放置两个*号

int **ptr//声明了一个指向 int 类型指针的指针

使用

在使用的时候也必须通过两个*号来访问实际值

最新回复(0)