[原创]指针数组VS数组指针
由于本人是菜鸟刚学没有几天
如果哪里写错了
还望大虾指教
我在这里谢过了
1指针PK数组
指针指向一块地址;数组对应一块地址
指针指向地址无所谓连续;数组对应的地址连续
指针指向地址可以改变;数组对应的地址不可以改变
指针可以指向数组;数组可以存储指针
有时候指针和数组是一致的
什么时候呢?
你比如说在一个数组作为形参的时候
它就转变为同类型的指针
都是传递首地址
进行连续操作
那为什么我们要用指针呢?
因为指针可以增加程序的灵活性
它可以对内存地址直接进行操作
可以扩大寻址范围
可以避免传值
提高代码执行效率
2。指针数组
指针数组是多个指针组成了数组
int *p[4]; //它是四个指针
//这四个指针组成一个数组
int a[4]={1,2,3,4};
p =a; //进行赋值
for(int i=0;i<4;i++)
cout<<*p[i]<<endl;
3。数组指针
int (*p)[4]; //[]的优先级高于*
//p是一个指针变量
//它指向一个有四个数组
int a[3][4]={{1,2,3,4},{5,6,7,8},{9,10,11,12}};
p =a; //进行赋值
for(int i=0;i<12;i++)
cout<<(*p)[i]<<endl;
4。指针数组的用处
那用指针数组的好处是什么呢?
如果我们要定义若干字符串
但是每个字符串的长度不一定一样
如果我们用数组来存储
那么我们就应该以对大字符串的长度为基准
这样会造成存储空间的浪费
我们将采用指针数组
每个指针的字节数是4
乘以数组下标的最大值
就是所要的空间
当我们定义了一个二维数组的时候
我们用数组指针来指向它
这样会很方便
由前面的指针PK数组
我们知道当要查找数组中元素时
指针数组的索引方式要快捷
5。数组指针的用处
数组指针有一个用处是在多维数组中使用
会增加程序的灵活性
让批评贴来的更猛烈些吧!