一、C語言的指針
1.指針說明
指針是包含另一變量的地址變量。
(1)int *p
p是一個指針,指向一個整形數。
(2)int *p()
p是一個函數,該函數返回一個指向整數的指針。
(3)int (*p)()
p是一個指針,該指針指向一個函數,這個函數返回一個整數。
(4)int *p[]
p是一個數組,該數組的每一個元素是指向整數的指針。
(5)int (*p)[]
p是一個指針,該指針指向一個數組,這個數組的每一個元素是一個整數。
(6)int *(*p)()
p是一個指針,該指針指向一個函數,這個函數返回一個指向整數的指針。
2.指針的初始化(賦地址)
(1)通過符號&取變量(包括結構變量、數組第一個元素)的地址賦給指針;
(2)把數組名賦給指針;
(3)把函數名賦給指向函數的指針;
(4)動態分配內存
例:struct c{double r,i;};
struct c *p;
p=(struct c *)malloc(sizeof(struct c));
3.指針與數組、函數的關系
(1)對于一維數組 int a[i] 或指針 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) 指向第 i個字符串的第 0個字符
*(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 *y}*p;
p是指向結構XY的指針
(*p).x 或 p->x 是表示 x 的內容
(*p).y 或 p->y 是表示指針 y 的值(地址)
*(*p).y 或 *p->y 是表示 y 所指的內容
&(*p).x 或 &p->x 是表示 x 的地址
(7)指向函數的指針
對于 void func(char *str)
{…}; //定義了一個函數
void (*p)(char*);//定義了一個函數指針
p=func; //讓指針指向函數
則(*p)("…"); //用指針p可以調用函數func
(8)指向多個不同函數的指針數組
對于void function_1() {…};
…
void function_4() {…}; //定義了四個函數
typedef void(*menu_fcn)();//定義了指向函數的指針
menu_fcn command[4]; //定義了指針數組
command[0]=function_1;
…
command[3]=function_4; //讓指針數組指向四個函數
則command[0](); //用指針數組中的一個元素調用一個函數
4.指針的分類
(1)近指針(near):
近指針為16位指針,它只含有地址的偏移量部分。近指針用于不超過64K 字節的單個數據段或代碼段。在微、小和中編譯模式下產生的數據指針是近指針(缺省狀態);在微、小和中編譯模式下產生的碼指針(指向函數的指針)是近指針(缺省狀態)。
(2)遠指針(far)
遠指針為32位指針,指針的段地址和偏移量都在指針內。可用于任意編譯模式。每次使用遠指針時都要重裝段寄存器。遠指針可尋址的目標不能超過64K ,因為遠指針增減運算時,段地址不參與運算。在緊湊、大和巨模式下編譯產生的數據指針是遠指針(缺省狀態)。
(3)巨指針(huge)
巨指針為32位指針,指針的段地址和偏移量都在指針內。可用于任意編譯模式。遠指針尋址的目標可以超過64K 。巨指針是規則化的指針。
5.指針的轉換
(1)遠指針轉換成巨指針
使用以下函數
void normalize(void far * * p)
{
*p=(void far *)(((long)*p&0xffff000f)+(((long)*p&0x0000fff00<<12));
}
6.指針的使用
(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);
二、C 語言的函數
1.用戶自定義函數格式
類型 函數名(形式參數表)
參數說明
{
……
}
2.函數的調用方式
(1)傳值方式
①傳給被調用函數的是整型、長整型、浮點型或雙精度型變量。被調用的函數得定義相應的變量為形參。





