Linux命令行选项及参数
1、main函数参数形式
int main(int argc , char *argv[] , char *env[]);
//第一个参数argc代表命令行的参数个数
//第二个参数依次指向各个参数,如"ls -l",argv[0]指向"ls",argv[1]指向"-l",argv[2]为NULL
//第三个参数为当前进程环境变量列表
2、命令行参数识别
在命令行输入命令时,选项的位置是随意的,如ls -l -a 与ls -a -l的效果是一样的
2.1、getopt(int argc , char *argv[] , char *optstring) 引入头文件"unistd.h"
第一个参数、第二个参数同main函数的前两个参数,第三个参数optstring定义了选项和参数的形式
(1)单个字符表示该选项没有参数
(2)单个字符后面接单个冒号,表示该选项后面必定有参数,且以空格分隔选项和参数
(3)单个字符后面接双冒号,表示该选项后可以有参数也可以没有参数;若有参数,参数必须紧跟在选项后
如:
ab:c::
选项a没有参数;选项b有一个参数且用空格分隔;选项c可以有参数也可以没有参数,若有参数,参数必须紧跟在选项后
此外还有4个与getopt相关的全局变量
int optopt:存储未满足optstring规定的选项
char *optarg:指向当前选项的参数指针
int optind:确定选项和对应参数后,指向下一个argv参数
int opterr:若设为0,则getopt不想stderr输出错误信息
调用原理:
每次调用完getopt,都会返回对应的选项,使得optarg指向该选项对应的参数。若选项不满足optstring的规则,则返回‘?’,并将该选项存入optopt;若解析完毕则返回-1。
解析完毕后,getopt会重新排列argv中的参数,所有不符合要求的选项和参数被放到argv的最后(其中选项在前、参数在后),并使optind指向这些不符合要求的选项参数在argv中的起始下标。
#include <stdio.h>
#include <unistd.h> int main(int argc ,char ** argv ,char ** env){
int res;
opterr=; //不显示错误信息
while((res = getopt(argc , argv , "ab:c::")) != -){
switch(res){
case 'a':
printf("option=a\toptarg=%s\toptopt=%c\toptind=%d\targv[optind]->%s\n",optarg,optopt,optind,argv[optind]);
break;
case 'b':
printf("option=b\toptarg=%s\toptopt=%c\toptind=%d\targv[optind]->%s\n",optarg,optopt,optind,argv[optind]);
break;
case 'c':
printf("option=c\toptarg=%s\toptopt=%c\toptind=%d\targv[optind]->%s\n",optarg,optopt,optind,argv[optind]);
break;
case '?':
printf("option=?\toptarg=%s\toptopt=%c\toptind=%d\targv[optind]->%s\n",optarg,optopt,optind,argv[optind]);
break;
} }
printf("OVER\noptarg=%s\toptopt=%c\toptind=%d\targv[optind]->%s\n",optarg,optopt,optind,argv[optind]); //打印三个全局变量最终值
int i = ;
printf("******************************************\n");
for(; i < argc ; i++){ //打印重新排列后的命令行参数
printf("%s\n",argv[i]);
}
}
sudo ./main -a -b bbb -c ccc -d ddd
option=a optarg=(null) optopt= optind=2 argv[optind]->-b
option=b optarg=bbb optopt= optind=4 argv[optind]->-c
option=c optarg=(null) optopt= optind=5 argv[optind]->ccc
option=? optarg=(null) optopt=d optind=7 argv[optind]->ddd
OVER
optarg=(null) optopt=d optind=6 argv[optind]->ccc
******************************************
-a
-b
bbb
-c
-d
ccc
ddd
2.2、getopt_long
它不仅能识别短选项(命令 -短选项),而且还支持长选项(命令 --长选项)。
int getopt_long(int argc , char **argv , char * shortOpt ,struct option * longOpt, int *index) 注意:struct option 要引入头文件”getopt.h“
前三个参数同getopt的参数,shortOpt定义的短选项及参数的形式。
第四个参数定义的是结构体option数组,
第五个参数记录长选项位于longOpt数组的下标,一般情况下设为NULL
struct option{
const char *name; //长选项名称
int has_arg; //0表示该选项没有参数,1表示必须有参数,2参数为可选
int *flag; //一般为NULL,则getopt_long返回val;否则,将val的值赋给flag所指向的整形变量,函数返回值为0
int val; //一般设为长选项对应的短选项,若flag为NULL,则val作为函数的返回值。否则将val赋给flag所指向的变量
};
若不想支持短选项,则让shortOpt为”“空字符串即可,但不能设为NULL。
#include <stdio.h>
#include <unistd.h>
#include <getopt.h>
int main(int argc , char **argv , char **env){
int res; //保存函数返回值
struct option longOption[]={ //定义长选项数组
{"help",,NULL,'h'},
{"version",,NULL,'v'},
{"output",,NULL,'o'},
{NULL,,NULL,}
};
opterr=; //不输出错误信息
int index; //长选项位于longOption的下标
while( - != (res = getopt_long(argc , argv , "hvo:",longOption ,&index))){
switch(res){
case 'h':
printf("option=help\n");
break;
case 'v':
printf("option=version\n");
break;
case 'o':
printf("option=output,output path=%s\n",optarg);
break;
case '?':
printf("error\n");
break;
}
printf("index in longOption is %d\n",index);
} return ;
}
输出:
sudo ./main -h
option=help
index in longOption is -1218614280 //对于短选项,函数的第五个参数无效
sudo ./main -o /home/out
option=output,output path=/home/out
index in longOption is -1219220488
sudo ./main --version
option=version
index in longOption is 1
sudo ./main --output /home/out
option=output,output path=/home/out
index in longOption is 2
Linux命令行选项及参数的更多相关文章
- argparse - 命令行选项与参数解析(转)
argparse - 命令行选项与参数解析(译)Mar 30, 2013 原文:argparse – Command line option and argument parsing 译者:young ...
- getopt:命令行选项、参数处理
在写shell脚本时经常会用到命令行选项.参数处理方式,如: ./test.sh -f config.conf -v --prefix=/home -f 为短选项,它需要一个参数,即config.co ...
- 【makefile】make程序的命令行选项和参数
Make命令参数的典型序列如下所示: make [-f makefile文件名][选项][宏定义][目标] 这里用[]括起来的表示是可选的.命令行选项由破折号“–”指明,后面跟选项,如: make – ...
- 脚本乐园 Shell中命令行选项和参数的处理
在Linux的Shell中怎样处理tail -n 10 access.log这样的命令行选项呢?这是被别人问起的一个问题,好好学习了一下,进行总结如下:在bash中,可以用以下三种方式来处理命令行参数 ...
- 【视频】Linux高级程序设计01.3命令行选项及参数
[课程笔记] [命令行参数] 选项:-l -a -i 参数:-l /home main 函数形式: int main(int argc, char *argv[]) main函数是有参数的,而且有返回 ...
- argparse - 命令行选项与参数解析
argparse模块作为optparse的一个替代被添加到Python2.7.argparse的实现支持一些不易于添加到optparse以及要求向后不兼容API变化的特性,因此以一个新模块添加到标准库 ...
- python argparse模块:命令行选项及参数解析
位置参数:给一个例子: import argparse parser = argparse.ArgumentParser() parser.add_argument("echo") ...
- 9、getopt的用法,被用来解析命令行选项参数
#include <unistd.h> extern char *optarg; //选项的参数指针 extern int optind, //下一次调用ge ...
- 命令行选项解析函数(C语言):getopt()和getopt_long()
命令行选项解析函数(C语言):getopt()和getopt_long() 上午在看源码项目webbench时,刚开始就被一个似乎挺陌生函数getopt_long()给卡住了,说实话这函数没怎么见过, ...
随机推荐
- [C语言](一)第一个Windows 32 API的窗口程序
#include <windows.h> LRESULT CALLBACK WndProc(HWND, UINT, WPARAM, LPARAM); int WINAPI WinMain( ...
- mac打开.caj格式文件
以为用mac后使用会变得更方便些,写毕设时终于派上用场,可惜啊,mac竟然打不开.caj文件,这意味着什么?相信所有在做毕设的小伙伴们都能懂其中的凄凉.特别是硕士或博士的论文,你得从知网上下上百篇的文 ...
- JAVA中关于同步与死锁的问题
java中当多个现成同时操纵同一资源的时候需要考虑同步的问题.如车站售票,不同售票点卖同一班次车票的时候就要同步,否则卖票会有问题.下面代码模拟车站卖票: class TicketSeller imp ...
- [JS]以下是JS省市联动菜单代码
以下是JS省市联动菜单代码: 代码一: <html> <head> <title></title> <script language=" ...
- [SQL]sql介绍
SQL语言概述 结构化查询语言(Structured Query Language,简称SQL)是一种介于关系代数与关系演算之间的语言,是一种用来与关系数据库管理系统通信的标准计算机语言.其功能包括数 ...
- Regional Changchun Online--Elven Postman(裸排序二叉树)
Elven Postman Time Limit: 1500/1000 MS (Java/Others) Memory Limit: 131072/131072 K (Java/Others) Tot ...
- 深入研究java.lang.ThreadLocal类
一.概述 ThreadLocal是什么呢?其实ThreadLocal并非是一个线程的本地实现版本,它并不是一个Thread,而是threadlocalvariable(线程局部变量).也许 ...
- python学习(二):python基本语法
前言:python基本的语法与其他语言诸如C,JAVA等类似,但个中有些许不同. 一.常规语法 1.变量名与关键字 与其他语言类似,变量名由字母.数字.下划线组成,且必须由字母开头. 变量使用不需要提 ...
- 002..NET MVC实现自己的TempBag
原文链接:http://www.dotnetbips.com/articles/bc422c95-02cc-4d05-9c5c-fa89d0e78cc0.aspx 1.前言 本来今天是想发那篇关于在W ...
- 慕课网-安卓工程师初养成-4-7 Java循环语句之 while
来源: http://www.imooc.com/code/1420 生活中,有些时候为了完成任务,需要重复的进行某些动作.如参加 10000 米长跑,需要绕 400 米的赛道反复的跑 25 圈.在 ...