typedef 函數指針的用法

代碼簡化, 促進跨平臺開發的目的.

 typedef 行爲有點像 #define 宏,用其實際類型替代同義字。

 不同點:typedef 在編譯時被解釋,因此讓編譯器來應付超越預處理器能力的文本替換

用法一:

typedef int (*MYFUN)(int, int);
這種用法一般用在給函數定義別名的時候
上面的例子定義MYFUN 是一個函數指針, 函數類型是帶兩個int 參數, 返回一個int

分析這種形式的定義的時候可以用下面的方法:
先去掉typedef 和別名, 剩下的就是原變量的類型.
去掉typedef和MYFUN以後就剩:
int (*)(int, int)

用法二:

typedef給變量類型定義一個別名.

typedef struct{
int a;
int b;
}MY_TYPE;

這裏把一個未命名結構直接取了一個叫MY_TYPE的別名, 這樣如果你想定義結構的實例的時候就可以這樣:
MY_TYPE tmp;

第二種用法:typedef 原變量類型 別名

簡單的函數指針的用法

//形式1:返回類型(*函數名)(參數表)

char(*pFun)(int);

//typedef char(*pFun)(int)   //跟上一行功能等同

/*typedef的功能是定義新的類型。第一句就是定義了一種PTRFUN的類型,並定義這種類型爲指向某種函數的指針,這種函數以一個int爲參數並返回char類型。*/

char glFun(int a){return;}

void main()

{

pFun =glFun;

(*pFun)(2);

}

第一行定義了一個指針變量pFun.它是一個指向某種函數的指針,這種函數參數是一個int類型,返回值是char類型。只有第一句我們還無法使用這個指針,因爲我們還未對它進行賦值

第二行定義了一個函數glFun().該函數正好是一個以int爲參數返回char的函數。我們要從指針的層次上理解函數-函數的函數名實際上就是一個指針函數名指向該函數的代碼在內存中的首地址

下面是一個例子:

  1. //#include<iostream.h>      
  2. #include<stdio.h>      
  3.      
  4. typedef int (*FP_CALC)(intint);      
  5. //注意這裏不是函數聲明而是函數定義,它是一個地址,你可以直接輸出add看看      
  6. int add(int a, int b)      
  7. {      
  8.      return a + b;      
  9. }      
  10. int sub(int a, int b)      
  11. {      
  12.      return a - b;      
  13. }      
  14. int mul(int a, int b)      
  15. {      
  16.      return a * b;      
  17. }      
  18. int div(int a, int b)      
  19. {      
  20.      return b? a/b : -1;      
  21. }      
  22. //定義一個函數,參數爲op,返回一個指針。該指針類型爲 擁有兩個int參數、      
  23. //返回類型爲int 的函數指針。它的作用是根據操作符返回相應函數的地址      
  24. FP_CALC calc_func(char op)      
  25. {      
  26.      switch (op)      
  27.       {      
  28.      case '+'return add;//返回函數的地址      
  29.      case '-'return sub;      
  30.      case '*'return mul;      
  31.      case '/'return div;      
  32.      default:      
  33.          return NULL;      
  34.       }      
  35.      return NULL;      
  36. }      
  37. //s_calc_func爲函數,它的參數是 op,      
  38. //返回值爲一個擁有 兩個int參數、返回類型爲int 的函數指針      
  39. int (*s_calc_func(char op)) (intint)      
  40. {      
  41.      return calc_func(op);      
  42. }      
  43. //最終用戶直接調用的函數,該函數接收兩個int整數,和一個算術運算符,返回兩數的運算結果      
  44. int calc(int a, int b, char op)      
  45. {      
  46.       FP_CALC fp = calc_func(op); //根據預算符得到各種運算的函數的地址      
  47.          int (*s_fp)(intint) = s_calc_func(op);//用於測試      
  48.          // ASSERT(fp == s_fp);    // 可以斷言這倆是相等的      
  49.      if (fp) return fp(a, b);//根據上一步得到的函數的地址調用相應函數,並返回結果      
  50.      else return -1;      
  51. }      
  52.      
  53. void main()      
  54. {         
  55.     int a = 100, b = 20;      
  56.      
  57.       printf("calc(%d, %d, %c) = %d\n", a, b, '+', calc(a, b, '+'));      
  58.       printf("calc(%d, %d, %c) = %d\n", a, b, '-', calc(a, b, '-'));      
  59.       printf("calc(%d, %d, %c) = %d\n", a, b, '*', calc(a, b, '*'));      
  60.       printf("calc(%d, %d, %c) = %d\n", a, b, '/', calc(a, b, '/'));      
  61. }    

運行結果

   calc(100, 20, +) = 120

   calc(100, 20, -) = 80

   calc(100, 20, *) = 2000

   calc(100, 20, /) = 5

轉自http://www.cnblogs.com/shenlian/archive/2011/05/21/2053149.html

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章