1、打印一个等腰三角形

#!/bin/bash
for i in `seq ` ;do
for j in `seq $[-$i]` ;do
echo -n ' '
done for k in `seq $[i*-]` ;do
echo -n '*'
done
echo
done

2、打印99乘法表

#!/bin/bash
for i in {..} ;do
for (( j=; j<=$i; j++ )) ;do
accumulate=$[i*j]
echo -ne "${j}*${i}=$accumulate\t"
done
echo
done

3、输入网段,探测网段内存活的主机

#!/bin/bash
trap 'exit' read -p "please input a network address: " DNET
echo $DNET |grep -qE "^([1-9]|[1-9][0-9]|1[0-9][0-9]|2[0-4][0-9]|25[0-4])\.(([0-9]|[1-9][0-9]|1[0-9][0-9]|2[0-4][0-9]|25[0-4])\.){2}0$" || { echo "ipaddr error"; exit; } for I in {..} ;do
{
if ping -W1 -c1 ${DNET%.*}.$I &>/dev/null ;then
echo "${DNET%.*}.$I is up."
fi
}&
done unset DNET
unset I
wait

4、打印国际象棋棋盘

#!/bin/bash
read -p "size: " bsize line=$[bsize*-]
for i in `seq $line` ;do
for j in `seq $line` ;do
if [ $[(i/bsize+j/bsize)%] -eq ] ;then
echo -ne "\033[47m \033[0m"
else
echo -n " "
fi
done
echo
done

5、编写函数(my_functions),实现打印绿色OK和红色FAILED

#Print OK and FAILED#######################################
green_OK() { echo -e "[ \033[1;32mOK\033[0m ]"; }
red_FAILED() { echo -e "[ \033[1;31mFAILED\033[0m ]"; } Screen=`stty -F /dev/tty size`
Columus=${Screen#* }
Spa_Col=$[Columus-] Progress() {
local i
for i in {..} ;do
echo -n "."
sleep 0.5
done
}
success() {
local i
string="$1"
Rt_Spa=$[$Spa_Col-${#string}]
echo -n "$string"
Progress
for i in `seq $Rt_Spa` ;do
echo -n " "
done
green_OK
}
failed() {
local i
string="$1"
Rt_Spa=$[$Spa_Col-${#string}]
echo -n "$string"
Progress
for i in `seq $Rt_Spa` ;do
echo -n " "
done
red_FAILED
}

6、编写脚本copycmd.sh

  • (1) 提示用户输入一个可执行命令名称;
  • (2) 获取此命令所依赖到的所有库文件列表;
  • (3) 复制命令至某目标目录(例如/mnt/sysroot)下的对应路径下;
    • 如:/bin/bash ==> /mnt/sysroot/bin/bash
  • (4) 复制此命令依赖到的所有库文件至目标目录下的对应路径下;
    • 如:/lib64/ld-linux-x86-64.so.2 ==> /mnt/sysroot/lib64/ld-linux-x86-64.so.2
  • (5)每次复制完成一个命令后,不要退出,而是提示用户键入新的要复制的命令,并重复完成上述功能;直到用户输入quit退出;
#!/bin/bash
. my_functions
Ddir="/mnt/sysroot"
[ ! -d "$Ddir" ] && mkdir "$Ddir" cpbin() {
cmddir=`echo "$Cmd_path" |grep -o ".*/\b"`
[ ! -d "${Ddir}${cmddir}" ] && mkdir -p "${Ddir}${cmddir}"
cp -n "$Cmd_path" "${Ddir}${cmddir}"
} libcp() {
echo "$Lib_path" |while read line ;do
libdir=`echo "$line" |grep -o ".*/\b"`
[ ! -d "${Ddir}${libdir}" ] && mkdir -p "${Ddir}${libdir}"
cp -n "$line" "${Ddir}${libdir}" 2>/dev/null
done
} while read -p "Input a cmd. (quit): " CMD ;do
if [ "$CMD" == 'quit' ] ;then echo "Think you! Bye bye."; break; fi
if ! which "$CMD" &>/dev/null ;then
echo "not find $CMD, please input again."
failed "copy $CMD failed."
continue
fi
Cmd_path=`which $CMD |grep -o "/.*"`
Lib_path=`ldd $Cmd_path |sed -nr 's#.*[[:space:]]+(/.*) .*#\1#p'`
cpbin
libcp
success "copy $CMD Complete."
done

7、求斐波那契数列的第N个数

#!/bin/bash
feibo() {
if [ $ -eq ] ; then
echo
elif [ $ -eq ] ;then
echo
else
echo $[`feibo $[$-]`+`feibo $[$-]`]
fi
} read -p "please a num: " n

8、求N的阶乘

#!/bin/bash
fact() {
if [ $ -eq -o $ -eq ] ;then
echo
else
echo $[$*`fact $[$-]`]
fi
} fact $

9、汉诺塔:问题是源于印度一个古老传说。大梵天创造世界的时候做了三根金刚石柱子,在一根柱子上从下往上按照大小顺序摞着64片黄金圆盘。大梵天命令婆罗门把圆盘从下面开始按大小顺序重新摆放在另一根柱子上。并且规定,在小圆盘上不能放大圆盘,在三根柱子之间一次只能移动一个圆盘,利用函数,实现N片盘的汉诺塔的移动步骤。

hannuota() {
local from=$
local buffer=$
local to=$
local m=$ if [ "$m" -eq ] ;then
echo "$from --> $to"
else
hannuota $[m-] $from $to $buffer
echo "$from --> $to"
hannuota $[m-] $buffer $from $to
fi
} read -p "please input num: " n
hannuota $n a b c

10、编写服务脚本testsrv.sh,完成如下要求

  • (1) 脚本可接受参数:start, stop, restart, status
  • (2) 如果参数非此四者之一,提示使用格式后报错退出
  • (3) 如是start:则创建/var/lock/subsys/SCRIPT_NAME, 并显示“启动成功”
    • 考虑:如果事先已经启动过一次,该如何处理?
  • (4) 如是stop:则删除/var/lock/subsys/SCRIPT_NAME, 并显示“停止完成”
    • 考虑:如果事先已然停止过了,该如何处理?
  • (5) 如是restart,则先stop, 再start
    • 考虑:如果本来没有start,如何处理?
  • (6) 如是status, 则如果/var/lock/subsys/SCRIPT_NAME文件存在,则显示“SCRIPT_NAME is running...” 如果/var/lock/subsys/SCRIPT_NAME文件不存在,则显示“SCRIPT_NAME is stopped...” 其中:SCRIPT_NAME为当前脚本名
  • (7)在所有模式下禁止启动该服务,可用chkconfig 和 service命令管理
#!/bin/bash
# chkconfig: 2345 98 01
. /root/bin/35_my_functions
lockfile="/var/lock/subsys/testsrv" s_start() {
[ -f "$lockfile" ] && failed "testsrv is running." && exit
touch "$lockfile"
success "testsrv start "
}
s_stop() {
[ ! -f "$lockfile" ] && failed "testsrv is not running." && exit
rm -f "$lockfile"
success "testsrv stop "
}
s_status() {
[ -f "$lockfile" ] && echo "testsrv is running." || echo "testsrv is not running."
}
s_usage() {
echo "Usage: `basename $0` {start|stop|restart|status}"
exit
} [ $# -ne ] && s_usage
case $ in
start)
s_start
;;
stop)
s_stop
;;
restart)
if [ -f "$lockfile" ] ;then
s_stop
s_start
else
failed "testsrv is not running , stop "
s_start
fi
;;
status)
s_status
;;
*)
s_usage
esac

个人学习笔记,只供参考 ^_^

最新文章

  1. iOS开发小技巧--纯代码自定义cell
  2. LeetCode 334 Increasing Triplet
  3. codeforces B.Fence 解题报告
  4. trackr: An AngularJS app with a Java 8 backend – Part I
  5. python 的文件操作。
  6. saprfc
  7. 简单分析Java中审批业务流程业务原理
  8. nginx server_name匹配顺序
  9. Server2003+IIS6+TP-Link+花生壳配置
  10. SED单行脚本快速参考(Unix 流编辑器)
  11. (转)CloudStack 安装及使用过程中常见问题汇总
  12. (改进)Python语言实现词频统计
  13. Oracle错误及解决方案
  14. 用 .NET Memory Profiler 跟踪.net 应用内存使用情况--基本应用篇(转)
  15. Android开发(九)——ViewFlipper实现图片轮播
  16. JSPatch实现原理详解
  17. 【校招面试 之 C/C++】第30题 C++ 11新特性(一)之auto关键字
  18. CentOS下安装docker,docker-compose
  19. UVA-10570 Meeting with Aliens (枚举+贪心)
  20. java中元注解

热门文章

  1. 查看字符串的编码chardet
  2. 白话算法(6) 散列表(Hash Table)从理论到实用(中)
  3. 闪回之 回收站、Flashback Drop (table、index、trigger等)
  4. JAVAmap容器基本使用
  5. java代码Math.sqrt
  6. 创建Ajax
  7. PopupWindow 防微信弹出右 侧窗体(继承PopupWindow )
  8. [ural1132]Square Root(cipolla算法)
  9. Learning Python 012 函数式编程 1 高阶函数
  10. 8、linux-数字计算