草庐IT

linux - fsync(fd) 是否适用于外部程序创建的文件?

我有一个禁用了写入缓存的SATA硬盘:hdparm-W0/dev/foo我在一个ext4分区上使用这些挂载选项(以及其他):data=orderedauto_da_allocLinux内核版本为2.6.32-5-686。现在,我有一个我无法修改的外部程序,但我知道它会按以下方式创建一个文件:intfd=open(path);write(fd,data,data_size);close(fd);即它在关闭前不同步。所以在这一点上,数据可能在RAM中,在内核/fs缓存中的某个地方。注意:元数据还不是问题:最终的元数据将在我确定数据已到达磁盘盘片后写入并同步。数据本身就是问题。那么问题来了,

linux - fsync(fd) 是否适用于外部程序创建的文件?

我有一个禁用了写入缓存的SATA硬盘:hdparm-W0/dev/foo我在一个ext4分区上使用这些挂载选项(以及其他):data=orderedauto_da_allocLinux内核版本为2.6.32-5-686。现在,我有一个我无法修改的外部程序,但我知道它会按以下方式创建一个文件:intfd=open(path);write(fd,data,data_size);close(fd);即它在关闭前不同步。所以在这一点上,数据可能在RAM中,在内核/fs缓存中的某个地方。注意:元数据还不是问题:最终的元数据将在我确定数据已到达磁盘盘片后写入并同步。数据本身就是问题。那么问题来了,

c - select 只检查 fds 直到 255 直到 FD_SETSIZE

选择高于255的fds不检查fd是否打开。这是我的示例代码:#include#include#include#includeintmain(){fd_setset;for(inti=5;iiis%d\n",i);FD_ZERO(&set);FD_SET(i,&set);close(i);intretval=select(FD_SETSIZE,&set,NULL,NULL,NULL);if(-1==retval){perror("select");}}}这导致:-->iis5select:Badfiledescriptor...-->iis255select:Badfiledescrip

c - select 只检查 fds 直到 255 直到 FD_SETSIZE

选择高于255的fds不检查fd是否打开。这是我的示例代码:#include#include#include#includeintmain(){fd_setset;for(inti=5;iiis%d\n",i);FD_ZERO(&set);FD_SET(i,&set);close(i);intretval=select(FD_SETSIZE,&set,NULL,NULL,NULL);if(-1==retval){perror("select");}}}这导致:-->iis5select:Badfiledescriptor...-->iis255select:Badfiledescrip

python - 有人有 Linux 上 fd_set 的 gdb pretty-print 代码吗?

现代版本的gdb允许集成python代码以“pretty-print”复杂的数据结构。对于C++的STL类以及一些更常见的boost.org类型,有一些非常pretty-print实现。在网络编程中,经常会遇到select/poll调用。poll()使用数据结构数组,而select()使用fd_set。有没有人遇到过fd_set的pretty-print实现,最好是可移植的,但即使是特定于平台的也可以。理想情况下,它是linux/x86,但我愿意接受任何东西并希望能够适应。 最佳答案 好吧,这是我写的东西,它似乎在Linux下对我有

python - 有人有 Linux 上 fd_set 的 gdb pretty-print 代码吗?

现代版本的gdb允许集成python代码以“pretty-print”复杂的数据结构。对于C++的STL类以及一些更常见的boost.org类型,有一些非常pretty-print实现。在网络编程中,经常会遇到select/poll调用。poll()使用数据结构数组,而select()使用fd_set。有没有人遇到过fd_set的pretty-print实现,最好是可移植的,但即使是特定于平台的也可以。理想情况下,它是linux/x86,但我愿意接受任何东西并希望能够适应。 最佳答案 好吧,这是我写的东西,它似乎在Linux下对我有

C write() 在调用 close(fd) 之前不发送数据

所以我有这个测试代码可以通过USB串行端口发送“HELLO”:intfd;structtermiostty;if((fd=open("/dev/ttyUSB0",O_WRONLY|O_NONBLOCK|O_NOCTTY))==-1){err(1,"Cannotopenwriteon/dev/ttyUSB0");}tcgetattr(fd,&tty);tty.c_iflag=0;tty.c_oflag=0;tty.c_lflag=0;tty.c_cflag=0;tty.c_cc[VMIN]=0;tty.c_cc[VTIME]=0;cfsetospeed(&tty,B19200);cfse

C write() 在调用 close(fd) 之前不发送数据

所以我有这个测试代码可以通过USB串行端口发送“HELLO”:intfd;structtermiostty;if((fd=open("/dev/ttyUSB0",O_WRONLY|O_NONBLOCK|O_NOCTTY))==-1){err(1,"Cannotopenwriteon/dev/ttyUSB0");}tcgetattr(fd,&tty);tty.c_iflag=0;tty.c_oflag=0;tty.c_lflag=0;tty.c_cflag=0;tty.c_cc[VMIN]=0;tty.c_cc[VTIME]=0;cfsetospeed(&tty,B19200);cfse

c - 从 C 中的系统命令启动的进程继承父 fd 的

我有一个在tcp和udp端口​​5060上监听的SIP服务器示例应用程序。在代码中的某个点,我做了一个system("pppdfile/etc/ppp/myoptions&");在此之后,如果我执行netstat-apn,它会显示端口5060也已为pppd打开!有什么方法可以避免这种情况吗?这是Linux系统功能的标准行为吗?谢谢,埃利森 最佳答案 是的,默认情况下,无论何时您fork一个进程(system所做的),子进程都会继承父进程的所有文件描述符。如果child不需要这些描述符,它应该关闭它们。使用system(或执行fork

c - 从 C 中的系统命令启动的进程继承父 fd 的

我有一个在tcp和udp端口​​5060上监听的SIP服务器示例应用程序。在代码中的某个点,我做了一个system("pppdfile/etc/ppp/myoptions&");在此之后,如果我执行netstat-apn,它会显示端口5060也已为pppd打开!有什么方法可以避免这种情况吗?这是Linux系统功能的标准行为吗?谢谢,埃利森 最佳答案 是的,默认情况下,无论何时您fork一个进程(system所做的),子进程都会继承父进程的所有文件描述符。如果child不需要这些描述符,它应该关闭它们。使用system(或执行fork