下面的聲明合法嗎?
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爲指向的數組的大小。
#include <stdio.h>
typedef 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.c
test.c: In function ‘main’:
test.c:15: warning: initialization from incompatible pointer type
~/will$ ./a.out
20, 20
0.000000
1.000000
2.000000
3.000000
4.000000
5.000000
6.000000
7.000000
8.000000
9.000000
0xbf8515b3, 0xbf8515b3, 0xbf8515bc, 0xbf8515b3, 0xbf8515b7
對於這行代碼:
char(*pcw)[4] = cArray; // 用類型爲char*的地址(cArray的首元素)初始化一個指向數組的指針 不合法,有警告
cArray是數組首元素的地址,是一個元素的地址,卻被用來初始化一個指向數組的指針,所以是不合法的,屬於指針的錯誤使用。
【指針數組】
指針數組是一個普通的數組,可以用來表示字符串集合
指針數組中每個元素爲一個指針;
指針數組的定義:
type* pArray[n];
type* 爲數組中每個元素的類型pArray爲數組名
n爲數組大小
#include <stdio.h>
#include <string.h>
#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<size; i++)
{
if( strcmp(key, table[i]) == 0 )
{
ret = i;
break;
}
}
return ret;
}
int main()
{
const char* keyword[] = {
"do",
"for",
"if",
"register",
"return",
"switch",
"while",
"case",
"static"
};
printf("%d\n", lookup_keyword("return", keyword, DIM(keyword)));
printf("%d\n", lookup_keyword("main", keyword, DIM(keyword)));
return 0;
}
小結:數組的類型由元素類型和數組大小共同決定’
數組指針是一個指針(type (*pointer)[n]),指向對應類型的數組;
指針數組是一個數組(type* pointer[n]),且其中每個元素都爲指針;(在上例中,通過指針訪問每個字符串)
數組指針遵循指針運算法則;
指針數組擁有C語言數組的各種特效。