189 8069 5689

linux命令parse 拷贝文件夹Linux命令

SuSE Linux -ksh: xxx: not found

ksh的路径错误

成都创新互联是一家专注于成都网站建设、做网站与策划设计,长泰网站建设哪家好?成都创新互联做网站,专注于网站建设十载,网设计领域的专业建站公司;建站业务涵盖:长泰等地区。长泰做网站价格咨询:18980820575

which ksh

看看是不是在 /bin/ksh

你写成了 /usr/bin/ksh

linux 什么时候会调用parse

首先请检查open、read之类的正确。之后,

你的ioctl要是自己定义的cmd,需要同时在内核态以及用户态建立描述这个cmd的头文件。否则乱传cmd自然不能匹配。

cmd里包含你的ioctl的参数类型(是否有参数,参数是只传递进内核;还是只从内核取;还是既传递进内核又从内核取)以及混淆

具体cmd的定义你可以很容易到内核源码里找到例子,grep -rni "ioctl" ./drivers

跟着学就好了

能把这个linux shell命令的每个参数给解释一下么

问题描述:在linux shell中如何处理tail -n 10 access.log这样的命令行选项?

在bash中,可以用以下三种方式来处理命令行参数,每种方式都有自己的应用场景。

1,直接处理,依次对$1,$2,...,$n进行解析,分别手工处理;

2,getopts来处理,单个字符选项的情况(如:-n 10 -f file.txt等选项);

3,getopt,可以处理单个字符选项,也可以处理长选项long-option(如:--prefix=/home等)。

总结:小脚本手工处理即可,getopts能处理绝大多数的情况,getopt较复杂、功能也更强大。

1,直接手工处理位置参数

必须要要知道几个变量,

复制代码代码如下:

* $0 :即命令本身,相当于c/c++中的argv[0]

* $1 :第一个参数.

* $2, $3, $4 ... :第2、3、4个参数,依次类推。

* $# 参数的个数,不包括命令本身

* $@ :参数本身的列表,也不包括命令本身

* $* :和$@相同,但"$*" 和 "$@"(加引号)并不同,"$*"将所有的参数解释成一个字符串,而"$@"是一个参数数组。

手工处理方式能满足多数的简单需求,配合shift使用也能构造出强大的功能,但处理复杂选项时建议用下面的两种方法。

例子,(getargs.sh):

复制代码代码如下:

#!/bin/bash

if [ $# -lt 1 ]; then

echo "error.. need args"

exit 1

fi

echo "commond is $0"

echo "args are:"

for arg in "$@"

do

echo $arg

done

运行命令:

复制代码代码如下:

./getargs.sh 11 22 cc

commond is ./getargs.sh

args are:

11

22

cc

2,getopts (shell内置命令)

处理命令行参数是一个相似而又复杂的事情,为此,c提供了getopt/getopt_long等函数,c++的boost提供了options库,在shell中,处理此事的是getopts和getopt。

getopts/getopt的区别,getopt是个外部binary文件,而getopts是shell builtin。

复制代码代码如下:

[root@jbxue ~]$ type getopt

getopt is /usr/bin/getopt

[root@jbxue ~]$ type getopts

getopts is a shell builtin

getopts不能直接处理长的选项(如:--prefix=/home等)

关于getopts的使用方法,可以man bash 搜索getopts

getopts有两个参数,第一个参数是一个字符串,包括字符和“:”,每一个字符都是一个有效的选项,如果字符后面带有“:”,表示这个字符有自己的参数。getopts从命令中获取这些参数,并且删去了“-”,并将其赋值在第二个参数中,如果带有自己参数,这个参数赋值在“optarg”中。提供getopts的shell内置了optarg这个变变,getopts修改了这个变量。

这里变量$optarg存储相应选项的参数,而$optind总是存储原始$*中下一个要处理的元素位置。

while getopts ":a:bc" opt #第一个冒号表示忽略错误;字符后面的冒号表示该选项必须有自己的参数

例子,(getopts.sh):

复制代码代码如下:

echo $*

while getopts ":a:bc" opt

do

case $opt in

a ) echo $optarg

echo $optind

b ) echo "b $optind"

c ) echo "c $optind"

? ) echo "error"

exit 1

esac

done

echo $optind

shift $(($optind - 1))

#通过shift $(($optind - 1))的处理,$*中就只保留了除去选项内容的参数,可以在其后进行正常的shell编程处理了。

echo $0

echo $*

执行命令:

复制代码代码如下:

./getopts.sh -a 11 -b -c

-a 11 -b -c

11

3

b 4

c 5

5

./getopts.sh

3,getopt(一个外部工具)

具体用用法可以 man getopt

#-o表示短选项,两个冒号表示该选项有一个可选参数,可选参数必须紧贴选项,如-carg 而不能是-c arg

#--long表示长选项

例子,(getopt.sh):

复制代码代码如下:

#!/bin/bash

# a small example program for using the new getopt(1) program.

# this program will only work with bash(1)

# an similar program using the tcsh(1) script. language can be found

# as parse.tcsh

# example input and output (from the bash prompt):

# ./parse.bash -a par1 'another arg' --c-long 'wow!*\?' -cmore -b " very long "

# option a

# option c, no argument

# option c, argument `more'

# option b, argument ` very long '

# remaining arguments:

# -- `par1'

# -- `another arg'

# -- `wow!*\?'

# note that we use `"$@"' to let each command-line parameter expand to a

# separate word. the quotes around `$@' are essential!

# we need temp as the `eval set --' would nuke the return value of getopt.

#-o表示短选项,两个冒号表示该选项有一个可选参数,可选参数必须紧贴选项

#如-carg 而不能是-c arg

#--long表示长选项

#"$@"在上面解释过

# -n:出错时的信息

# -- :举一个例子比较好理解:

#我们要创建一个名字为 "-f"的目录你会怎么办?

# mkdir -f #不成功,因为-f会被mkdir当作选项来解析,这时就可以使用

# mkdir -- -f 这样-f就不会被作为选项。

temp=`getopt -o ab:c:: --long a-long,b-long:,c-long:: \

-n 'example.bash' -- "$@"`

if [ $? != 0 ] ; then echo "terminating..." 2 ; exit 1 ; fi

# note the quotes around `$temp': they are essential!

#set 会重新排列参数的顺序,也就是改变$1,$2...$n的值,这些值在getopt中重新排列过了

eval set -- "$temp"

#经过getopt的处理,下面处理具体选项。

while true ; do

case "$1" in

-a|--a-long) echo "option a" ; shift

-b|--b-long) echo "option b, argument \`$2'" ; shift 2

-c|--c-long)

# c has an optional argument. as we are in quoted mode,

# an empty parameter will be generated if its optional

# argument is not found.

case "$2" in

"") echo "option c, no argument"; shift 2

*) echo "option c, argument \`$2'" ; shift 2

esac

--) shift ; break

*) echo "internal error!" ; exit 1

esac

done

echo "remaining arguments:"

for arg do

echo '-- '"\`$arg'" ;

done

运行命令:

复制代码代码如下:

./getopt.sh --b-long abc -a -c33 remain

option b, argument `abc'

option a

option c, argument `33'

remaining arguments:

-- `remain'

以上提供参考学习,谢谢!

关于linux gcc。parse error before '[' token

后面的参数年有问题,你试试,只用

gcc h1.c

对了,你得有#includestdio.h

还有应该用int main()

}之前应该加上return 0;


网站栏目:linux命令parse 拷贝文件夹Linux命令
链接分享:http://cdxtjz.cn/article/ddjojgh.html

其他资讯