我打开一个套接字将请求直接发送到X服务器(绕过使用Xlib/XCB)。针对UNIX套接字的缓冲写入?
#define X11_OP_REQ_CREATE_WINDOW 0x01
#define X11_OP_REQ_MAP_WINDOW 0x08
#define X11_OP_REQ_CREATE_PIX 0x35
#define X11_OP_REQ_CREATE_GC 0x37
#define X11_OP_REQ_PUT_IMG 0x48
...
struct sockaddr_un serv_addr = {0};
int socketfd = socket(AF_UNIX, SOCK_STREAM, 0); // Create the socket!
serv_addr.sun_family = AF_UNIX;
strcopy(serv_addr.sun_path, "/tmp/.X11-unix/X0", 0);
int srv_len = sizeof(struct sockaddr_un);
connect(socketfd,(struct sockaddr*)&serv_addr, sizeof(serv_addr));
我必须做一堆write()
S,虽然,我知道,这个文件可能是慢了很多比fwrite
,由于缓冲,因为系统调用是昂贵的。是否有与套接字一起使用的等效函数?甚至有可能用套接字来做缓冲IO? (没关系该fwrite
需要FILE*
流过,而所有我已经是一个描述符。)
这里的发送(使用write
)这样的要求的功能的一个例子。
void x11_put_img(int socketfd, struct x11_connection* conn, uint8 format, uint32 target, uint32 gc, uint16 w, uint16 h, uint16 x, uint16 y, uint8 depth, uint32* data){
uint32 packet[6];
uint16 length = ((w*h)) + 6;
packet[0] = X11_OP_REQ_PUT_IMG | format<<8 | length<<16;
packet[1] = target;
packet[2] = gc;
packet[3] = w | h<<16;
packet[4] = x | y<<16;
packet[5] = depth<<8;
write(socketfd, packet, 24);
write(socketfd, data, (w*h)*4);
return;
}
(没有错误检查,为简单起见。)
不知道你是怎么想的。通常,如果您通过套接字发送某个内容,则需要在发送下一个命令之前进行回复。通过缓冲写入,您还可以缓冲读取和某种消息队列。不知道这是否真的值得开销。 – Olaf
[writev](http://man7.org/linux/man-pages/man2/readv.2.html)? – rici