zoukankan      html  css  js  c++  java
  • windows多线程应用编程注意事项

    1,资源争用保护

    对于文件操作、界面资源、GDI操作等一般由主线程完成的任务,要加以顺序化处理(serialization),即一个资源一次只能由一个线程访问,多个线程同时访问将导致错误。

    方法一般可采用TRTLCriticalSection,程序启动时创建TRTLCriticalSection实例,退出时释放实例,使用时先调用EnterCriticalSection,再调用LeaveCriticalSection

    2,线程执行的异常处理

    线程中的异常可能导致线程死在内存中无法释放,积累多了会导致资源耗尽。

    因此对线程中执行的操作,一般要考虑异常处理。通常是用Try...Except 对可疑操作进行包裹,避免错误逸出。

            try
              res := API_call(p1,p2);
            except  //重要:防止函数调用出错,线程死掉不能释放!!
              on e:exception do
              addLog(10,e.Message);
            end;

    3,线程释放

    windows程序每个进程可以创建的线程数是有限的。本人win7 64位机器,程序最多创建的线程数不超过1500个。如果程序要创建的线程数超过最大线程数,系统就会报错。

     一般程序不需要在内存中创建并运行太多线程。线程不足可能是未及时释放导致。因此线程的释放十分关键。

    1,线程创建时设定 FreeOnTerminate为True,则线程执行完毕后系统会自动释放线程资源。

    2,保障线程及时执行完毕execute过程。特别是注意不能出错,或出错后不进行处理。

    实践发现,线程的释放时机是windows决定的。当程序可用线程足够且较忙时,即使线程已经结束,系统可能也并不马上释放线程资源,而是在空闲时缓慢释放。

    但如果程序占用的线程已经达到1500左右,且又要创建新的线程时,系统就会主动去释放已经结束的线程,以便为新线程提供资源。

    下图是测试启动10000个线程,发现当程序进程到达1460个线程时,程序会主动释放已结束的线程,此时线程数不再上升,且程序正常运行。

    4,多线程的测试

    对于多线程程序一定要进行自动化测试,因为人工测试难以模拟到一些涉及多线程特性的问题。

    实践发现,Jmeter是一个非常好用的多线程压力测试工具,做好测试计划可反复使用,用法也较为简单。在此推荐一下。

  • 相关阅读:
    【HDOJ4812】D Tree(点分治)
    【POJ1741】Tree(点分治)
    点分治模板
    【ZJOI2017 Round1练习】D4T2 trie(贪心,状压DP)
    【ZJOI2017 Round1练习&BZOJ4774】D3T2 road(斯坦纳树,状压DP)
    【ZJOI2017 Round1练习&BZOJ4773】D3T1 cycle(最小负环,倍增)
    【ZJOI2017 Round1练习&BZOJ5350】D5T1 masodik(DP,斜率优化)
    【SGU194&ZOJ2314】Reactor Cooling(有上下界的网络流)
    【HDOJ4322】Candy(费用流)
    jstl_fn方法库
  • 原文地址:https://www.cnblogs.com/jackkwok/p/7379945.html
Copyright © 2011-2022 走看看