系统IO与标准IO
-
当系统调用被执行时,需要从用户态转换成内核态,执行完毕后又要转回用户态,如果频繁来回切换会导致性能丢失
-
在标准IO中,内部维护一个缓冲区(1k,1024字节),要写入的数据先存储到缓冲区中,只有当满足特定条件时才会把缓冲区中数据全部通过系统调用write写入文件,从而降低了系统调用的使用频率,减少了状态的切换,因此标准IO的效率要比直接使用系统IO要快
-
如果想要提高系统IO的速度,可以尝试自己维护一个缓冲区,先把数据存储到缓冲区,等满后再调用write,这样提高速度
-
普通情况下建议使用标准IO,因为更快,如果对速度还有更高的要求,可以自己使用系统IO+大缓冲区
void sys_io(void) { int fd = open("test.txt",O_WRONLY|O_CREAT|O_TRUNC,0644); if(0 > fd) { perror("open"); return; } int buf[1024] = {}; for(int i=0; i<10000000; i++) { int num = rand(); buf[i%1024] = num; if(0 == (i+1)%1024) { write(fd,buf,sizeof(buf)); } } close(fd); }
-
UNIX/Linux只有一套读写文件的系统调用,没有像标准C中的文本读写 ,那么可以先把数据转换成字符串(sprintf/sscanf),然后再通过write\read读写,从而实现文本读写的效果