getopt_long支援長選項的命令列解析,使用man getopt_long,得到其聲明如下:
  #include <getopt.h>

       int getopt_long(int argc, char * const argv[],
                  const char *optstring,
                  const struct option *longopts, int *longindex);

       int getopt_long_only(int argc, char * const argv[],
                  const char *optstring,
                  const struct option *longopts, int *longindex);

說明:函數中的argc和argv通常直接從main()到兩個參數傳遞而來。optsting是選項參數組成的字串,如

果該字串裡任一字母後有冒號,那麼這個選項就要求有參數。下一個參數是指向陣列的指標,這個陣列是

option結構陣列,option結構稱為長選項表,其聲明如下:

 struct option {
              const char *name;
              int has_arg;
              int *flag;
              int val;
          };

結構中的元素解釋如下:
const char *name:選項名,前面沒有短橫線。譬如"help"、"verbose"之類。
int has_arg:描述長選項是否有選項參數,如果有,是哪種類型的參數,其值見下表:
符號常量             數值            含義
no_argument            0            選項沒有參數
required_argument      1            選項需要參數
optional_argument      2            選項參數是可選的
int *flag:
如果該指針為NULL,那麼getopt_long返回val欄位的值;
如果該指標不為NULL,那麼會使得它所指向的結構填入val欄位的值,同時getopt_long返回0
int val:
如果flag是NULL,那麼val通常是個字元常量,如果短選項和長選項一致,那麼該字元就應該與optstring中

出現的這個選項的參數相同;

最後一個參數:longindex參數一般賦為NULL即可;如果沒有設置為NULL,那麼它就指向一個變數,這個變數

會被賦值為尋找到的長選項在longopts中的索引值,這可以用於錯誤診斷。

注:GNU提供的getopt-long()和getopt-long-only()函數,其中,後者的長選項字串是以一個短橫線開始的

,而非一對短橫線。


linux 命令列約定:
     幾乎所有的GNU/Linux程式都遵循一些命令列參數定義的約定。程式希望出現的參數可以分成兩種:選

項(options or flags)、其他類型的的參數。Options修飾了程式運行的方式,其他類型的參數則提供了輸

入(例如,輸入檔的名稱)。

     對於options類型參數可以有兩種方式:
     1)短選項(short options):顧名思義,就是短小參數。它們通常包含一個連字型大小和一個字母(大寫

或小寫字母)。例如:-s,-h等。
     2)長選項(long options):長選項,包含了兩個連字型大小和一些大小寫字母組成的單詞。例如,--

size,--help等。
     *注:一個程式通常會提供包括short options和long options兩種參數形式的參數。

     對於其他類型參數的說明:
     這種類型的參數,通常跟隨在options類型參數之後。例如,ls –s /功能為顯示root目錄的大小。’/

’這個參數告訴ls要顯示目錄的路徑。


getopt_long()函數使用規則:

(1)使用前準備兩種資料結構
    字元指標型變數
    該資料結構包括了所有要定義的短選項,每一個選項都只用單個字母表示。如果該選項需要參數(如,

需要檔路徑等),則其後跟一個冒號。例如,三個短選項分別為‘-h’‘-o’‘-v’,其中-o需要參數,

其他兩個不需要參數。那麼,我們可以將資料結構定義成如下形式:
const char * const shor_options = “ho:v” ;

    struct option 類型陣列
    該資料結構中的每個元素對應了一個長選項,並且每個元素是由四個域組成。通常情況下,可以按以下

規則使用。第一個元素,描述長選項的名稱;第二個選項,代表該選項是否需要跟著參數,需要參數則為1,

反之為0;第三個選項,可以賦為NULL;第四個選項,是該長選項對應的短選項名稱。另外,資料結構的最後

一個元素,要求所有域的內容均為0,即{NULL,0,NULL,0}。下面舉例說明,還是按照短選項為‘-h’‘-o’

‘-v’的例子,該資料結構可以定義成如下形式:
const struct option long_options = {
{  “help”,      0,   NULL,   ‘h’  },
{  “output”,    1,   NULL,   ‘o’  },
{  “verbose”,   0,   NULL,   ‘v’  },
{  NULL,      0,    NULL,   0  }
};

(2)調用方法
     參照(1)準備的兩個資料結構,則調用方式可為:
getopt_long( argc, argv, short_options, long_options, NULL);

(3)幾種常見返回值
    (a)每次調用該函數,它都會分析一個選項,並且返回它的短選項,如果分析完畢,即已經沒有選項了,

則會返回-1。
    (b)如果getopt_long()在分析選項時,遇到一個沒有定義過的選項,則返回值為‘?’,此時,程式師可

以列印出所定義命令列的使用資訊給使用者。
    (c)當處理一個帶參數的選項時,全域變數optarg會指向它的參數
    (d)當函數分析完所有參數時,全域變數optind(into argv)會指向第一個‘非選項’的位置

實踐小例子:


 

[c-sharp] view plaincopy

  1. #include <stdio.h>  
  2. #include <getopt.h>  
  3. char *l_opt_arg;  
  4. char* const short_options = "nbl:";  
  5. struct option long_options[] = {  
  6.      { "name",     0,   NULL,    'n'     },  
  7.      { "bf_name",  0,   NULL,    'b'     },  
  8.      { "love",     1,   NULL,    'l'     },  
  9.      {      0,     0,     0,     0},  
  10. };  
  11. int main(int argc, char *argv[])  
  12. {  
  13.      int c;  
  14.      while((c = getopt_long (argc, argv, short_options, long_options, NULL)) != -1)  
  15.      {  
  16.          switch (c)  
  17.          {  
  18.          case 'n':  
  19.              printf("My name is XL./n");  
  20.              break;  
  21.          case 'b':  
  22.              printf("His name is ST./n");  
  23.              break;  
  24.          case 'l':  
  25.              l_opt_arg = optarg;  
  26.              printf("Our love is %s!/n", l_opt_arg);  
  27.              break;  
  28.          }  
  29.      }  
  30.      return 0;  
  31. }  

編譯並運行:

[root@localhost liuxltest]# gcc -o getopt getopt.c

[root@localhost liuxltest]# ./getopt -n -b -l forever
My name is XL.
His name is ST.
Our love is forever!
[root@localhost liuxltest]#

[root@localhost liuxltest]# ./getopt -nb -l forever
My name is XL.
His name is ST.
Our love is forever!
[root@localhost liuxltest]# ./getopt -nbl forever 
My name is XL.
His name is ST.
Our love is forever!

原文出處

http://blog.csdn.net/ast_224/article/details/3861625

arrow
arrow
    全站熱搜
    創作者介紹
    創作者 立你斯 的頭像
    立你斯

    立你斯學習記錄

    立你斯 發表在 痞客邦 留言(0) 人氣()