本篇文章带来 1. 字符指针 2. 数组指针 3. 指针数组的相关知识详细讲解!
如果您觉得文章不错,期待你的一键三连哦,你的鼓励是我创作的动力之源,让我们一起加油,一起奔跑,让我们顶峰相见!!!
初阶指针 知识点复习:
内存会划分为一个个的内存单元,每个内存单元都有自己独立唯一的编号---这些编号也被称为地址;在C语言中,地址也被称为指针;
指针(地址)需要存储起来,存储在变量中,这个变量就被称为指针变量;
1. 指针就是个变量,用来存放地址,地址唯一标识一块内存空间;
2. 指针的大小是固定的 4/8 个字节( 32 位平台 /64 位平台) (物理电信号转换为数字信号);
3. 指针是有类型,指针的类型决定了指针的 +- 整数的步长,指针解引用操作的时候的权限;
4. 指针的运算;(指针加减整数,指针减去指针,指针关系运算等)
如有不懂可以在初阶指针进行复习!!!
接下来我们进入进阶指针:
一.字符指针
在指针的类型中我们知道有一种指针类型为字符指针 char* ;
char*的指针是用来存放是char 类型的变量的地址的;
例如:
还有一种使用方式如下:
代码 const char* pstr = "hello bit." ;
特别容易让同学以为是把字符串 hello bit 放到字符指针 pstr 里了,但是/本质是把字符串 hello bit. 首字符的 地址放到了pstr中。
上面代码的意思是把一个常量字符串的首字符 h 的地址存放到指针变量 pstr 中
代码验证:
运行结果:
面试题1
问题:下面代码最终输出的是什么?
分析:
这里str3和str4指向的是一个同一个常量字符串。C/C++会把常量字符串存储到单独的一个内存区域,当几个指针 指向同一个字符串的时候,他们实际会指向同一块内存。
但是用相同的常量字符串去初始化不同的数组的时候就会 开辟出不同的内存块。然而str1和str2是首元素的地址,所以str1和str2不同,str3和str4相同;
运行结果:
二.指针数组
整型数组--存放整型的数组
字符数组--存放字符的数组
指针数组--存放指针的数组
这里我们再复习一下,下面指针数组是什么意思?
分析:
[ ]的结合性比*高,所以先和[ ]结合,成为数组,然后数组里面的每个元素类型为int */char */char **;
使用指针数组模拟实现二维数组
运行结果:
三.数组指针
类比:
整型指针--指向整型变量的指针,存储整型变量地址的指针变量;
字符指针--指向字符变量的指针,存储字符变量地址的指针变量;
数组指针--指向数组的指针,存储数组地址的指变量;
数组指针是指针?还是数组?
答案是:指针
我们已经熟悉:
整形指针: int * pint; 能够指向整形数据的指针
浮点型指针: float * pf; 能够指向浮点型数据的指针
那数组指针应该是:能够指向数组的指针
分析:
首先,[ ]的结合型比*要高,所以第一个是一个数组,数组里面存放变量的类型是int *,所以int* p1[10]是指针数组;
int ( * p )[ 10 ];
//解释:p先和*结合,说明p是一个指针变量,然后指着指向的是一个大小为10个整型的数组。所以p是一个指针,指 向一个数组,叫数组指针
//这里要注意:[]的优先级要高于*号的,所以必须加上()来保证p先和*结合
1.&数组名VS数组名
数组名的理解:
数组名表示首元素地址
但是有2个例外
1.sizeof(数组名),这里的数组名不是首元素的地址,是整个数组的地址,计算的是整个数组大小,单位是字节;
2.&数组名,这里的数组名是整个数组的地址,&数组名取出的是整个数组的大小;
如下代码:
根据上面的代码我们发现,其实&arr和arr,虽然值是一样的,但是意义应该不一样的;
实际上: &arr 表示的是数组的地址,而不是数组首元素的地址。(细细体会一下)
本例中 &arr 的类型是: int(*)[10] ,是一种数组指针类型
数组的地址+1,跳过整个数组的大小,所以 &arr+1 相对于 &arr 的差值是40.
2.数组指针的使用
数组指针指向的是数组,那数组指针中存放的应该是数组的地址;
数组指针的表示:
利用数组指针打印数组的内容:
(不建议这样使用)
一般在二维数组中使用,才更加方便
例如:
分析:
本章完~