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) (庫函數的頭文件裏邊就有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);
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章