2.3 指針大小
l 使用sizeof()測量指針的大小,得到的總是:4或8
l sizeof()測的是指針變量指向存儲地址的大小
l 在32位平台,所有的指針(地址)都是32位(4字節)
l 在64位平台,所有的指針(地址)都是64位(8字節)
int *p1;
int **p2;
char *p3;
char **p4;
printf("sizeof(p1) = %d\n", sizeof(p1));
printf("sizeof(p2) = %d\n", sizeof(p2));
printf("sizeof(p3) = %d\n", sizeof(p3));
printf("sizeof(p4) = %d\n", sizeof(p4));
printf("sizeof(double *) = %d\n", sizeof(double *));
7.2.4 野指針和空指針
指針變量也是變量,是變量就可以任意賦值,不要越界即可(32位為4字節,64位為8字節),但是,任意數值賦值給指針變量沒有意義,因為這樣的指針就成了野指針,此指針指向的區域是未知(操作系統不允許操作此指針指向的內存區域)。所以,野指針不會直接引發錯誤,操作野指針指向的內存區域才會出問題。
int a = 100;
int *p;
p = a; //把a的值賦值給指針變量p,p為野指針, ok,不會有問題,但沒有意義
p = 0x12345678; //給指針變量p賦值,p為野指針, ok,不會有問題,但沒有意義
*p = 1000; //操作野指針指向未知區域,內存出問題,err
但是,野指針和有效指針變量保存的都是數值,為了標志此指針變量沒有指向任何變量(空閑可用),C語言中,可以把NULL賦值給此指針,這樣就標志此指針為空指針,沒有任何指針。
int *p = NULL;
NULL是一個值為0的宏常量:
#define NULL ((void *)0)
7.2.5萬能指針void *
void *指針可以指向任意變量的內存空間:
void *p = NULL;
int a = 10;
p = (void *)&a; //指向變量時,最好轉換為void *
//使用指針變量指向的內存時,轉換為int *
*( (int *)p ) = 11;
printf("a = %d\n", a);
7.2.6 const修飾的指針變量
int a = 100;
int b = 200;
//指向常量的指針
//修飾*,指針指向內存區域不能修改,指針指向可以變
const int *p1 = &a; //等價於int const *p1 = &a;
//*p1 = 111; //err
p1 = &b; //ok
//指針常量
//修飾p1,指針指向不能變,指針指向的內存可以修改
int * const p2 = &a;
//p2 = &b; //err
*p2 = 222; //ok


