我正在开发一个使用
epoll library的C中的服务器,我有一个关于如何处理struct epoll_event的内存的问题.我在一些在线例子中注意到,当进行epoll_ctl调用时,事件参数被分配在堆栈上,然后指针被传递,如下所示:
struct epoll_event ev; ev.events = EPOLLIN; epoll_ctl(epfd,EPOLL_CTL_ADD,sockfd,&ev);
现在我们都知道当函数返回时,ev发生了什么.我的问题是:epoll库是否在内部产生这些值的副本,还是依赖于您传递给堆分配的结构?上述示例会完全打破我的反应堆实施吗?如果是这样,最好的方法是跟踪我的堆分配的epoll_event结构体?
谢谢你的时间.