1. 程式人生 > >C語言指標用法

C語言指標用法

一、指標說明

指標是包含另一變數的地址變數。

1、int *p

p是一個指標,指向整型數。

2、int *p()

p是一個函式,該函式返回一個指向整型的指標。

3、int (*p)()

p是一個指標,該指標指向一個函式,這個函式返回一個整數。

4、int *p[]

p是一個數組,該陣列的每一個元素是指向整數的指標。

5、int (*p)[]

p是一個指標,該指標指向一個數組,這個陣列的每一個元素是一個整數。

6、int *(*p)()

p是一個指標,該指標指向一個函式,這個函式返回一個指向整數的指標。

二、指標的初始化(賦地址)

1、通過符號&取變數(包括結構變數、陣列第一個元素)的地址賦給指標;

2、把陣列名賦給指標;

3、把函式名賦給指向函式的指標;

4、動態分配記憶體;

示例:

struct c {double r,i;};

struct c *p;

p=(struct c*)malloc(sizeof(struct c));

三、指標與陣列、函式的關係

1、對於一維陣列int a[]或指標int *a

a+i指向a[i]

2、對於字串char s[i]或指標char *s

s+i指向第i個字元s[i]

3、對於二維陣列int a[i][j]

*a+j指向a[0][j]

*(a+i)指向a[i][0]

*(a+i)+j指向a[i][j]

示例:

對於a[2][3]={1,2,3,4,5,6};

有*(*(a+1)+1)=5;

4、對於字串陣列char p[i][j]或字元型指標陣列char *p[i]

*p+j指向第0個字串的第j個字元

*(p+i)+j指向第i個字串的第j個字元

示例:

對於p[]={“ABC”,“DEF”};有(*(p+1)+1)=“E”;

對於char p[3]={“ABC”,“DEF”};有*(*(p+1)+1)=“E”;

5、對於指標陣列int *a[i]

a[i]指向變數i,即*a[i]=變數i或a[i]=&變數i

6、對於結構struct XY

{int x;int *p}*p;

p是指向結構XY的指標

(*p).x或p→x是表示x的內容

(*p).y或p→y是表示指標y的值(地址)

*(*p).y或p→y是表示y所指的內容

&(*p).x或&p→x是表示x的地址

四、指標的分類

1、近指標(near)

近指標為16位指標,它只含有地址的偏移量部分,近指標用於不超過64K位元組的單個數據段或程式碼段。在微、小和中編譯模式下產生的資料指標是近指標(預設狀態),在微、小和中編譯模式下產生的碼指標(指向函式的指標)是近指標(預設狀態)。

2、遠指標(far)

遠指標為32位指標,指標的段地址和偏移量都在指標內,可用於任意編譯模式,每次使用遠指標時都要重灌段暫存器,遠指標可定址的目標不能超過64K,因為遠指標增減運算時,段地址不參與運算,在緊湊、大和巨模式下編譯產生的資料指標是遠指標(預設狀態)。

3、巨指標(huge)

巨指標為32位指標,指標的段地址和偏移量都在指標內,可用於任意編譯模式,遠指標可定址的目標可以超過64K,巨指標是規則化的指標。

五、指標的轉換

1、遠指標轉換成巨指標

使用以下函式

void normalize(void far **p)

{

*p=(void far *)(((long)*p&0xffff000f)+(((long)*p&0x0000fff00<<12));

}

六、指標的使用

1、將浮點數轉換為二進位制數

float ff = 16.5;

unsigned char *cc;

(float*)cc=&ff;

此時cc的內容為“00008441”,即cc第一個位元組=0,第二個位元組=0,第三個位元組=0x84,第四個位元組=0x41。

2、將二進位制數轉換成浮點數

float ff;

unsigned char *cc;

cc=(unsigned char *)malloc(4);

cc=(unsigned char *)&ff;

*(cc+0)=0;

*(cc+1)=0;

*(cc+2)=0x84;

*(cc+3)=0x41;

//此時ff=16.5;

free(cc);