C function pointer 指標函數

相當方便的指標函數,可以輕鬆的乎叫對應的function。 (C function pointer with array can make functions call easier.) 

所有的function都有一個位址,例如 func1() ,呼叫時我們可以直接呼叫func1();
 或是透過指標,如: int(*p)(); 先宣告一個指標,然後 p=func1; or p=&func1; 都可以,func1 與 &func1,都是func1的起始位置。 
a.呼叫時 1. p(); 2. (*p)(); 都可以,此時p與*p都是func1的起始位置。
 b.(*p)()不可以寫成*p(),()優先序高於*,這樣會出錯。
 c. 對指標含數進行*(p+1) 之類的運算是沒意義的。

#include <stdio .h>
#include<stdlib .h>

typedef int (*MYFUNC)();


int func1()
{
 printf("\n%s\n",__func__);
}

int func2()
{
 printf("\n%s\n",__func__);
}

int func3()
{
 printf("\n%s\n",__func__);
}

/* static (*funcs[3])() = { &func1, &func2, &func3};   
*  static (*funcs[3])() = { func1, func2, func3};    
*  這三個寫法都一樣的效果,&可加可不加,都是指到同樣的位址。
*/ 
static MYFUNC funcs[3] = { &func1, &func2, &func3};


int main(int argc, char *argv[])
{

   (*(funcs[atoi(argv[1])]))();
}




執行結果(result):
[root@new-host-832 stanley]# ./a.out 0

func1
[root@new-host-832 stanley]# ./a.out 1

func2
[root@new-host-832 stanley]# ./a.out 2

func3
上面的範例,要剛好argv是照0~2,若argv是分開的話,可以用下面的做法。
#include <stdio .h>
#include<stdlib .h>

#define ARRAY_LEN(x) (sizeof(x)/sizeof((x)[0]))   //sizeof(x)是array x的總長, sizeof(x[0])是求x[0]用掉的空間..相除便是用array的size
#define FUNC_NUM ARRAY_LEN(CmdTable)

typedef void (*MYFUNC)();

typedef struct{
char *CmdName;
MYFUNC Cmdfunc;
}CMD;

void func1()
{
 printf("\n%s\n",__func__);
}

void func2()
{
 printf("\n%s\n",__func__);
}

void func3()
{
 printf("\n%s\n",__func__);
}

CMD CmdTable[]={
{"39",func1},
{"66",func2},
{"99",func3}
};

int main(int argc, char *argv[])
{
   int i=0;
     
     
    for(i=0; i< FUNC_NUM ;i++){
        if( !strcmp(argv[1],CmdTable[i].CmdName) )
                     (*(CmdTable[i].Cmdfunc))();
    }
}

執行結果如下: iwpriv, iwlist 很多open source的程式會用到這個方法。
[root@new-host-832 stanley]# ./a.out 39

func1
[root@new-host-832 stanley]# ./a.out 66

func2
[root@new-host-832 stanley]# ./a.out 99

func3

留言

這個網誌中的熱門文章

Raspberry Pi (ARMv6)上自幹一個微小作業系統

Linux VLAN 筆記

C語言,大數運算,階層筆記