草庐IT

Thread_pool_pattern

全部标签

Windows 服务应用程序上的 Java5 - 获取 Full Thread Dump 需要说明

我在这里浏览了几篇文章,例如:javastackdumponwindowsThreaddumpprogrammatically/JDI(JavaDebuggerInterface)但没有得到确切的答案。问题:Windows上有一个作为服务运行的Java5应用程序(因此我们没有可以使用Ctrl+Break进行转储的控制台)。有时应用程序挂起,我们需要一个线程转储。我们试过“jstack”但它在我们的环境中不起作用(我们发现它只兼容Java6)。所以我们制作了一个C++应用程序,它通过附加到Java应用程序进程的.dll调用方法调用线程转储,因此它需要本地管理员权限,这不是很好。因此,我们

python - 在 python 中使用 map.pool 有什么问题?

我有一个正在运行的命令行程序,我通过管道输入文本作为参数:somecommand.exe它会运行一段时间(通常是一小部分到几个小时),然后将结果写入许多文本文件。我正在尝试编写一个脚本来同时启动其中的几个,使用多核机器上的所有内核。在其他操作系统上,我会fork,但在Windows的许多脚本语言中都没有实现。Python的多处理看起来可以解决问题,所以我想我会试一试,尽管我根本不懂python。我希望有人能告诉我我做错了什么。我写了一个脚本(如下),我指向一个目录,如果找到可执行文件和输入文件,并使用pool.map和n的池启动它们,以及使用调用的函数。我看到的是,最初(启动了第一组n

windows - 是否可以将断点条件设置为 "break when called by another thread"?

我正在调查一个可能由多线程引起的问题。数据不断被一个线程读取,我想看看它是否被另一个线程读取。我可以设置断点并按住F5并检查它是否在另一个线程中中断,但这有点烦人。是否可以将断点条件设置为“被另一个线程调用时中断”? 最佳答案 您可以设置一个过滤器(参见UsingBreakpoints)。例如,可以在ThreadId上设置过滤器。要设置过滤器,请右键单击断点,选择Conditions...,然后输入ThreadId!=作为过滤器表达式。确保表达式中没有任何空白字符。否则,您将收到一条不太有用的错误消息。

linux - "Thread.sleep(30000)"在 Windows 和 Linux 上的工作方式是否相同?

我怀疑“Thread.sleep()”在Windows和Linux上的工作是否相同?现在我正在开发一个企业应用程序,我正在使用springmvc框架工作。现在的问题是,我的一个函数中有这一行“Thread.sleep(30000)”。这里的值“30000”表示“30秒”的sleep,它在我的本地系统(Windows操作系统)上工作正常。当我在Linux服务器上部署我的应用程序时,我怀疑“Thread.sleep(30000)”没有按预期工作。 最佳答案 如果您的服务器在Linux下运行,您可能会遇到LeapSecond错误看这里Le

c++ - 多线程独立任务

我有N个任务,它们是独立的(即,写入不同的内存地址)但完成时间并不完全相同(比如2到10秒)。我有P个线程。我可以将我的N个任务分成P个线程,然后启动我的线程。最终,在最后,将剩下一个线程来完成最后几个任务,这不是最优的。我还可以启动P个线程,每个线程有1个任务,WaitForMultipleObjects,然后重新启动P个线程等(这就是我目前所做的,因为与任务相比,创建线程的开销很小)。但是,这也没有解决问题,仍然会有P-1个线程在某个时候等待最后一个。有没有办法启动线程,一旦线程完成任务,就继续执行下一个可用任务,直到所有任务完成?谢谢! 最佳答案

c++ - 在 win32::WaitForSingleObject 期间 Windows 上的 Boost.Thread 断言/崩溃

我的代码中有一个很少发生的问题会触发断言,涉及Boost.Thread库。我无法使用独立示例重现此问题,而且我也不知道是什么原因造成的,因此很难提供示例案例。我希望任何熟悉boost.thread内部结构的人都能提供帮助。这是我知道的:问题发生在boost::lock_guard(或unique_lock和普通非递归互斥锁的变体)被声明。它发生在Boost.Asio的处理函数中。堆栈上是执行io_service::run的线程,一堆调用Asio回调函数的胶水,然后是我的回调函数(由async_write调用触发)。该函数的第一行是lock_guard的声明这是导致问题的原因。this我

Windows 内核 - 是否有类似 ExGetPoolsForTag(pool_tag) 的东西?

这是关于Windows内核驱动程序和内存管理的。我真的很好奇是否有一个函数(或者任何不方便的方法)来获取(或迭代)特定池标签的所有内存分配?这些是使用ExAllocatePoolWithTag(type,size,tag)...有使用特定池标签的内核函数,现在我需要找到使用该标签进行的所有分配?我比较确定这是不可能的(出于安全原因),但仍需要对此进行确认。干杯,将更新:(关于下面的WinDbg评论)kd>!poolfindObFlScanninglargepoolallocationtableforTag:ObFl(fffffa8002290000:fffffa8002350000)S

windows - 为什么 python 中的 pool.map 不起作用

importmultiprocessingasmuldeff(x):returnx**2pool=mul.Pool(5)rel=pool.map(f,[1,2,3,4,5,6,7,8,9,10])print(rel)当我运行上面的程序时,应用程序卡在一个循环中,无法停止。我在Windows中使用python3.5,有什么问题吗?这是我在屏幕上看到的:我是财务数据分析的新手;我正试图找到一种方法来通过并行计算解决大数据问题。 最佳答案 它不起作用,因为您是在shell中键入命令;尝试将代码保存在文件中并直接运行。不要忘记正确复制代码,

函数内的Python多处理: calling pool.映射

我正在尝试使用mutltiprocessing包在一个函数中使用多个CPU。当我在函数外部运行玩具示例时,它会在四分之一秒内运行,没有任何问题(见下文)。frommultiprocessingimportPoolimporttimestart=time.clock()deff(x):returnx*xif__name__=='__main__':withPool(processes=7)aspool:result=pool.map(f,range(1000))print(time.clock()-start)但是,当我将相同的代码改编成一个函数时(见下文),它会打印True以指示__n

c++ - Boost 1.66.0 : could not find boost libraries :boost_system, boost_filesystem、boost_thread、boost_date_time

我的配置是:操作系统:Windows10x64boost:1.66.0CMake:3.10VisualStudio:2017我正在以这种方式编译boost:bootstrap.\b2--build-dir=buildtoolset=msvcaddress-model=64--build-type=completestage运行CMake时出现此错误:couldnotfindboostlibraries:boost_systemboost_filesystemboost_threadboost_localeboost_date_time我搜索这些库,它们位于stage文件夹中。我尝试了B