sam_jiang 2014-12-16 07:49 采纳率: 0%
浏览 1873

信号量和线程同步的问题:线程函数比较耗时

void trigger()
{
UINT uWait=::WaitForSingleObject(IEvent,INFINITE);
if ( uWait == WAIT_OBJECT_0 )
{

processA();

}
}

processA(); 比较耗时,如果它还没有跑完,下一个触发又来了,就马上又开始执行一个processA(); 吗,还是等待上次的执行完成然后再执行?

  • 写回答

2条回答 默认 最新

  • 庄鱼 2014-12-16 08:44
    关注

    PC机上会出现乱序或是假死,也就是说有可能后发的先做,而不是顺序执行,如要顺序执行,则在编程时需要先写阻塞程序,即忙信号,让申请方将任务丢给缓冲池。
    作为多CPU多通道并发处理则是事先根据资源情况建立标志信号,当信号为空时就可以提交,如信号全满则进入等待队列,当超时时进入超时处理:或返回、或丢弃、或挂起依策略不同而处理。

    评论

报告相同问题?

悬赏问题

  • ¥15 oracle集群安装出bug
  • ¥15 关于#python#的问题:自动化测试
  • ¥20 问题请教!vue项目关于Nginx配置nonce安全策略的问题
  • ¥15 教务系统账号被盗号如何追溯设备
  • ¥20 delta降尺度方法,未来数据怎么降尺度
  • ¥15 c# 使用NPOI快速将datatable数据导入excel中指定sheet,要求快速高效
  • ¥15 再不同版本的系统上,TCP传输速度不一致
  • ¥15 高德地图2.0 版本点聚合中Marker的位置无法实时更新,如何解决呢?
  • ¥15 DIFY API Endpoint 问题。
  • ¥20 sub地址DHCP问题