首页 > 代码库 > 项目中libevent几个问题
项目中libevent几个问题
几个问题:1.libevent到底用的是select还是iocp,然后是如何突破64限制的typedef struct fd_set { u_int fd_count; /* how many are SET? */ SOCKET fd_array[FD_SETSIZE]; /* an array of SOCKETs */} fd首先libevent使用的是select,至于为什么不用iocp,有可能没有实现#define FD_SETSIZE 64看到这个就以为最多是64个连接,那时因为这个是在暂时分配栈的内存,如果分配在堆上就可以解决看Libevent里面struct win_fd_set {u_int fd_count;SOCKET fd_array[1];};然后在堆上分配内存,就可以动态指定大小,只要内存可以存放具体看http://www.cnblogs.com/ayanmw/p/3467373.html2.客户端为什么要监听看到客户端监听的端口比较随便,所以个人判断这个监听是没用的,也许只是为了和服务端的代码重用,主要是为了使用下面的派发线程m_spThread.reset(new std::thread([this]{ //SetThreadPriority(GetCurrentThread(), THREAD_PRIORITY_HIGHEST); //event_base_loop(m_base, EVLOOP_ONCE); event_base_dispatch(m_base); if(WSAENOTSOCK == WSAGetLastError()) { Plug::PlugMessageBox(L"操作无效套接字啊!"); } Plug::PlugMessageBox(L"Libevent派发线程退出!");}));3.什么时候调用读事件和写事件,往哪儿写,从哪儿读当input有数据的时候调用读事件,当Output为空的时候调用写事件读是从Input读,写是往output写bufferevent_setcb(bev, conn_readcb, NULL, conn_eventcb, c2);//NULL表示bufferevent不会进行数据的读取或者写入bufferevent_enable(bev, EV_READ | EV_WRITE );服务器不用设置写事件,而是自己调用bufferevent_write向output写入数据的客户端设置了写事件,然后也是自己调用的bufferevent_write,但这个写事件回调里面没做什么东西,只有当output没有数据的时候才会调用这个写事件3.channelid到底对应的是啥,到底是如何实现这么多客户端并发的:现在知道channelid对应一个bufferevent,而bufferevent对应一个socket,这样就确定是哪个客户端了,然后select模式知道哪些socket可读,可写,然后就自动的往socket写,或者从socket读4.两句代码的理解 //设置读写回调,当input有数据的时候需要调用conn_readcb,这个是libevent自动调用的 bufferevent_setcb(bev, conn_readcb, conn_writecb, conn_eventcb, c2); //我去这个有点坑啊,这个EV_WIRTE是默认设置的,bufferevent_get_enabled默认得到的是6 //EV_WRITE和EV_READ是指socket和缓冲区之间的读和写 bufferevent_enable(bev, EV_READ);5.写事件至于服务器为什么不设置写回调函数,真心不知道,这个还真不太清楚为啥,但客户端设置了
项目中libevent几个问题
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。