这节是比较重要的,因为这节要是没弄明白之后的函数实现理解起来就很麻烦,linux环境的函数,是怎么实现的,都会困难很多甚至完全理解不了。
在支持C语言的环境中,可以在程序开始执行时将命令行传递给程序。调用主函数main时:
第一个参数(argc,用于参数计数)的值表示运行程序时命令行中参数的数目。
第二杆参数(argv,用于参数向量)是一个指向字符中数组的指针,每个字符对应一个指针。通常用多级指针处理这些字符串。
也就是说第一个参数是统计参数有多少的,第二个参数是指针,其所指的位置是具体的参数。
C语言约定,argv[0]的值是启动该程序的程序名(就是说第一个参数就是这个程序的名称).因此argc的值至少是1.如果argc的值是1,那么就说明程序名后面没有参数.第一个可选的参数是argv[1],因为argv[0]是参数名,约定不可更改.最后一个可选参数是argv[argc - 1].因为参数是从0开始计数的,所以需要总数减去1才是最后一个.另外ANSI标准要求argv[argc]就是最后一个参数后面必须是空指针0.
例子是将argv的元素除了程序名外(第0个元素)依次输出。后面那个(i < argc - 1) ? " " : "";的目的只是为了加个空格吧?
下面例子说难也没多难,一样的东西,但是这个指向char类型的指针的指针有点拗口。
argv→argv[i]→char类型
把argv当成一个指针,它指向的元素也是一个指针,而这个指针又指向了char类型.
这里完全是因为数组和指针是差不多一样的,可以混用.所以才这样.
理解了上面的那些基础,之后这个例子就简单了.
开头一样还是带参数的.
然后就是那个line的指针数组,元素都是指向每个输入行的首字符的指针.
判断参数是不是等于2.等于2才是正确的参数数量,第一个是argc.
然后就是查找,先确定还存在未读取的行.
然后将argv1与line对比.如果当前行没有就返回NULL,如果有那么就继续.
将该行打印在屏幕上.
然后将计数变量加1.
返回包含参数字符的行数量.
UNIX系统中的C语言有一个公共的约定,以负号开头的参数表示一个可选标志或参数.
因为argv为指针数组,假设命令行参数为:eco hello world 所以:
1.++argv[0],[]优先级最高,所以先取argv[0]的值,argv[0]为字符串数组"ehco\0"的指针,然后指针自增++,再使用,即字符 c。
2.(++argv)[0],即先(argv+1)取出argv[1]中的值,argv[1]为字符串数组"hello\0"的指针,所以最后结果为字符 h。
两者截然不同。
指针数组作为函数参数时,函数将其作为指向指针的指针处理,因此可以自增
而自定义的指针数组实质还是数组,对数组名自增运算是非法的.
这是摘自网上的两段解释,非常清楚的解释了(++argv)[0]是想表达什么意思.
但是如果将之前的指针数组的元素都是字符串的首字符这点明确的话,这里应该也是比较好理解的.
因为上面那些原因所以可以对负号'-'进行对比.
之后就是多路判定,判断参数.
想了一会为啥argc要等于1,书上给了解释,argc执行自减运算,argv自增,到最后如果格式正确,即参数正确都是-开头的情况下,到最后就是argc自减成1,变成只剩程序名一个,argc也走到了 参数后面需要查找的字符那里.
然后就是判断输出,不过加了一个lineno这个就是计数的没循环一次加1并打印.
然后又个exceot是判断是否输出当前行的,参数有x的话之前except就被赋值为1,否则就是0,
找到这样的行就是1,与except对比如果不是1就输出,如果是0就不输出.
然后判断number 这个就是加个序号.
之前那个(++argv)[0]书上也有解释.可以看一下.