我的代码中有一个很少发生的问题会触发断言,涉及 Boost.Thread 库。我无法使用独立示例重现此问题,而且我也不知道是什么原因造成的,因此很难提供示例案例。我希望任何熟悉 boost.thread 内部结构的人都能提供帮助。
这是我知道的:
boost::lock_guard<boost::recursive_mutex> (或 unique_lock 和普通非递归互斥锁的变体)被声明。io_service::run 的线程,一堆调用 Asio 回调函数的胶水,然后是我的回调函数(由 async_write 调用触发)。该函数的第一行是 lock_guard<> 的声明这是导致问题的原因。this我的函数内部是有效的,并且没有被删除或类似的东西。调试器显示它指向有效数据。锁定在我的 handle_write 中的互斥量函数还防止删除处理函数使用的内存。lock()互斥量的方法(在 boost::unique_lock<> 的构造函数中),然后调用 lock()在boost::detail::basic_recursive_mutex_impl ,它调用 lock() boost::detail::basic_timed_mutex的方法| .在 Boost 1.46 中,断言 ( BOOST_VERIFY ) 位于 basic_timed_mutex.hpp 的第 78 行,它调用 win32::WaitForSingleObject:
do
{
BOOST_VERIFY(win32::WaitForSingleObject(
sem,::boost::detail::win32::infinite)==0);
clear_waiting_and_try_lock(old_count);
lock_acquired=!(old_count&lock_flag_value);
}
while(!lock_acquired);
WaitForSingleObject ),没有其他线程持有互斥锁(至少在断言发生时,并且可以在调试器中检查)。这很奇怪,因为它应该能够获得锁而不必等待另一个线程放弃控制。sem - 0xdddddddddddddddddddd - 这在每次崩溃时始终相同。lock_acquired - 错误。 old_count - 0xdddddddddddddddd。 this - 似乎是有效的,它的地址与持有它的对象的地址相匹配(handle_write 的对象是一个方法)。它似乎没有被删除或以任何方式弄乱。this->active_count - 一个负整数,我见过的范围在 -570000000 和 -580000000 之间。this->event - 0xdddddddddddddddd。 很遗憾,我无法看到 WaitForSingleObject 的结果称呼。 MSDN entry API 函数上的 表示四种可能的返回类型,其中两种在这种情况下是不可能的。自 WaitForSingleObject正在使用无效的事件句柄调用( sem = 0xdddddddddddddddd ),我假设它正在返回 0xFFFFFFFF并且 GetLastError 将指示提供了无效的句柄。
所以实际问题似乎是 get_event() basic_timed_mutex的方法|正在返回 0xdddddddddddddddd .然而,MSDN entry对于 CreateEvent (get_event() 最终使用)告诉我它返回事件的有效句柄,或者 NULL .
同样,这可能是我可以提供的对问题的最佳描述,因为它无法在该特定应用程序之外可靠地重现。我希望有人知道可能导致此问题的原因!
最佳答案
我想很难对您的问题给出准确的答案,但您似乎遇到了堆损坏问题,您是否尝试过在启用普通页面堆的情况下使用 AppVerifier? 如果您随后将调试器附加到进程并出现堆损坏,则当遇到损坏的堆 block 时,它有望中断,您甚至可以查看分配代码的调用堆栈。
编辑:如果使用 WinDbg,您还可以在 WaitForSingleObject(或任何其他函数)上放置条件断点,仅在调用失败时中断,然后检查最后一个错误,例如:bp kernel32 !WaitForSingleObject "gu; .if(eax == 0) {g}" -> 这将告诉调试器在断点处 i) 运行到函数的末尾 (gu) 和 ii) 检查返回值值(存储在 EAX 寄存器中)并继续执行 (g) 如果一切正常。如果返回错误,您可以使用 !gle 扩展命令检查 GetLastError() 的值。
关于c++ - 在 win32::WaitForSingleObject 期间 Windows 上的 Boost.Thread 断言/崩溃,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/5189068/
我需要在客户计算机上运行Ruby应用程序。通常需要几天才能完成(复制大备份文件)。问题是如果启用sleep,它会中断应用程序。否则,计算机将持续运行数周,直到我下次访问为止。有什么方法可以防止执行期间休眠并让Windows在执行后休眠吗?欢迎任何疯狂的想法;-) 最佳答案 Here建议使用SetThreadExecutionStateWinAPI函数,使应用程序能够通知系统它正在使用中,从而防止系统在应用程序运行时进入休眠状态或关闭显示。像这样的东西:require'Win32API'ES_AWAYMODE_REQUIRED=0x0
我的瘦服务器配置了nginx,我的ROR应用程序正在它们上运行。在我发布代码更新时运行thinrestart会给我的应用程序带来一些停机时间。我试图弄清楚如何优雅地重启正在运行的Thin实例,但找不到好的解决方案。有没有人能做到这一点? 最佳答案 #Restartjustthethinserverdescribedbythatconfigsudothin-C/etc/thin/mysite.ymlrestartNginx将继续运行并代理请求。如果您将Nginx设置为使用多个上游服务器,例如server{listen80;server
我想设置一个默认日期,例如实际日期,我该如何设置?还有如何在组合框中设置默认值顺便问一下,date_field_tag和date_field之间有什么区别? 最佳答案 试试这个:将默认日期作为第二个参数传递。youcorrectlysetthedefaultvalueofcomboboxasshowninyourquestion. 关于ruby-on-rails-date_field_tag,如何设置默认日期?[rails上的ruby],我们在StackOverflow上找到一个类似的问
我将我的Rails应用程序部署到OpenShift,它运行良好,但我无法在生产服务器上运行“Rails控制台”。它给了我这个错误。我该如何解决这个问题?我尝试更新rubygems,但它也给出了权限被拒绝的错误,我也无法做到。railsc错误:Warning:You'reusingRubygems1.8.24withSpring.UpgradetoatleastRubygems2.1.0andrun`gempristine--all`forbetterstartupperformance./opt/rh/ruby193/root/usr/share/rubygems/rubygems
我正在尝试从Postgresql表(table1)中获取数据,该表由另一个相关表(property)的字段(table2)过滤。在纯SQL中,我会这样编写查询:SELECT*FROMtable1JOINtable2USING(table2_id)WHEREtable2.propertyLIKE'query%'这工作正常:scope:my_scope,->(query){includes(:table2).where("table2.property":query)}但我真正需要的是使用LIKE运算符进行过滤,而不是严格相等。然而,这是行不通的:scope:my_scope,->(que
这似乎非常适得其反,因为太多的gem会在window上破裂。我一直在处理很多mysql和ruby-mysqlgem问题(gem本身发生段错误,一个名为UnixSocket的类显然在Windows机器上不能正常工作,等等)。我只是在浪费时间吗?我应该转向不同的脚本语言吗? 最佳答案 我在Windows上使用Ruby的经验很少,但是当我开始使用Ruby时,我是在Windows上,我的总体印象是它不是Windows原生系统。因此,在主要使用Windows多年之后,开始使用Ruby促使我切换回原来的系统Unix,这次是Linux。Rub
如何将send与+=一起使用?a=20;a.send"+=",10undefinedmethod`+='for20:Fixnuma=20;a+=10=>30 最佳答案 恐怕你不能。+=不是方法,而是语法糖。参见http://www.ruby-doc.org/docs/ProgrammingRuby/html/tut_expressions.html它说Incommonwithmanyotherlanguages,Rubyhasasyntacticshortcut:a=a+2maybewrittenasa+=2.你能做的最好的事情是:
之前在培训新生的时候,windows环境下配置opencv环境一直教的都是网上主流的vsstudio配置属性表,但是这个似乎对新生来说难度略高(虽然个人觉得完全是他们自己的问题),加之暑假之后对cmake实在是爱不释手,且这样配置确实十分简单(其实都不需要配置),故斗胆妄言vscode下配置CV之法。其实极为简单,图比较多所以很长。如果你看此文还配不好,你应该思考一下是不是自己的问题。闲话少说,直接开始。0.CMkae简介有的人到大二了都不知道cmake是什么,我不说是谁。CMake是一个开源免费并且跨平台的构建工具,可以用简单的语句来描述所有平台的编译过程。它能够根据当前所在平台输出对应的m
文章目录1.开发板选择*用到的资源2.串口通信(个人理解)3.代码分析(注释比较详细)1.主函数2.串口1配置3.串口2配置以及中断函数4.注意问题5.源码链接1.开发板选择我用的是STM32F103RCT6的板子,不过代码大概在F103系列的板子上都可以运行,我试过在野火103的霸道板上也可以,主要看一下串口对应的引脚一不一样就行了,不一样的就更改一下。*用到的资源keil5软件这里用到了两个串口资源,采集数据一个,串口通信一个,板子对应引脚如下:串口1,TX:PA9,RX:PA10串口2,TX:PA2,RX:PA32.串口通信(个人理解)我就从串口采集传感器数据这个过程说一下我自己的理解,
深度学习部署:Windows安装pycocotools报错解决方法1.pycocotools库的简介2.pycocotools安装的坑3.解决办法更多Ai资讯:公主号AiCharm本系列是作者在跑一些深度学习实例时,遇到的各种各样的问题及解决办法,希望能够帮助到大家。ERROR:Commanderroredoutwithexitstatus1:'D:\Anaconda3\python.exe'-u-c'importsys,setuptools,tokenize;sys.argv[0]='"'"'C:\\Users\\46653\\AppData\\Local\\Temp\\pip-instal