根据C++NPV2 P199中描述,该方法会并发地运行在各个工作者线程中,
该工作者线程在ACE_Task中通过activate方法分配的。
函数原型如下:
virtual int activate (long flags = THR_NEW_LWP | THR_JOINABLE |THR_INHERIT_SCHED ,
int n_threads = 1,
int force_active = 0,
long priority = ACE_DEFAULT_THREAD_PRIORITY,
int grp_id = -1,
ACE_Task_Base *task = 0,
ACE_hthread_t thread_handles[] = 0,
void *stack[] = 0,
size_t stack_size[] = 0,
ACE_thread_t thread_ids[] = 0);
因为多个线程同时运行svc()方法,所以需要在线程之间做好同步。
svc()方法本身没有使用同步设施,其依靠的是ACE_Message_Queue的同步化的dequeue和enqueue操作。
关于同步化的理解,个人认为以下解释非常到位:
http://blog.youkuaiyun.com/morewindows/article/details/7538247
1.线程(进程)同步的主要任务
答:在引入多线程后,由于线程执行的异步性,会给系统造成混乱,特别是在急用临界资源时,如多个线程急用同一台打印机,会使打印结果交织在一起,难于区分。当多个线程急用共享变量,表格,链表时,可能会导致数据处理出错,因此线程同步的主要任务是使并发执行的各线程之间能够有效的共享资源和相互合作,从而使程序的执行具有可再现性。