博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
发现一个时隐时现的bug!
阅读量:6567 次
发布时间:2019-06-24

本文共 1007 字,大约阅读时间需要 3 分钟。

在awk里可以这样使用正则:

#截取 a.cn?fr=1211 中的1211if(match(url,/fr=[0-9]+/) > 1){    fr = substr(url,RSTRART + 3, RLENGTH - 3 )}#截取 a.cn?ct=test 中的testif(match(url,/ct=[a-zA-Z]+/) > 1){    fr = substr(url,RSTRART + 3, RLENGTH - 3)}

这样就导致一个需求:复用这些相似的代码 (我终于也培养成了代码洁癖 T_T)那么最先想到的是写成函数,到处调用。首先是功能模块:

# 文件:   logic/parser.awk# 功能:   从str里找到指定的标记,并返回这个整个或部分标记# 参数:   str    需要搜索的字符串#         flag   查找的字符串#         offset 偏离量,调用时不传递的话当作0来使用# 返回值: 匹配上的字符串function getflag(str, flag, offset, __ARGVEND__){        if(match(str, flag) > 1)        {                return substr(str, RSTART + offset, RLENGTH - offset)        }        else        {                return ""        }}

然后是调用:

@include logic/parser.awkurl = "a.cn?fr=1211"fr = getflag(url, "fr=[0-9]+", 3)

看起来很美妙,代码终于变得干净了,起初看起来也都能工作,但是很快会发现使用这个模块的程序会内存泄漏,我之前也知道awk低于3.17的版本会泄漏,但是这个泄漏,也不一定总是发生,某次特意去测的时候就没有发现,当我逐次注释代码时终于发现:当程序里只有一个getflag调用语句时没有泄漏(似乎倒是不在乎在循环里调用多次),但多于一个调用语句,就发生了内存泄漏了,因为这种问题比较难排查,所以记录一下,用作将来的参考

转载于:https://www.cnblogs.com/code-style/p/3443555.html

你可能感兴趣的文章
postgresql创建表
查看>>
springMVC参数传递(三)
查看>>
说说Keepalived的脑裂
查看>>
linux 学习总结
查看>>
CentOS6.4下安装xampp
查看>>
shell语法
查看>>
从某次测试过程中,得到的MySQL性能优化的建议,和定位问题的方法
查看>>
JS三大对象中常用方法集锦
查看>>
词汇与分词技术
查看>>
SVN安装部署方案(一)
查看>>
我的友情链接
查看>>
CentOS7.4下建立DNS主从服务器(二)
查看>>
浅析 Linux 初始化 init 系统
查看>>
RMAN的"rman: can't open target"错误
查看>>
我的友情链接
查看>>
hadoop hive 安装
查看>>
Linux任务高度进程crond的使用
查看>>
20130710--代码技巧
查看>>
APACHE工作原理详解
查看>>
HDMI都不灵,为什么电脑连电视效果差
查看>>