By francis_hao    Jul 5,2017

 

getopt:分析命令行选项

概述

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

 

描述

getopt()函数分析命令行参数,它的参数argc和argv就是程序传递给main()函数的参数,一个以'-'(不是仅有一个'-'或"--")开头的argv元素就是一个选项。'-'后面跟着的就是选项字符,调用多次getopt()函数会连续返回选项字符

变量optind是下一个要处理的元素在argv中的索引,系统初始化该变量为1,调用者可以给它复位为1,以重新扫描argv或扫描一个新的参数向量。

如果getopt()找到一个选项字符,它返回该字符,更新外部变量optind和静态变量nextchar,因此下一次调用getopt()函数时可以继续扫描剩余的选项。如果已经没有更多的选项字符了,getopt()则返回-1,然后,optind变为argv第一个不是选项元素的索引。

optstring是输入参数,它是一个包含需要进行处理的选项字符的集合,如果字符后面跟着一个冒号,表示该选项需要一个参数,因此getopt()将放置一个指向选项后面参数的指针给optarg,注意,形如-t 1和-t1都是可以的,都会将"1"传给optarg。两个冒号说明选项参数是可选的。

默认情况下,getopt()会排列它扫描到的argv中的内容,因此最终,所有不是选项的项会排在最后,另外实现的两种模式:
1、如果optstring的第一个字符是'+',或者环境变量POSIXLY_CORRECT置位,那么getopt()遇到非选项参数即停止,
2、如果optstring的第一个字符是'-',那么每个不是选项的参数,都被当作选项为1的参数处理
命令行中一个特殊的参数"--",当getopt()遇到它时,会强制参数扫描结束。

如果getopt()没有识别选项字符,它会打印一个错误信息到标准错误,存放这个字符到optopt并返回'?'。调用程序可以通过将opterr置0来防止产生错误信息的打印。

关于长选项参见man getopt_long。

 

示例

本示例为man手册上的例子,添加了一些打印以验证部分描述中的说明。

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

int main(int argc,
char
*argv[])
{
    int flags, opt;
    int nsecs;
    int i;

    nsecs =
0;
    flags =
0;
    printf("first of all optind is %d\n", optind);
    printf("---at the begining,list argv value---\n");
    for
(i=0; i<argc; i++){
        printf("argv[%u] is %s\n",i,argv[i]);
    }

    printf("-----------------------------\n");
    while
((opt = getopt(argc, argv,
"nt:"))
!=
-1)
{
        printf("current optind is %d\n", optind);
        switch
(opt)
{
            case
'n':
                flags++;
                break;
            case
't':
                nsecs = atoi(optarg);
                flags++;
                break;
            default:
/* '?' */
                fprintf(stderr,
"Usage: %s [-t nsecs] [-n] name\n",argv[0]);
                exit(EXIT_FAILURE);
        }

    }

    printf("---at the end,list argv value---\n");
    for
(i=0; i<argc; i++){
        printf("argv[%u] is %s\n",i,argv[i]);
    }

    printf("-----------------------------\n");
    printf("after all optind is %d\n", optind);

    printf("flags=%d; nsecs=%d\n", flags, nsecs);

    if
(optind >= argc)
{
        fprintf(stderr,
"Expected argument after options\n");
        exit(EXIT_FAILURE);
    }

    printf("name argument = %s\n", argv[optind]);

    /* Other code omitted */

    exit(EXIT_SUCCESS);
}

 

一个执行实例:

做以下说明:

  1. optind会指向下一次getopt()函数要处理的argv的索引,最终会指向第一个不是选项的参数的argv中的索引(例中的"name")。
  2. argv中的参数会被重新排序,不是选项的参数会排在选项参数之后。
  3. 需要参数的选项,这两种形式是一样的:-t1和-t 1。

 

程序源码在github上,可以直接clone编译。

 


本文由 刘英皓 创作,采用 知识共享 署名-非商业性使用-相同方式共享 3.0 中国大陆 许可协议进行许可。欢迎转载,请注明出处:
转载自:http://www.cnblogs.com/yinghao1991/p/7123622.html

 

参考

【1】 man 3 getopt

 

 

 

C语言的getopt的更多相关文章

  1. 命令行选项解析函数(C语言):getopt()和getopt_long()

    命令行选项解析函数(C语言):getopt()和getopt_long() 上午在看源码项目webbench时,刚开始就被一个似乎挺陌生函数getopt_long()给卡住了,说实话这函数没怎么见过, ...

  2. C语言getopt()函数的使用

    getopt(分析命令行参数)     相关函数表头文件         #include<unistd.h>定义函数         int getopt(int argc,char * ...

  3. linux C语言getopt()函数的使用

    getopt被用来解析命令行选项参数. #include <unistd.h> 函数及参数介绍 extern char *optarg; //选项的参数指针,如果选项字符串里的字母后接着冒 ...

  4. C语言-getopt函数

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

  5. C语言命令行解析函数:getopt/getopt_long

    命令行工具下的参数选项有两种,长选项和短选项.短选项以-开头,后面跟单个字母:长选项以--开头,后面可跟多个字母. 一. getopt() 1.功能:解析命令行短选项参数 2.函数原型: #inclu ...

  6. c语言基础之getopt()

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

  7. C语言查缺补漏

    7.用ucontext实现简单的用户空间协作多线程 转 http://blog.chinaunix.net/uid-26000137-id-3973004.html http://blog.csdn. ...

  8. 软件工程线上课程(C语言实践篇)学习心得总结

    林牧 + 原创作品转载请注明出处 + <软件工程(C编码实践篇)>MOOC课程http://mooc.study.163.com/course/USTC-1000002006 软件工程的理 ...

  9. [转]Python 命令行参数和getopt模块详解

    FROM : http://www.tuicool.com/articles/jaqQvq 有时候我们需要写一些脚本处理一些任务,这时候往往需要提供一些命令行参数,根据不同参数进行不同的处理,在Pyt ...

随机推荐

  1. 深度剖析HBase负载均衡和性能指标

    深度剖析HBase负载均衡和性能指标 在分布式系统中,负载均衡是一个非常重要的功能,HBase通过Region的数量实现负载均衡,即通过hbase.master.loadbalancer.class实 ...

  2. Go生成UUID

    Go生成UUID 在实际项目中,是经常会使用到一个唯一标识的,比如唯一标识一条记录等,使用C#得到唯一标识是很容易的.例 string guid = Guid.NewGuid().ToString() ...

  3. 「LibreOJ#516」DP 一般看规律

    首先对于序列上一点,它对答案的贡献只有与它的前驱和后驱(前提颜色相同)构成的点对, 于是想到用set维护每个颜色,修改操作就是将2个set暴力合并(小的向大的合并),每次插入时更新答案即可 颜色数要离 ...

  4. LeetCode:5. Longest Palindromic Substring(Medium)

    原题链接:https://leetcode.com/problems/longest-palindromic-substring/description/ 1. 题目要求:找出字符串中的最大回文子串 ...

  5. Linux 下安装Python报错:zlib not available

    问题描述: 在Linux下安装Python时出现一个错误:zipimport.ZipImportError: can't decompress data; zlib not available 详细错 ...

  6. Java并发基础--多线程基础

    一.多线程基础知识 1.进程和线程 进程:是指一个内存中运行的应用程序,每个进程都有一个独立的内存空间,一个应用程序可以同时运行多个进程:进程也是程序的一次执行过程,是系统运行程序的基本单位:系统运行 ...

  7. 5.爬虫 requests库讲解 高级用法

    0.文件上传 import requests files = {'file': open('favicon.ico', 'rb')} response = requests.post("ht ...

  8. CentOS7安装Jenkins Master

    一.安装java环境 1.查看服务器版本 cat /etc/redhat-release CentOS Linux release 7.2.1511 (Core) 升级操作系统 yum update ...

  9. cmd端口占用查看和关闭端口

    cmd——回车,输入netstat -ano——回车,可以查看已占用的端口,记下端口的PID,然后打开任务管理器,点查看,选择列,勾选PID确定,找到对应的PID,结束进程,如果结束不了或者结束后还不 ...

  10. lintcode-125-背包问题 II

    125-背包问题 II 给出n个物品的体积A[i]和其价值V[i],将他们装入一个大小为m的背包,最多能装入的总价值有多大? 注意事项 A[i], V[i], n, m均为整数.你不能将物品进行切分. ...