指针数组
指针的数组,实际是一个数组,长度由数组本身决定,这个数组的所有元素都是指针类型,存放的都是地址。
int *prt[ 10 ] ; *prt[ 1 ],*prt[ 2 ],*prt[ 3 ]… 数组中每个元素都指向一个地址。
#include <iostream>
#include <string.h>
#include <stdio.h>
using namespace std;
void sort(char **pa, int n)
{
int i, j;
char *tmp = NULL;
for(i = 0; i < n; i++)
{
cout << *(pa+i) << endl;
}
cout << endl;
/* 第一个字符串和最后一个字符串互换,其实就是字符串首地址互换了 */
tmp = *pa;
*pa = *(pa+3);
*(pa+3) = tmp;
for(i = 0; i < n; i++)
{
cout << *(pa+i) << endl;
}
cout << endl;
}
int main()
{
char *pa[4] = {"abc", "def", "ghi", "jkl"};
sort(pa,4);
for(int i = 0; i < 4; i++)
{
cout << *(pa+i) << endl;
}
}
首先char *pa1[4]是一个包含三个指针的数组,那么pa1就是数组的首地址,pa1就是 数组第一个指针的值也就是第一这指针指向的位置,也就是"abc"字符串所在位置的首地址,所以打印的pa1 就是"abc"
对于函数sort()中的二级指针,应该知道如果我想要在函数中修改一个指针指向的地址的值,那就需要二级指针
数组指针
数组的指针,实际是一个指针,长度固定(32 位系统下占 4 个字节),这个指针指向数组,但指向的数组占多少个字节不确定。
int a[5]={ 1,2,3,4,5 }; //定义一个一维数组 a
int (*prt)[5]; // 步长为 5 的数组指针,即 prt 指向的数组里有 5 个元素
prt=&a; // 把数组 a 的地址付给 prt,则 prt 为数组 a 的地址,*prt 表示数组 a 本身
prt[ 0 ]; //表示数组首元素的地址
*prt[ 0 ]; //表示数组的首元素的值,即为数组 a 的 1
**prt; //表示数组的首元素的值,即为数组 a 的 1
*prt[ 1 ] ; //表示指向数组的下一行元素的首元素的值,但是a是一维数组,只有一行,所以指向的地址中的值不确定
数组指针加 1,步长为所指向数组的列数,即为下一行的首地址,只在二维及以上维度的数组中有意义,一维数组只有一行,无意义。