前后台运行
Linux系统进程前后台运行相关的几个命令:&、ctrl+z、jobs、fg、bg
& 用在一个命令或代码块的最后(注意需要空格隔开),可以把命令或代码段放到后台执行;
ctrl + z 可以将一个正在前台执行的命令放到后台,并且暂停;
jobs 查看当前后台运行的命令列表;
fg 将后台中的命令调至前台继续运行(前台运行);
bg 将一个在后台暂停的命令,变成继续执行(后台运行);
Shell命令控制蜂鸣器发声
1、使用如下命令进行安装:
sudo apt-get install beep
2、安装好后,查看帮助信息:
beep [-verbose-debug] [-e device-device device] [-f N] [-l N] [-r N] [-d N] [-D N] [-s] [-c]
-verbose或-debug选项开启调试信息输出功能;
-e device或-device device选项设定event设备,未指定则尝试/dev/tty0和/dev/vc/0两设备;
-f N表示beep的频率为N Hz,0<N<20000;
-l N表示beep多久,为N毫秒;
-r N表示beep重复次数,默认为1;
-d N和-D N表示两次重复间的延时为N毫秒,其中d则表示最后一次重复不发生该延时,而D则表示每次都有该延时;
-s和-c表示beep时需从stdin读取,s表示每读一行,c表示每读一字符。
3、测试有没有声音出来:
beep -f 300.7 -r 2 -d 100 -l 400
该命令是用man beep里看到的,使用该例子进行测试,但声音没有出来?查了下,发现驱动没有加载:
lsmod | grep pcspkr
上面这条命令返回空。
确认Linux内核的配置里CONFIG_INPUT_PCSPKR=m,那就更肯定是没加载了。
继续查,最后发现在/etc/modprobe.d/blacklist.conf文件里居然有如下这句:
blacklist pcspkr
看来是每次启动时都被黑名单过滤掉了,我们手动加载下吧:
sudo modprobe pcspkr
这时再执行上面的beep命令就有声音出来了。
注意:如果你需要在Shell脚本里使用beep命令,记得用上/usr/bin/beep这个绝对路径,别只用命令,还有如果该Shell脚本要每次启动都能成功执行,那么上面的blacklist一句记得注释掉。
shell脚本输出带颜色信息
echo显示带颜色,需要使用参数-e
格式如下:
echo -e "\033[字背景颜色;文字颜色m字符串\033[0m"
例如:
echo -e "\033[41;37m TonyZhang \033[0m"
其中41的位置代表底色, 37的位置是代表字的颜色
注意:
1、字背景颜色和文字颜色之间是英文的“""”
2、文字颜色后面有个m
3、字符串前后可以没有空格,如果有的话,输出也是同样有空格
下面看几个例子:
echo -e "\033[30m 黑色字 \033[0m"
echo -e "\033[31m 红色字 \033[0m"
echo -e "\033[32m 绿色字 \033[0m"
echo -e "\033[33m ×××字 \033[0m"
echo -e "\033[34m 蓝色字 \033[0m"
echo -e "\033[35m 紫色字 \033[0m"
echo -e "\033[36m 天蓝字 \033[0m"
echo -e "\033[37m 白色字 \033[0m"
echo -e "\033[40;37m 黑底白字 \033[0m"
echo -e "\033[41;37m 红底白字 \033[0m"
echo -e "\033[42;37m 绿底白字 \033[0m"
echo -e "\033[43;37m 黄底白字 \033[0m"
echo -e "\033[44;37m 蓝底白字 \033[0m"
echo -e "\033[45;37m 紫底白字 \033[0m"
echo -e "\033[46;37m 天蓝底白字 \033[0m"
echo -e "\033[47;30m 白底黑字 \033[0m"
控制选项说明 :
\33[0m 关闭所有属性
\33[1m 设置高亮度
\33[4m 下划线
\33[5m 闪烁
\33[7m 反显
\33[8m 消隐
\33[30m -- \33[37m 设置前景色
\33[40m -- \33[47m 设置背景色
\33[nA 光标上移n行
\33[nB 光标下移n行
\33[nC 光标右移n行
\33[nD 光标左移n行
\33[y;xH设置光标位置
\33[2J 清屏
\33[K 清除从光标到行尾的内容
\33[s 保存光标位置
\33[u 恢复光标位置
\33[?25l 隐藏光标
\33[?25h 显示光标
shell 比较大小
一、整数比较
-eq 等于,如:if [ "$a" -eq "$b" ]
-ne 不等于,如:if [ "$a" -ne "$b" ]
-gt 大于,如:if [ "$a" -gt "$b" ]
-ge 大于等于,如:if [ "$a" -ge "$b" ]
-lt 小于,如:if [ "$a" -lt "$b" ]
-le 小于等于,如:if [ "$a" -le "$b" ]
大于(需要双括号),如:(("$a" > "$b"))
>= 大于等于(需要双括号),如:(("$a" >= "$b"))
小数据比较可使用AWK
二、字符串
#判断字符串是否相等
if [ "$A" = "$B" ];then
echo "[ = ]"
fi
#判断字符串是否相等,与上面的=等价
if [ "$A" == "$B" ];then
echo "[ == ]"
fi
#注意:==的功能在[[]]和[]中的行为是不同的,如下
#如果$a以”a”开头(模式匹配)那么将为true
if [[ "$A" == a* ]];then
echo "[[ ==a* ]]"
fi
#如果$a等于a*(字符匹配),那么结果为true
if [[ "$A" == "a*" ]];then
echo "==/"a*/""
fi
#File globbing(通配) 和word splitting将会发生, 此时的a*会自动匹配到对应的当前以a开头的文件
#如在当前的目录中有个文件:add_crontab.sh,则下面会输出ok
#if [ "add_crontab.sh" == a* ];then
#echo "ok"
#fi
if [ "$A" == a* ];then
echo "[ ==a* ]"
fi
#如果$a等于a*(字符匹配),那么结果为true
if [ "$A" == "a*" ];then
echo "==/"a*/""
fi
#字符串不相等
if [ "$A" != "$B" ];then
echo "[ != ]"
fi
#字符串不相等
if [[ "$A" != "$B" ]];then
echo "[[ != ]]"
fi
#字符串不为空,长度不为0
if [ -n "$A" ];then
echo "[ -n ]"
fi
#字符串为空.就是长度为0.
if [ -z "$A" ];then
echo "[ -z ]"
fi
#需要转义<,否则认为是一个重定向符号
if [ $A /< $B ];then
echo "[ < ]"
fi
if [[ $A < $B ]];then
echo "[[ < ]]"
fi
#需要转义>,否则认为是一个重定向符号
if [ $A /> $B ];then
echo "[ > ]"
fi
if [[ $A > $B ]];then
echo "[[ > ]]"
fi
算术运算有三种命令方式
#!/bin/bash
#PATH1=0
for i in $*; #$*:所有输入参数的内容
do
PATH2=${i}
#方式一
let PATH1=PATH1+PATH2
#方式二
PATH3=$((PATH3+PATH2))
#方式三(注意加号有空格)
PATH4=$(expr $PATH4 + ${i})
done
echo $PATH1
echo $PATH3
echo $PATH4