COM组件的多线程测试-Apartment模型 (转)

COM组件的多线程测试-Apartment模型 (转)[@more@]

COM组件的多线程测试-Apartment模型XML:namespace prefix = o ns = "urn:schemas-microsoft-com:Office:office" />

 

版本信息:

版本

作者

修正/记录

Ver 1.0

Zzyx

2003-5-16。创建

关键字:

com 多线程 线程模型 single Apartment CoInitialize CoInitializeEx

COINIT_APARTMENTTHREADED COINIT_APARTMENTTHREADED

测试对象

组件对象线程模型为Apartment。

组件代码:

STDMETHODIMP CTest2::Test(long nCnt)

{

  printf(" 对象Test2。所在线程ID:%d",GetCurrentThreadId());

  _tzset();

  char tmpbuf[128];

  _strtime( tmpbuf );

  printf( " 线程ID:%d,begin time: %s ", GetCurrentThreadId(),tmpbuf );

  Sleep(1000*nCnt);

  _strtime( tmpbuf );

  printf( " 线程ID:%d,end time: %s ", GetCurrentThreadId(),tmpbuf );

  return S_OK;

}

 

对象跨线程调用

测试方法:

客户端创建一个对象实例,把该对象的指针传递给多个线程

每个线程中调用该实例的方法

观察输出结果

 

编号

客户端COM环境

结果

心得

S1

NO

无法创建对象

 

S2

CoInitialize

同步执行

且对象的方法被创建的多个线程同步调用

从组件的角度看,需要管理线程同步

S3

CoInitializeEx

COINIT_APARTMENTTHREADED

同上

同上

S4

CoInitializeEx

COINIT_MULTITHREADED

顺序执行

对象的方法被同一个线程顺序调用

该线程为系统创建的

COM完成了线程同步的工作。

但如果是不同的方法呢?逻辑上应该也是同步的,未测试

 

多线程中对象实例调用

测试方法:

客户端启动多个线程

每个线程创建一个对象实例,调用该对象的方法。

观察输出结果。

 

测试结果如下:

主线程

COM环境

编号

线程COM

环境

运行结果

NO

T1

NO

无法创建对象

T2

CoInitialize

 

同时调用

每个线程都启动

每个COM对象运行在各自的调用线程中

T3

CoIntializeEx

COINIT_APARTMENTTHREADED

同时调用

每个线程都启动

每个COM对象运行在各自的调用线程中

T4

CoIntializeEx

COINIT_MULTITHREADED

注意:顺序调用

每个线程都启动

但对象都运行在另外的一个线程中,似乎是系统创建的

 

Yes

CoInitialize

T5

NO

无法创建对象

T6

CoInitialize

同T2

 

T7

CoIntializeEx

COINIT_APARTMENTTHREADED

同T2

T8

CoIntializeEx

COINIT_MULTITHREADED

!!!注意!!!

顺序调用

每个线程都启动

每个对象运行在相同的一个线程中,似乎是系统创建的

 

CoInitializeEx

COINIT_APARTMENTTHREADED

T9

NO

 

T10

CoInitialize

同T2

 

T11

CoIntializeEx

COINIT_APARTMENTTHREADED

同T2

 

T12

CoIntializeEx

COINIT_MULTITHREADED

同T8

 

CoInitializeEx

COINIT_MULTITHREADED

T13

NO

无法

T14

CoInitialize

同T2

T15

CoIntializeEx

COINIT_APARTMENTTHREADED

同T2

T16

CoIntializeEx

 COINIT_MULTITHREADED

同T8

 

输出结果见附录

来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/10752019/viewspace-956710/,如需转载,请注明出处,否则将追究法律责任。

转载于:http://blog.itpub.net/10752019/viewspace-956710/

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值