libevent(6)windows上使用iocp网络模型

news/2024/11/7 20:51:50/

windows操作系统上不能使用epoll模型,只能使用iocp网络模型。这里我把怎么在windows上使用iocp的代码直接贴上:


#include <iostream>
#include <signal.h>
#include <event2/event.h>
#include <event2/listener.h>
#include <event2/thread.h>#define SPORT 5001void listen_cb(struct evconnlistener* ev,evutil_socket_t s,struct sockaddr* addr,int socketLen,void* arg) {std::cout << "listen_cb event_base_new success!" << std::endl;
}int main()
{
#ifdef _WIN32//windows初始化socket库WSADATA wsa;WSAStartup(MAKEWORD(2, 2), &wsa);
#else//发送数据给已关闭socket时,忽略管道信息.//否则可能导致程序dump.if (signal(SIGPIPE, SIG_IGN) == SIG_ERR) {return -1;}
#endif//创建配置上下文event_config* conf = event_config_new();//设置网络模型,使用select//event_config_avoid_method(conf, "epoll");//event_config_avoid_method(conf, "poll");//window支持iocp
#ifdef _WIN32event_config_set_flag(conf, EVENT_BASE_FLAG_STARTUP_IOCP);// 初始化IOCP线程(必须要有)evthread_use_windows_threads();//设置cpu数量SYSTEM_INFO si;GetSystemInfo(&si);event_config_set_num_cpus_hint(conf, si.dwNumberOfProcessors);
#endif//初始化libevent配置上下文event_base* base = event_base_new_with_config(conf);event_config_free(conf);if (!base) {std::cerr << "event_base_new_with_config failed!" << std::endl;}else {std::cout << "event_base_new_with_config success!" << std::endl;//获取当前网络模型std::cout << "current method is:" << event_base_get_method(base) << std::endl;struct sockaddr_in sin;memset(&sin, 0, sizeof(sin));sin.sin_family = AF_INET;sin.sin_port = htons(SPORT);evconnlistener* ev = evconnlistener_new_bind(base,  // libevent上下文listen_cb,  // 接收连接的回调函数base,  // 回调函数获取的参数LEV_OPT_REUSEABLE | LEV_OPT_CLOSE_ON_FREE,  // 设置地址重用和关闭同时关闭socket10, // 连接队列大小,对应listen函数(struct sockaddr*)&sin, // 绑定socket地址和端口sizeof(sin));event_base_dispatch(base);evconnlistener_free(ev);event_base_free(base);}#ifdef _WIN32//清理window的socket库WSACleanup();
#endifreturn 0;
}

运行后,我们在任务管理器里就可以看到程序进程的线程数目:我这里是11个线程。


http://www.ppmy.cn/news/622446.html

相关文章

t5、bart源码讲解

一直做nlu的任务比较多&#xff0c;所以对bart和t5这类生成式模型了解不多&#xff0c;这里收藏一些不错的源码讲解 BART源码剖析&#xff08;transformers 4.9.0&#xff09;T5: the Text-To-Text Transfer Transformer - transformers API使用方法(源码解析)

win7,远程桌面连接如何调用 C2050 卡

今天测试的时候发现&#xff0c;客户远程桌面连接测试服务器&#xff0c;无法调用GPU卡。 背景&#xff1a;测试服务器安装的是windows7 64位操作系统&#xff0c;GPU卡的型号是C2050。 研究发现&#xff1a; 1. Windows 7 操作系统&#xff0c;如果安装K20等GPU卡&#…

C语言中c2050是什么错误,C语言常见错误指令-2017年10月.pptx

C语言常见错误指令 C语言常见错误指令fatal?error?C1003:?error?count?exceeds?number;?stopping?compilation?错误太多&#xff0c;停止编译分析&#xff1a;修改之前的错误&#xff0c;再次编译 ?fatal?error?C1004:?unexpected?end?of?file?found?文件未结…

hdu-2050 折线分割平面

我们看到过很多直线分割平面的题目&#xff0c;今天的这个题目稍微有些变化&#xff0c;我们要求的是n条折线分割平面的最大数目。比如&#xff0c;一条折线可以将平面分成两部分&#xff0c;两条折线最多可以将平面分成7部分&#xff0c;具体如下所示。 Input 输入数据的第一…

2050 折线分割平面

题目详情 折线分割平面 Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others) Total Submission(s): 55127 Accepted Submission(s): 36070 Problem Description 我们看到过很多直线分割平面的题目&#xff0c;今天的这个题目稍微有些变…

杭电OJ第11页2050~2054算法题(C语言)

目录 2050.折线分割平面2051.Bitset2052.Picture2053.Switch Game2054.A B ? 2050.折线分割平面 Problem Description 我们看到过很多直线分割平面的题目&#xff0c;今天的这个题目稍微有些变化&#xff0c;我们要求的是n条折线分割平面 的最大数目。比如&#xff0c;一条折…

通过KXTF9-2050芯片分析I2C协议

1、I2C协议 参见博客&#xff1a;《I2C通信协议详解和通信流程分析》。 2、I2C驱动的框架分析 (1)驱动框架分为两层&#xff1a;物理层和协议层。物理层是通用的&#xff0c;取决于主设备&#xff1b;协议层则每个从设备都不同。 (2)物理层&#xff1a;物理层可以理解成通用层&…