指针数组与数组指针

来源:互联网 发布:网络投影仪安装 编辑:程序博客网 时间:2024/04/30 15:43

1指针PK数组
指针指向一块地址;数组对应一块地址
指针指向地址无所谓连续;数组对应的地址连续
指针指向地址可以改变;数组对应的地址不可以改变
指针可以指向数组;数组可以存储指针 

有时候指针和数组是一致的
什么时候呢?
你比如说在一个数组作为形参的时候
它就转变为同类型的指针
都是传递首地址
进行连续操作

那为什么我们要用指针呢?
因为它效率高啊
那它怎么就效率高呢?
那我们举个例子
char ch[]="Hello World!";
char *p;
p =ch;

这个字符数组占了13个字节(还有一个换行符)
这个字符指针占了4个字节(所以的指针都占4个字节)
你看看存储空间是不是节省了

如果我们要用数组输出W
我们要先找到数组的首地址
然后后移6个单位

如果我们要用指针输出W
我们要先找到指针
然后加6

这样你可以看出来效率了吧


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[0];     //进行赋值
for(int i=0;i<12;i++)
cout<<(*p)[i]<<endl;

4。指针数组的用处
那用指针数组的好处是什么呢?
 如果我们要定义若干字符串
但是每个字符串的长度不一定一样
如果我们用数组来存储
那么我们就应该以对大字符串的长度为基准
这样会造成存储空间的浪费
我们将采用指针数组
每个指针的字节数是4
乘以数组下标的最大值
就是所要的空间

当我们定义了一个二维数组的时候
我们用数组指针来指向它
这样会很方便

由前面的指针PK数组
我们知道当要查找数组中元素时
指针数组的索引方式要快捷

5。数组指针的用处
数组指针有一个用处是在多维数组中使用
会增加程序的灵活性

原创粉丝点击