(1)/dev/null:回收站、无底洞。
(2)/dev/zero:产生字符。
2、测试磁盘写能力
代码如下:
time dd if=/dev/zero of=/testw.dbf bs=4k count=100000
因为/dev//zero是一个伪设备,它只产生空字符流,对它不会产生IO,所以,IO都会集中在of文件中,of文件只用于写,所以这个命令相当于测试磁盘的写能力。命令结尾添加oflag=direct将跳过内存缓存,添加oflag=sync将跳过hdd缓存。
3、测试磁盘读能力
代码如下:
time dd if=/dev/sdb of=/dev/null bs=4k
因为/dev/sdb是一个物理分区,对它的读取会产生IO,/dev/null是伪设备,相当于黑洞,of到该设备不会产生IO,所以,这个命令的IO只发生在/dev/sdb上,也相当于测试磁盘的读能力。(Ctrl+c终止测试)
4、测试同时读写能力
代码如下:
time dd if=/dev/sdb of=/testrw.dbf bs=4k
在这个命令下,一个是物理分区,一个是实际的文件,对它们的读写都会产生IO(对/dev/sdb是读,对/testrw.dbf是写),假设它们都在一个磁盘中,这个命令就相当于测试磁盘的同时读写能力。
在Linux下面/proc/pid/maps,这个文件里面保存了执行进程的所有内存映射情况以及内存属性,在程序里面可以通过读该文件进行判断内存是否可写。有些人会认为,有必要吗,调用者要确保传入的参数是正确的,听起来也有道理,但在某些场合,就是因为用户传入参数出错,或这个参数被踩了,导致这个函数写内存而崩溃,是不允许的。 下面这个函数可以检查输入地址和一个长度,检查这个范围中,是否都可以写。 #include #include int check_mem_wrtieable(unsigned long addr, int len){pid_t pid char access, maps[32] , buff[1024]unsigned long start_addr, end_addr, last_addrFILE *fmappid = getpid()sprintf(maps, "/proc/%d/maps", pid)fmap = fopen(maps, "rb")if(!fmap){printf("open %s file failed!/n", maps)return 0} while(fgets(buff, sizeof(buff)-1, fmap) != NULL) {/* "%*c"表示忽略第一个字符 */sscanf(buff, "%lx-%lx %*c%c", &start_addr, &end_addr, &access)if((addr >= start_addr) &&(addr欢迎分享,转载请注明来源:内存溢出
评论列表(0条)