使用pthreads时的后台线程(不错,优先级)

Mar*_*tts 5 c c++ linux pthreads

我有一个GUI应用程序,它使用pthreads进行一些繁重的后台处理.

在后台处理正在运行时,GUI非常无响应,我认为这是因为后台线程正在耗尽CPU时间.

在Windows上你可以在后台线程上设置:: SetThreadPriority(hThread,THREAD_PRIORITY_BELOW_NORMAL),一切都很好.

但是在Linux上我使用的是pthreads,我找不到一个好的选择.

我已经考虑过了;

  • :: sched_setscheduler(SCHED_FIFO)或:: sched_setscheduler(SCHED_RR) - 这是不可行的,因为它需要root(对我的GUI应用程序不好) - 这也会使GUI线程拥有太多的CPU; 我只希望GUI优先于后台线程.
  • :: pthread_setschedparam但是当使用不支持SCHED_FIFO或SCHED_RR以外的任何东西时(:: sched_get_priority_min(SCHED_OTHER)和:: sched_get_priority_max(SCHED_OTHER)都返回0)
  • 有多个进程并使用:: nice.GUI和后台线程之间存在太多耦合以使其可行(并且为此设计移植如此多的代码是一项大量工作)
  • 使用:: setpriority重新调整后台线程.这确实有效 - 但是直接反对文档所说的内容:PThreads文档(因此可能会在以后的系统中"修复")

我确信这是GUI应用程序的一种常见模式,所以我错过了什么?

马库斯.

编辑:添加:: setpriority到选项列表(感谢ZalewaPL)

Zal*_*aPL 3

将后台线程的好值设置为更高的值可能会有所帮助。
请参阅: pthreads 的 Nice-Level?

  • 谢谢,我确实考虑过这一点,但文档提到了进程而不是线程。虽然它*确实*适用于线程(我刚刚测试过它)-但我对于依赖直接违背文档所说的东西并不感到高兴(http://www.kernel.org/doc/man-页面/在线/页面/man7/pthreads.7.html) (2认同)