我一直在为如何安排这件事而烦恼。我在网上找到了如何进行阅读和写作的信息,但我对如何同时进行阅读和写作感到困惑。我需要启动两个事件基循环吗?或者我能用一个吗?下面是我在网上找到的用于发送的代码示例(省略回调函数):
int err;
#ifdef _WIN32
WORD wVersionRequested;
WSADATA wsaData;
/* Use the MAKEWORD(lowbyte, highbyte) macro declared in Windef.h */
wVersionRequested = MAKEWORD(2, 2);
err = WSAStartup(wVersionRequested, &wsaData);
if (err != 0) {
/* Tell the user that we could not find a usable */
/* Winsock DLL. */
printf("WSAStartup failed with error: %d\n", err);
return false;
}
#endif
struct event_base *base;
struct bufferevent *bev;
struct sockaddr_in sin;
base = event_base_new();
memset(&sin, 0, sizeof(sin));
sin.sin_family = AF_INET;
sin.sin_addr.s_addr = htonl(0x7f000001); /* 127.0.0.1 */
sin.sin_port = htons(22346);
bev = bufferevent_socket_new(base, -1, BEV_OPT_CLOSE_ON_FREE);
bufferevent_setcb(bev, NULL, NULL, eventcb, NULL);
bufferevent_enable(bev, EV_READ|EV_WRITE);
evbuffer_add_printf(bufferevent_get_output(bev), "WOOOOOOOOOOOOOO");
if (bufferevent_socket_connect(bev,
(struct sockaddr *)&sin, sizeof(sin)) < 0) {
/* Error starting connection */
bufferevent_free(bev);
return -1;
}
event_base_dispatch(base);
发布于 2014-03-09 13:14:52
首先,您应该使用bufferevent_write()
而不是较低级别的evbuffer_add_printf()
-前者更干净,底层的evbuffer_add_printf()
可能会被冻结。
您还禁用了读和写回调-因此,当您可以从缓冲区事件读取时,您将不会得到回调。至少实现读取回调,并通过bufferevent_setcb()
设置它。也许这就是你没看到任何事情发生的原因。
接下来,可能你要么:
bufferevent_write()
回调中获得连接事件(BEV_EVENT_CONNECTED
)时使用eventcb
。https://stackoverflow.com/questions/22260369
复制相似问题