• 常用函数


    • getopt() - 分析命令行选项

    SYNOPSIS

       #include <unistd.h>
    
       int getopt(int argc, char * const argv[],
                  const char *optstring);
    
       extern char *optarg;
       extern int optind, opterr, optopt;
    

    optarg——指向当前选项参数(如果有)的指针。 optind——再次调用 getopt() 时的下一个 argv 指针的索引。 optopt——最后一个未知选项。

    getopt返回值: 选项

    如果optstring的字母后接着冒号“:”,则表示还有相关的参数,全域变量optarg 即会指向此额外参数。如果在处理期间遇到了不符合optstring指定的其他选项getopt()将显示一个错误消息,并将全域变量optarg设为“?”字符,如果不希望getopt()打印出错信息,则只要将全域变量opterr设为0即可。

    例如: getopt(argc, argv, "ab:c:de::");
    1.abcde都是命令行的一个选项
    2.b:c: 表示-b -c后面都需要接一个参数,紧跟选项后或空格隔开。optarg指向该参数。
    3.e:: 表示-e 可以跟一个参数,也可以不跟。如果跟一个参数,参数必须紧跟在选项后不能以空格隔开。该参数的指针赋给optarg。(如上例中的e::,如果没有跟参数,则optarg = NULL)

    实例:

    #include <stdio.h>
    #include <unistd.h>
    
    int main(int argc, char *argv[])
    {
    	int ch = 0;
    	opterr = 0;
    	while((ch = getopt(argc,argv,"a:bcde::")) != -1){
    	    switch(ch){           
    	        case 'a': 
    	            printf("option a:'%s'
    ", optarg);
    	            break;
    	        case 'b':
    	            printf("option b :'%s'
    ", optarg);
    	            break;
    	        case 'e': 
    	            printf("option e:'%s'
    ", optarg);
    	            break;
    	        default:
    	            printf("other option : %c
    ", ch);
    	    }
    	    printf("optopt +%c
    ", optopt);
    	} 
    	return 0;
    }
    

    结果如下:

    可知-e不带参数也没问题。-a不带参数不能识别,返回?,且optopt = a。

    xxx@xxx-pc:~/Documents$ ./a.out -b
    option b :'(null)'
    optopt +
    
    xxx@xxx-pc:~/Documents$ ./a.out -e123
    option e:'123'
    optopt +
    
    xxx@xxx-pc:~/Documents$ ./a.out -e
    option e:'(null)'
    optopt +
    
    xxx@xxx-pc:~/Documents$ ./a.out -a
    other option : ?
    optopt +a
    
    xxx@xxx-pc:~/Documents$ ./a.out -a333
    option a:'333'
    optopt +
  • 相关阅读:
    基础知识
    显示功能
    监听器
    检测session是否为空
    W7-Web服务器[JavaWeb]
    D9-哈希表[Java数据结构和算法]
    D8-查找算法[Java数据结构和算法]
    D7-排序算法(三)[Java数据结构和算法]
    W6-junit、泛型、枚举、增强for、可变参数、反射[JavaWeb]
    D6-排序算法(二)[Java数据结构和算法]
  • 原文地址:https://www.cnblogs.com/fuluwwa/p/6791540.html
Copyright © 2020-2023  润新知