写入测试:

dd bs=64k count=4k if=/dev/zero of=/tmp/test

没有加任何参数,dd默认的方式不包括“同步(sync)”命令。也就是说,dd命令完成前并没有让系统真正把文件写到磁盘上。所以以上命令只是单纯地把这128MB的数据读到内存缓冲当中(写缓存[write cache])。所以你得到的将是一个超级快的速度。因为其实dd给你的只是读取速度,直到dd完成后系统才开始真正往磁盘上写数据,但这个速度你是看不到了。所以如果这个速度很快,没有什么作用。

dd bs=64k count=4k if=/dev/zero of=/tmp/test oflag=dsync

加入这个参数后,dd在执行时每次都会进行同步写入操作。也就是说,这条命令每次读取64k后就要先把这64k写入磁盘,然后再读取下面这64k,一共重复128次。这可能是最慢的一种方式了,因为基本上没有用到写缓存(write cache)。这种方法是最严格的,可以模拟数据库的插入操作,所以很慢,也是用来测试vps硬盘性能标准的一条标杆,一般来说测试结果,如果超过10M,对正常建站就无影响。超过50M,就是非常给力状态。

读测试

time dd if=/dev/sdb1 of=/dev/null bs=8k

因为/dev/sdb1是一个物理分区,对它的读取会产生IO,/dev/null是伪设备,相当于黑洞,of到该设备不会产生IO,所以,这个命令的IO只发生在/dev/sdb1上,也相当于测试磁盘的读能力。

方法一:

在正则表达式的前面加上(?i)即可

pattern := `(?i)hello world`
matchStr := "hello world"
regexp.MatchString(pattern,matchStr)

方法二:

先将要匹配的字符串全部转化为小写(正则中不含有大写的情况下)

matchStr := strings.ToLower("Hello world")
pattern := `hello world`
regexp.MatchString(pattern,matchStr)

两种的速度差异:

两种方法在匹配了同样一段复杂的正则100,000后发现,第二种方法比第一种方法平均快了几百微秒,可以忽略不计,可任一选用一种方法

/** 
 * 返回字符的字节长度(汉字算2个字节) 
 * @param {string} 
 * @returns {number} 
 */
  
var getByteLen = function (val) { 
    var len = 0; 
    for (var i = 0; i < val.length; i++) { 
        if (val[i].match(/[^x00-xff]/ig) != null) //全角 
            len += 2; 
        else
            len += 1; 
    }; 
    return len; 
}