概述我有一个使用epoll(7)的多线程 linux程序. epoll(7)手册页说当其中一个fds关闭时,这个fd将自动从epoll集中删除.我的问题是如果epoll集的fd在一个线程中关闭,而epoll集在另一个线程中被同时轮询而没有同步.程序是否会损坏或者内核会自动同步此访问吗? 谢谢 丰 epoll集中的fds由内核维护,因此您是安全的 – 内核处理任何必要的同步. 也就是说,在fd关闭之前, 我有一个使用epoll(7)的多线程 linux程序. epoll(7)手册页说当其中一个fds关闭时,这个fd将自动从epoll集中删除.我的问题是如果epoll集的fd在一个线程中关闭,而epoll集在另一个线程中被同时轮询而没有同步.程序是否会损坏或者内核会自动同步此访问吗?
谢谢
丰
解决方法 epoll集中的fds由内核维护,因此您是安全的 – 内核处理任何必要的同步.
也就是说,在fd关闭之前,fd上的事件仍有可能进入另一个线程.因此,有可能从fd中获得一个不再出现在集合中的事件.通过精心设计的程序,这不应该导致问题.
总结
以上是内存溢出为你收集整理的linux中多线程epoll的问题全部内容,希望文章能够帮你解决linux中多线程epoll的问题所遇到的程序开发问题。
如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。
评论列表(0条)