shell、AWK、SWAP
2017-12-12 14:16
344 查看
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语言中变量需要),
使用一个定义过的变量,只要在变量名前面加美元符号即可,
shell中函数的定义格式如下:
遇到大段的代码需要临时注释起来,过一会儿又取消注释,怎么办呢?
每一行加个#符号太费力了,可以把这一段要注释的代码用一对花括号括起来,定义成一个函数,没有地方调用这个函数,这块代码就不会执行,达到了和注释一样的效果。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的-F参数可以制定其他的域分隔符,比如下面的代码将打印D
http://www.jb51.net/article/53259.htm 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
分配太多浪费空间,太少系统错误
将代码保存为 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.jb51.net/article/53259.htm 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
分配太多浪费空间,太少系统错误
相关文章推荐
- 用shell 或者 awk 合并两个文件
- 利用shell中awk和xargs以及sed将多行多列文本中某一列合并成一行
- shell脚本学习:循序渐进之初级awk语句,until循环,test语句
- shell练习-awk命令
- Shell编程作业-awk
- 【一天一个shell命令】文本内容操作系列-awk
- shell+sed+awk和perl和python的区别
- awk 程序中使用 Shell 命令
- shell往awk传参数
- awk与shell效率比较
- Shell中的grep、awk和sed的常用命令和语法
- shell grep awk统计脚本小记
- shell 知识点补充(3)-修改语系/特殊字符/ printf/sed 工具/awk 工具/diff/cmp
- Shell脚本之awk详解
- shell 脚本完成对日志文件的提取之awk 学习
- Shell脚本内置变量 和 awk脚本内置变量 比较
- shell--- awk最新教程
- shell awk 使用实例 awk 合并行
- shell之awk
- sed和awk中使用shell变量【转】