Shell
将代码保存为 test.sh,并 cd 到相应目录:
chmod +x ./test.sh #使脚本具有执行权限
./test.sh #执行脚本
注意,一定要写成 ./test.sh,而不是 test.sh,运行其它二进制的程序也一样,直接写 test.sh,linux 系统会去 PATH 里寻找有没有叫 test.sh 的,而只有 /bin, /sbin, /usr/bin,/usr/sbin 等在 PATH 里,你的当前目录通常不在 PATH 里
定义变量时,变量名不加美元符号($,PHP语言中变量需要),
your_name="runoob.com"使用一个定义过的变量,只要在变量名前面加美元符号即可,
echo ${your_name}
shell中函数的定义格式如下:
[ function ] funname [()] { action; [return int;] }
遇到大段的代码需要临时注释起来,过一会儿又取消注释,怎么办呢?
每一行加个#符号太费力了,可以把这一段要注释的代码用一对花括号括起来,定义成一个函数,没有地方调用这个函数,这块代码就不会执行,达到了和注释一样的效果。http://www.runoob.com/linux/linux-shell-passing-arguments.html
AWK
awk '/pattern/{action}' files
其中patter是一个正则表达式,action又是一系列命令,对于满足匹配的文本执行一些动作,files表示待操作的文件,如果不指定,则输入是STDIN。如果不指定pattern,则对所有文件的每一行都执行action。
awk自动将读入的行分割成域(field),域是由一个或多个分隔符分割开的字符集,缺省的分隔符是tab和空格,访问域可以用$1,$2, ... $n的形式,域都是从1开始的,而$0表示整个行(以行本来的面目呈现)
如
awk '{ printf "%-15s %s\n", $1, $2 ;}' zdd.txt
awk的-F参数可以制定其他的域分隔符,比如下面的代码将打印D
echo A:B:C:D | awk -F: '{print $4}'
http://www.cnblogs.com/softwaretesting/archive/2012/02/02/2335332.html
Swap分区
swap分区是在硬盘空间中开辟一块区域,用来存放内存溢出来的数据,可以提高linux系统性能。可以将内存想象成一个杯子,程序运行时产生的数据作为水放进杯子中,当我们运行的程序过多,或是处理的数据量过大时,杯子慢慢变满,导致盛不下了,此时如果有swap分区的话,就如同将过多的水倒入swap分区这个杯子中。
分配太多浪费空间,太少系统错误
在windows的swap分区,我们更常称之为虚拟内存。虽然两者的技术实现上有很大差异,但是我们可以姑且认为它们具有相同的作用。此外,linux系统休眠的数据是保存到swap分区中的,换言之,如果系统没用配置swap分区,linux是无法休眠的!(这个未亲身验证过)
从理论上讲,swap分区确实是增大了可使用的内存空间,但是,内存中数据交换速度非常快,而swap分区讲物理内存当作内存的载体,物理磁盘的数据交换速度远远落后于物理内存,因此不可避免的带来运行效率的下降。
参考自https://www.cnblogs.com/bozhicheng/p/5644740.html