mytags: myblog
title: Lua 调用 C/C++ 动态库
date: 2020-12-20 10:28:54
categories: 数据库
tags: 链接库
- 
屏蔽命令执行的出错信息
ls a 2> /dev/nulllinux 中
0 – stdin (standard input,标准输入)
1 – stdout (standard output,标准输出)
2 – stderr (standard error,标准错误输出)2> /dev/null将标准错误输出重定向到 null 设备, 从而实现屏蔽 ls 的小细节
ls 在输出时会判断是在终端还是管道,若在终端中则默认不换行输出, 输出到管道或文件则换行.
可以ls -1 强制换行 ls -C 强制不换行- 
案例: 获取文件夹下以 x-y 格式命名的文件名列表, 列表内容为不重复的 x 名称
比如 demo 下有 a-hello, b-world, b-ok 则列表为 a bls demo | awk -F- '/.*-.*/{print $1}' | sort | uniq- ls 列出 demo 下的所有文件或文件夹列表, 每一项一行, 输出给 awk;
 - 对于输入的每一行, awk 中的先进行正则筛选 
.*-.*表示只匹配包含-字符的行; - 对于符合正则筛选的行, 根据 -F 参数给的分割符 (默认空格) 进行字符串分割 (这里是 
-); - awk 命令部分 
{print $1}表示打印第一个分割点; - 对所有行, awk 都执行一次上述操作, 于是得到所有x-y 模式中的 x;
 - 对列表进行排序 (sort) 和去重 (uniq) 便得到最终结果
 
 - 
awk match 函数
- 案例, 想要提取 
./a.out(+0x11ee) [0x5606cd0041ee]中的0x11ee, 从而提取报错函数的地址. 
awk '{match( $0, /.*\(\+(.*)\)/, a ); print( a[1] )}'- 首先awk 的程序部分直接执行 match 函数, 该函数接收三个参数: 要匹配的源字符串, 正则部分, 输出列表;
 - 源字符串直接取输入的行 (
$0); - 正则部分包含在两个 
/之间, 该正则首先直接忽略前面字符(.*) 直到匹配到第一个左括号和 + 号 (\(\+) (需加反斜杠因为(和+是正则关键字); - 然后收录之后的所有内容 (
(.*)) 直到右括号 (\)) 出现; - 就此结束, 后面不论出现什么都不管了; 于是第一个收录内容放到了 a[1] 里面, 这正是我们匹配的括号里的内容。
 
 - 案例, 想要提取