我打開一個套接字將請求直接發送到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