原创  windows和linux的线程同步性能 收藏


目的是测试在无碰撞的情况下,进出最快的锁性能如何。
linux采用pthread_mutext,windows2k采用critical_section
linux版本为RHEL4。

伪代码如下:

    CMyLock test_sync;
    
double begin = get_current_time();
    
for(int i = 0; i < 1000000; i++)
    {
        test_sync.
lock();
        test_sync.unlock();
    }
    
double end = get_current_time();
   
double used = end - begin;


结果如下:
linux进出一次需要49.7纳秒。
windows进出一次需要13.6纳秒。

分析:
看起来相差三四倍,其实对系统影响很小。我们假设处理一条message需要进出10次锁,而且由于设计良好极少发生锁碰撞,那么两个环境下的delay差别只有360纳秒,也就是0.36微秒,也就是0.00036毫秒。忽略不计。

其他:
在设法破除了编译器的不合常理的针对性优化之后,内存拷贝memcpy(ttt, sss, 100)在windows下每次需要48.7纳秒,linux需要20.1纳秒。列举这个资料是为了说明windows和linux各有长处。

发表于 @ 2007年12月04日 16:31:00 | 评论( loading... ) | 编辑| 举报| 收藏

旧一篇:有人说Java比C++快? | 新一篇:[Linux] linux下的GetModuleFileName函数

  • 发表评论
  • 评论内容:
  •  
Copyright © wwwsq
Powered by CSDN Blog