[ACE程序员教程笔记]使用ACE_Guard访问子线程
2011-01-08 16:50
267 查看
ACE_Guard提供了自动锁定、释放机制的同步锁,对可见的scope范围内进行自动加锁,当超出scope范围是程序自动卸锁。Guard需要与一个ACE_LOCK的类作为模板,本例中采用了ACE_Thread_Mutex实现,见代码。
#include "stdafx.h" #include "ace/ace.h" #include "ace/Thread.h" #include "ace/Synch.h" #include "ace/Log_Msg.h" ACE_Thread_Mutex tmMutex; int g_nCounter; //子线程处理函数,在此函数中采用mutex保证每次打印三个连续的整数 //中间的输出不会被打断 static void* ChildProc(void* pParam) { //如果没有mutext,输出结果将会有很大的不同,无法保证输出的完整性! ACE_Guard<ACE_Thread_Mutex> gdSync(tmMutex); for (int i = 0; i < 3;i++) { ACE_DEBUG((LM_DEBUG,ACE_TEXT("(%t) = %d/n"),g_nCounter++)); } return NULL; } //创建的线程个数 #define NUM_THRD 100 int ACE_TMAIN(int argc, ACE_TCHAR* argv[]) { ACE_thread_t* pThreadIDs = new ACE_thread_t[NUM_THRD]; ACE_hthread_t* pHandles = new ACE_hthread_t[NUM_THRD]; //启动NUM_THRD个线程 if (ACE_Thread::spawn_n(pThreadIDs,NUM_THRD,(ACE_THR_FUNC)ChildProc,0, THR_JOINABLE|THR_NEW_LWP, ACE_DEFAULT_THREAD_PRIORITY, 0,0, pHandles) == -1 ) { ACE_DEBUG((LM_DEBUG,ACE_TEXT("spawn_n error!/n"))); return -1; } //等待所有的子线程处理完毕,主线程才退出 for (int i = 0; i < NUM_THRD;i++) { ACE_Thread::join(pHandles[i]); } return 0; }
相关文章推荐
- [ACE程序员教程笔记]使用ACE_Thread_Mutex访问子线程中的数据
- [ACE程序员教程笔记]使用ACE_Acceptor分离连接和事件处理
- [ACE程序员教程笔记]ACE_Connector使用一个连接多个线程发送数据
- [ACE程序员教程笔记]使用ACE_Acceptor建立连接并处理连接请求
- [ACE程序员教程笔记]使用ACE_Thread_Manager创建线程组
- [ACE程序员教程笔记]使用ACE_Connector连接服务器
- [ACE程序员教程笔记]使用ACE_Thread创建多个线程
- [ACE程序员教程笔记]使用Reactor处理信号
- ACE一些控件使用笔记
- [ACE程序员教程笔记]使用Reactor实现Accept和数据读取
- [Android]笔记12:使用QuickContactBadge关联联系人
- spring boot Websocket(使用笔记)
- 水晶报表的一些学习笔记(使用特殊字体实现特殊报表效果【转载】)
- 微软企业库4.1学习笔记(十六)缓存模块4 服务器场中的缓存使用
- html5学习笔记---03. Canvas简介,Canvas的使用方法
- Android使用笔记
- UITextView使用笔记
- C++/GDI+ 学习笔记(一)——安装、配置&使用
- 尚学堂Struts学习笔记1:Struts标签的配置和使用
- 【JSP学习笔记】使用Servlet实现网页验证码