本文共 2214 字,大约阅读时间需要 7 分钟。
下面的声明合法吗?
int array[5]; int matrix[3][3]; int* pa = array; int* pm = matrix;array代表数组首元素的地址,那么matrix代表什么?
array和&array的地址值相同,但是意义不同,那么他们所代表的类型相同吗?
C语言中的数组有自己特定的类型:
数组的类型由【元素类型】和【数组大小】共同决定。
int array[5]的类型为int[5];划重点:
那么,这里定义的数组是什么类型的呢? 答:int型。————错!C语言中通typedef为【数组类型】重命名:
typedef type(name)[size]数组类型:
typedef int(AINT5)[5]; typedef float(AFLOAT10)[10];数组定义:
AINT5 iArray; AFLOAT10 fArray;【数组指针】用于指向一个数组 数组名是数组首元素的起始地址,但并不是数组的起始地址; 通过将取地址符&作用于数组名可以得到数组的起始地址;
可通过数组类型定义数组指针:
ArrayType* pointer;
也可以直接定义:
type(*pointer)[n];pointer为数组指针变量名 type为指向的数组的类型 n为指向的数组的大小。
#includetypedef int(AINT5)[5];typedef float(AFLOAT10)[10];typedef char(ACHAR9)[9];int main(){ AINT5 a1; float fArray[10]; AFLOAT10* pf = &fArray; ACHAR9 cArray; //char cArray[9]; char(*pc)[9] = &cArray; // char* pc[9] = char(*pcw)[4] = cArray; // 用类型为char*的地址(cArray的首元素)初始化一个指向数组的指针 不合法,有警告 int i = 0; printf("%d, %d\n", sizeof(AINT5), sizeof(a1)); for(i=0; i<10; i++) { (*pf)[i] = i; //fArray[i] = 1; } for(i=0; i<10; i++) { printf("%f\n", fArray[i]); } printf("%p, %p, %p, %p, %p\n", &cArray, pc, pc+1, pcw, pcw+1); //pc + 1 => (unsigned int)pc + sizeof(*pc) //pcw的指针运算: pcw + 1 => (unsigned int)pcw +sizeof(*pcw)4 return 0;}
编译运行:
~/will$ gcc test.ctest.c: In function ‘main’:test.c:15: warning: initialization from incompatible pointer type~/will$ ./a.out20, 200.0000001.0000002.0000003.0000004.0000005.0000006.0000007.0000008.0000009.0000000xbf8515b3, 0xbf8515b3, 0xbf8515bc, 0xbf8515b3, 0xbf8515b7
对于这行代码:
char(*pcw)[4] = cArray; // 用类型为char*的地址(cArray的首元素)初始化一个指向数组的指针 不合法,有警告
cArray是数组首元素的地址,是一个元素的地址,却被用来初始化一个指向数组的指针,所以是不合法的,属于指针的错误使用。
【指针数组】
指针数组是一个普通的数组,可以用来表示字符串集合指针数组中每个元素为一个指针;指针数组的定义:
type* pArray[n];type* 为数组中每个元素的类型 pArray为数组名 n为数组大小
#include小结: 数组的类型由 元素类型和数组大小共同决定’ 数组指针是 一个指针(type (*pointer)[n]),指向对应类型的数组; 指针数组是 一个数组(type* pointer[n]),且其中每个元素都为指针;(在上例中,通过指针访问每个字符串) 数组指针遵循指针运算法则; 指针数组拥有C语言数组的各种特效。#include #define DIM(a) (sizeof(a)/sizeof(*a))int lookup_keyword(const char* key, const char* table[], const int size) //使用指针key对指针数组中的元素进行匹配{ int ret = -1; int i = 0; for(i=0; i
转载地址:http://qwdin.baihongyu.com/