草庐IT

pthread_sigmask

全部标签

php - 如何在 Ubuntu 中使用 Pthreads PHP 扩展

我对PthreadsPHPextension有疑问.我在启用ZTS(--enable-maintainer-zts)的情况下编译了PHP,并通过pecl安装了pthreads,还尝试手动编译扩展。我好像真的不知道怎么用。我假设我可以像使用任何其他内置类一样在PHP中使用Thread类,但没有运气,因为PHP无法识别它。POSIX函数似乎有效。我正在使用Ubuntu12.10服务器64位和mod_php5.4.6。 最佳答案 如果您无法访问扩展类,则不会加载它。我想你打开了一个错误报告,我回复说你的配置行格式不正确。您要使用的配置行是

c++ - pthread_key_t 和 pthread_once_t?

从pthreads入手,看不懂pthread_key_t和pthread_once_t有什么关系?如果可能的话,有人会用简单的语言举例说明吗?谢谢 最佳答案 pthread_key_t用于创建线程thread-localstorage:每个线程都有自己的数据变量拷贝,而不是所有线程共享一个全局(或函数静态、类静态)变量。TLS由一个键索引。参见pthread_getspecific等人了解更多详情。pthread_once_t是一个用pthread_once只执行一次函数的控件.假设您必须调用一个初始化例程,但您只能调用该例程一次。

c++ - 对符号 'pthread_create@@GLIBC_2.2.5' 的 undefined reference

我刚刚拉取了一个git存储库,我和我的friend正在其中开发一个应用程序。当我运行ma​​ke时,我遇到了这个错误:undefinedreferencetosymbol'pthread_create@@GLIBC_2.2.5'/lib/x86_64-linux-gnu/libpthread.so.0:erroraddingsymbols:DSOmissingfromcommandlinecollect2:error:ldreturned1exitstatusMakefile:182:recipefortarget'bin/release/ns'failedmake[1]:*[bin/

c++ - 取消 pthread_cond_wait() 挂起与 PRIO_INHERIT 互斥锁

2012年4月10日更新:Fixedbylibcpatch我在pthread_cond_wait中取消线程时遇到问题,将互斥锁与PTHREAD_PRIO_INHERIT一起使用属性集。不过,这只发生在某些平台上。以下最小示例演示了这一点:(使用g++.cpp-lpthread编译)#include#includepthread_mutex_tmutex;pthread_cond_tcond;voidclean(void*arg){std::cout每次我运行它,main()卡在pthread_join().gdb回溯显示如下:Thread2(Thread0xb7d15b70(LWP25

c++ - 使用 Pthreads 捕获异常

虽然这个问题不限于OpenKinect库,但它是我能想出的最好的例子来展示它。在OpenKinect的C++包装器中,每当出现问题时,它都会抛出runtime_error异常。这个例子来自libfreenect.hpp。线程在类的构造函数中创建。//Donotcalldirectly,threadrunsherevoidoperator()(){while(!m_stop){if(freenect_process_events(m_ctx)(user_data);(*freenect)();returnNULL;}我的问题很简单:是否有可能以某种方式捕获并处理这些错误?通常,我会处理异

c++ - 从静态构造函数代码调用时 pthread 库失败

我有一个包含GLiblibrary的C++共享库对象。当我创建一个带有空main()函数的最小测试程序,并链接到共享库时,该程序在运行时立即中止,并显示以下GLib错误信息:GLib(gthread-posix.c):UnexpectederrorfromClibraryduring'pthread_cond_init':Invalidargument.Aborting.因为我的主函数是空的,错误一定是在某个地方的某个预主初始化函数中发生的。因此,使用GDB我发现GLib有一个静态初始化构造函数(在glib-init.c中),它在运行时调用main()之前。在该初始化函数中,它调用了p

c++ - 使用 native_handle() + pthread_cancel() 取消 std::thread

我正在将之前围绕pthreads的线程包装器转换为std::thread。但是c++11没有办法取消线程。尽管如此,我还是需要取消线程,因为它们可能正在外部库中执行非常冗长的任务。我正在考虑在我的平台中使用给我pthread_id的native_handle。我在Linux(Ubuntu12.10)中使用gcc4.7。这个想法是:#include#include#includeusingnamespacestd;intmain(intargc,char**argv){cout线程被pthreads抛出的异常取消。我的问题是:这种做法会不会有什么问题(除了不可移植)?

c++ - Pthread 程序运行速度随着线程的增加而变慢

我是并行编程的初学者,我尝试使用pthread库编写并行程序。我在8处理器计算机上运行该程序。问题是,当我增加NumProcs时,每个线程都会变慢,尽管它们的任务总是相同的。有人可以帮我弄清楚发生了什么吗?`#defineMAX_NUMP16usingnamespacestd;intNumProcs;pthread_mutex_tSyncLock;/*mutex*/pthread_cond_tSyncCV;/*conditionvariable*/intSyncCount;/*numberofprocessorsatthebarriersofar*/pthread_mutex_tThr

c++ - pthread-win32 扩展 sem_post_multiple

我目前正在围绕pthreads构建一个薄的C++包装器供内部使用。Windows和QNX都是目标,幸运的是pthreads-win32端口似乎工作得很好,而QNX符合我们实际目的的POSIX。现在,在实现信号量时,我点击了函数sem_post_multiple(sem_t*,int)这显然只在pthreads-win32上可用,但在QNX中缺失。顾名思义,该函数应该通过作为第二个参数给出的计数来增加信号量。据我所知,该函数既不是POSIX1b也不是POSIX1c的一部分。虽然目前对上述功能没有要求,但我仍然想知道为什么pthreads-win32提供该功能以及它是否有用。我可以尝试使用

c++ - 关于pthread调度器和优先级的问题

我在Debian7上使用gccc++4.7。我想为我的线程设置一些优先级。看起来我必须通过pthread来完成。我对pthread中的调度程序策略和优先级感到困惑。问题1:我在我的C++代码中使用sched_setscheduler将线程调度程序设置为SCHED_RR。这个进程中的所有线程都会使用这个实时调度程序吗?或者我可以在一个进程中为不同的线程设置不同的调度程序策略?问题2:线程优先级是只在进程内部生效还是跨进程生效?例如。我有两个进程都使用SCHED_RR。一个有一个优先级为99的线程,另一个有一个优先级为98的线程。前一个线程的优先级是否高于后者?如果线程使用不同的调度程序怎