还是无聊的测试,当线程间会频繁的碰撞时,可能就需要我们仔细的设计同步的检测规则,这个测试说明Interlocked系列函数比CS函数可能更具有优势。所以当我们在多线程间同步时,可以考虑把某些用CS进行同步时的规则合理的转换成 Interlocked函数。
#include
"
stdafx.h
"
![None.gif](http://blog.vckbase.com/Images/OutliningIndicators/None.gif)
#include
<
windows.h
>
#include
<
stdlib.h
>
#include
<
stdio.h
>
#include
<
process.h
>
![None.gif](http://blog.vckbase.com/Images/OutliningIndicators/None.gif)
![None.gif](http://blog.vckbase.com/Images/OutliningIndicators/None.gif)
LONG uiCount
=
0
;
![None.gif](http://blog.vckbase.com/Images/OutliningIndicators/None.gif)
UINT WINAPI IOWorkerThreadProc(LPVOID pParam)
![ExpandedBlockStart.gif](http://blog.vckbase.com/Images/OutliningIndicators/ExpandedBlockStart.gif)
{
![InBlock.gif](http://blog.vckbase.com/Images/OutliningIndicators/InBlock.gif)
DWORD dTick = GetTickCount();
for(int i = 0; i < 100000000; i++)
![ExpandedSubBlockStart.gif](http://blog.vckbase.com/Images/OutliningIndicators/ExpandedSubBlockStart.gif)
{
::EnterCriticalSection( &m_cs );
uiCount++;
::LeaveCriticalSection( &m_cs );
}
![InBlock.gif](http://blog.vckbase.com/Images/OutliningIndicators/InBlock.gif)
![InBlock.gif](http://blog.vckbase.com/Images/OutliningIndicators/InBlock.gif)
![InBlock.gif](http://blog.vckbase.com/Images/OutliningIndicators/InBlock.gif)
printf("Thread dead! %d -- %d ",uiCount,GetTickCount()-dTick);
![InBlock.gif](http://blog.vckbase.com/Images/OutliningIndicators/InBlock.gif)
return 0xdead;
}
![None.gif](http://blog.vckbase.com/Images/OutliningIndicators/None.gif)
![None.gif](http://blog.vckbase.com/Images/OutliningIndicators/None.gif)
![None.gif](http://blog.vckbase.com/Images/OutliningIndicators/None.gif)
UINT WINAPI IOWorkerThreadProc_(LPVOID pParam)
![ExpandedBlockStart.gif](http://blog.vckbase.com/Images/OutliningIndicators/ExpandedBlockStart.gif)
{
![InBlock.gif](http://blog.vckbase.com/Images/OutliningIndicators/InBlock.gif)
DWORD dTick = GetTickCount();
for(int i = 0; i < 100000000; i++)
![ExpandedSubBlockStart.gif](http://blog.vckbase.com/Images/OutliningIndicators/ExpandedSubBlockStart.gif)
{
InterlockedIncrement(&uiCount);
}
![InBlock.gif](http://blog.vckbase.com/Images/OutliningIndicators/InBlock.gif)
![InBlock.gif](http://blog.vckbase.com/Images/OutliningIndicators/InBlock.gif)
![InBlock.gif](http://blog.vckbase.com/Images/OutliningIndicators/InBlock.gif)
printf("Thread dead! %d -- %d ",uiCount,GetTickCount()-dTick);
![InBlock.gif](http://blog.vckbase.com/Images/OutliningIndicators/InBlock.gif)
return 0xdead;
}
![None.gif](http://blog.vckbase.com/Images/OutliningIndicators/None.gif)
![None.gif](http://blog.vckbase.com/Images/OutliningIndicators/None.gif)
![None.gif](http://blog.vckbase.com/Images/OutliningIndicators/None.gif)
![None.gif](http://blog.vckbase.com/Images/OutliningIndicators/None.gif)
![None.gif](http://blog.vckbase.com/Images/OutliningIndicators/None.gif)
![None.gif](http://blog.vckbase.com/Images/OutliningIndicators/None.gif)
void
main()
![ExpandedBlockStart.gif](http://blog.vckbase.com/Images/OutliningIndicators/ExpandedBlockStart.gif)
{
::InitializeCriticalSection( &m_cs );
![InBlock.gif](http://blog.vckbase.com/Images/OutliningIndicators/InBlock.gif)
int i = 0;
![InBlock.gif](http://blog.vckbase.com/Images/OutliningIndicators/InBlock.gif)
for(i = 0; i < 5; i++)
![ExpandedSubBlockStart.gif](http://blog.vckbase.com/Images/OutliningIndicators/ExpandedSubBlockStart.gif)
{
_beginthreadex(0,0,IOWorkerThreadProc, 0,0, NULL);
}
![InBlock.gif](http://blog.vckbase.com/Images/OutliningIndicators/InBlock.gif)
getchar();
printf("SUM:%d ",uiCount);
uiCount = 0;
![InBlock.gif](http://blog.vckbase.com/Images/OutliningIndicators/InBlock.gif)
for(i = 0; i < 5; i++)
![ExpandedSubBlockStart.gif](http://blog.vckbase.com/Images/OutliningIndicators/ExpandedSubBlockStart.gif)
{
_beginthreadex(0,0,IOWorkerThreadProc_, 0,0, NULL);
}
![InBlock.gif](http://blog.vckbase.com/Images/OutliningIndicators/InBlock.gif)
![InBlock.gif](http://blog.vckbase.com/Images/OutliningIndicators/InBlock.gif)
getchar();
![InBlock.gif](http://blog.vckbase.com/Images/OutliningIndicators/InBlock.gif)
printf("SUM:%d ",uiCount);
![InBlock.gif](http://blog.vckbase.com/Images/OutliningIndicators/InBlock.gif)
![InBlock.gif](http://blog.vckbase.com/Images/OutliningIndicators/InBlock.gif)
getchar();
::DeleteCriticalSection( &m_cs );
![InBlock.gif](http://blog.vckbase.com/Images/OutliningIndicators/InBlock.gif)
}
输出结果:
Thread dead! 420951825 -- 59672
Thread dead! 427460014 -- 60563
Thread dead! 433629330 -- 61391
Thread dead! 498019991 -- 70047
Thread dead! 500000000 -- 70188
![None.gif](http://blog.vckbase.com/Images/OutliningIndicators/None.gif)
![None.gif](http://blog.vckbase.com/Images/OutliningIndicators/None.gif)
![None.gif](http://blog.vckbase.com/Images/OutliningIndicators/None.gif)
![None.gif](http://blog.vckbase.com/Images/OutliningIndicators/None.gif)
![None.gif](http://blog.vckbase.com/Images/OutliningIndicators/None.gif)
![None.gif](http://blog.vckbase.com/Images/OutliningIndicators/None.gif)
![None.gif](http://blog.vckbase.com/Images/OutliningIndicators/None.gif)
![None.gif](http://blog.vckbase.com/Images/OutliningIndicators/None.gif)
![None.gif](http://blog.vckbase.com/Images/OutliningIndicators/None.gif)
![None.gif](http://blog.vckbase.com/Images/OutliningIndicators/None.gif)
![None.gif](http://blog.vckbase.com/Images/OutliningIndicators/None.gif)
![None.gif](http://blog.vckbase.com/Images/OutliningIndicators/None.gif)
![ExpandedBlockStart.gif](http://blog.vckbase.com/Images/OutliningIndicators/ExpandedBlockStart.gif)
![ContractedBlock.gif](http://blog.vckbase.com/Images/OutliningIndicators/ContractedBlock.gif)
![dot.gif](http://blog.vckbase.com/Images/dot.gif)
![InBlock.gif](http://blog.vckbase.com/Images/OutliningIndicators/InBlock.gif)
![InBlock.gif](http://blog.vckbase.com/Images/OutliningIndicators/InBlock.gif)
![InBlock.gif](http://blog.vckbase.com/Images/OutliningIndicators/InBlock.gif)
![ExpandedSubBlockStart.gif](http://blog.vckbase.com/Images/OutliningIndicators/ExpandedSubBlockStart.gif)
![ContractedSubBlock.gif](http://blog.vckbase.com/Images/OutliningIndicators/ContractedSubBlock.gif)
![dot.gif](http://blog.vckbase.com/Images/dot.gif)
![InBlock.gif](http://blog.vckbase.com/Images/OutliningIndicators/InBlock.gif)
![InBlock.gif](http://blog.vckbase.com/Images/OutliningIndicators/InBlock.gif)
![InBlock.gif](http://blog.vckbase.com/Images/OutliningIndicators/InBlock.gif)
![InBlock.gif](http://blog.vckbase.com/Images/OutliningIndicators/InBlock.gif)
![ExpandedSubBlockEnd.gif](http://blog.vckbase.com/Images/OutliningIndicators/ExpandedSubBlockEnd.gif)
![InBlock.gif](http://blog.vckbase.com/Images/OutliningIndicators/InBlock.gif)
![InBlock.gif](http://blog.vckbase.com/Images/OutliningIndicators/InBlock.gif)
![InBlock.gif](http://blog.vckbase.com/Images/OutliningIndicators/InBlock.gif)
![InBlock.gif](http://blog.vckbase.com/Images/OutliningIndicators/InBlock.gif)
![InBlock.gif](http://blog.vckbase.com/Images/OutliningIndicators/InBlock.gif)
![InBlock.gif](http://blog.vckbase.com/Images/OutliningIndicators/InBlock.gif)
![ExpandedBlockEnd.gif](http://blog.vckbase.com/Images/OutliningIndicators/ExpandedBlockEnd.gif)
![None.gif](http://blog.vckbase.com/Images/OutliningIndicators/None.gif)
![None.gif](http://blog.vckbase.com/Images/OutliningIndicators/None.gif)
![None.gif](http://blog.vckbase.com/Images/OutliningIndicators/None.gif)
![None.gif](http://blog.vckbase.com/Images/OutliningIndicators/None.gif)
![ExpandedBlockStart.gif](http://blog.vckbase.com/Images/OutliningIndicators/ExpandedBlockStart.gif)
![ContractedBlock.gif](http://blog.vckbase.com/Images/OutliningIndicators/ContractedBlock.gif)
![dot.gif](http://blog.vckbase.com/Images/dot.gif)
![InBlock.gif](http://blog.vckbase.com/Images/OutliningIndicators/InBlock.gif)
![InBlock.gif](http://blog.vckbase.com/Images/OutliningIndicators/InBlock.gif)
![InBlock.gif](http://blog.vckbase.com/Images/OutliningIndicators/InBlock.gif)
![ExpandedSubBlockStart.gif](http://blog.vckbase.com/Images/OutliningIndicators/ExpandedSubBlockStart.gif)
![ContractedSubBlock.gif](http://blog.vckbase.com/Images/OutliningIndicators/ContractedSubBlock.gif)
![dot.gif](http://blog.vckbase.com/Images/dot.gif)
![InBlock.gif](http://blog.vckbase.com/Images/OutliningIndicators/InBlock.gif)
![ExpandedSubBlockEnd.gif](http://blog.vckbase.com/Images/OutliningIndicators/ExpandedSubBlockEnd.gif)
![InBlock.gif](http://blog.vckbase.com/Images/OutliningIndicators/InBlock.gif)
![InBlock.gif](http://blog.vckbase.com/Images/OutliningIndicators/InBlock.gif)
![InBlock.gif](http://blog.vckbase.com/Images/OutliningIndicators/InBlock.gif)
![InBlock.gif](http://blog.vckbase.com/Images/OutliningIndicators/InBlock.gif)
![InBlock.gif](http://blog.vckbase.com/Images/OutliningIndicators/InBlock.gif)
![InBlock.gif](http://blog.vckbase.com/Images/OutliningIndicators/InBlock.gif)
![ExpandedBlockEnd.gif](http://blog.vckbase.com/Images/OutliningIndicators/ExpandedBlockEnd.gif)
![None.gif](http://blog.vckbase.com/Images/OutliningIndicators/None.gif)
![None.gif](http://blog.vckbase.com/Images/OutliningIndicators/None.gif)
![None.gif](http://blog.vckbase.com/Images/OutliningIndicators/None.gif)
![None.gif](http://blog.vckbase.com/Images/OutliningIndicators/None.gif)
![None.gif](http://blog.vckbase.com/Images/OutliningIndicators/None.gif)
![None.gif](http://blog.vckbase.com/Images/OutliningIndicators/None.gif)
![None.gif](http://blog.vckbase.com/Images/OutliningIndicators/None.gif)
![ExpandedBlockStart.gif](http://blog.vckbase.com/Images/OutliningIndicators/ExpandedBlockStart.gif)
![ContractedBlock.gif](http://blog.vckbase.com/Images/OutliningIndicators/ContractedBlock.gif)
![dot.gif](http://blog.vckbase.com/Images/dot.gif)
![InBlock.gif](http://blog.vckbase.com/Images/OutliningIndicators/InBlock.gif)
![InBlock.gif](http://blog.vckbase.com/Images/OutliningIndicators/InBlock.gif)
![InBlock.gif](http://blog.vckbase.com/Images/OutliningIndicators/InBlock.gif)
![InBlock.gif](http://blog.vckbase.com/Images/OutliningIndicators/InBlock.gif)
![InBlock.gif](http://blog.vckbase.com/Images/OutliningIndicators/InBlock.gif)
![ExpandedSubBlockStart.gif](http://blog.vckbase.com/Images/OutliningIndicators/ExpandedSubBlockStart.gif)
![ContractedSubBlock.gif](http://blog.vckbase.com/Images/OutliningIndicators/ContractedSubBlock.gif)
![dot.gif](http://blog.vckbase.com/Images/dot.gif)
![InBlock.gif](http://blog.vckbase.com/Images/OutliningIndicators/InBlock.gif)
![ExpandedSubBlockEnd.gif](http://blog.vckbase.com/Images/OutliningIndicators/ExpandedSubBlockEnd.gif)
![InBlock.gif](http://blog.vckbase.com/Images/OutliningIndicators/InBlock.gif)
![InBlock.gif](http://blog.vckbase.com/Images/OutliningIndicators/InBlock.gif)
![InBlock.gif](http://blog.vckbase.com/Images/OutliningIndicators/InBlock.gif)
![InBlock.gif](http://blog.vckbase.com/Images/OutliningIndicators/InBlock.gif)
![InBlock.gif](http://blog.vckbase.com/Images/OutliningIndicators/InBlock.gif)
![InBlock.gif](http://blog.vckbase.com/Images/OutliningIndicators/InBlock.gif)
![ExpandedSubBlockStart.gif](http://blog.vckbase.com/Images/OutliningIndicators/ExpandedSubBlockStart.gif)
![ContractedSubBlock.gif](http://blog.vckbase.com/Images/OutliningIndicators/ContractedSubBlock.gif)
![dot.gif](http://blog.vckbase.com/Images/dot.gif)
![InBlock.gif](http://blog.vckbase.com/Images/OutliningIndicators/InBlock.gif)
![ExpandedSubBlockEnd.gif](http://blog.vckbase.com/Images/OutliningIndicators/ExpandedSubBlockEnd.gif)
![InBlock.gif](http://blog.vckbase.com/Images/OutliningIndicators/InBlock.gif)
![InBlock.gif](http://blog.vckbase.com/Images/OutliningIndicators/InBlock.gif)
![InBlock.gif](http://blog.vckbase.com/Images/OutliningIndicators/InBlock.gif)
![InBlock.gif](http://blog.vckbase.com/Images/OutliningIndicators/InBlock.gif)
![InBlock.gif](http://blog.vckbase.com/Images/OutliningIndicators/InBlock.gif)
![InBlock.gif](http://blog.vckbase.com/Images/OutliningIndicators/InBlock.gif)
![InBlock.gif](http://blog.vckbase.com/Images/OutliningIndicators/InBlock.gif)
![InBlock.gif](http://blog.vckbase.com/Images/OutliningIndicators/InBlock.gif)
![InBlock.gif](http://blog.vckbase.com/Images/OutliningIndicators/InBlock.gif)
![InBlock.gif](http://blog.vckbase.com/Images/OutliningIndicators/InBlock.gif)
![ExpandedBlockEnd.gif](http://blog.vckbase.com/Images/OutliningIndicators/ExpandedBlockEnd.gif)
输出结果:
Thread dead! 420951825 -- 59672
Thread dead! 427460014 -- 60563
Thread dead! 433629330 -- 61391
Thread dead! 498019991 -- 70047
Thread dead! 500000000 -- 70188
SUM:500000000
Thread dead! 416899248 -- 11875
Thread dead! 435609187 -- 12344
Thread dead! 482671736 -- 13750
Thread dead! 499292047 -- 14187
Thread dead! 500000000 -- 14250
Thread dead! 416899248 -- 11875
Thread dead! 435609187 -- 12344
Thread dead! 482671736 -- 13750
Thread dead! 499292047 -- 14187
Thread dead! 500000000 -- 14250
SUM:500000000
转载于:https://blog.51cto.com/laokaddk/256209