Linux(ubuntu13):
#include
#include
#include
int main()
{
//clock_t oldTime=0;//陈旧变量
unsigned long oldTimeUInt=clock();/10; //记录上一次LoopWork时间
//
//--------------------------------------------------------------
int In0i1=0; //LoopWork计数🧮Count
clock_t starTimeSec=clock(); // clock_clik开始时间,用于clik计时⌛️
for(unsigned long ULLi0=0;1==1;++ULLi0) //true:1==1
{//for1100ULLi0
if( clock()/10==oldTimeUInt/10). // 1/10每10次clik才LoopWork一次!clock_clik to loop
{//220if
printf("i=%lu",ULLi0);
usleep(1);// the number2 sleep point(第二个睡觉点place No2)
continue;
}//220if
//
oldTimeUInt=clock();// /10 此处及时更新oldTimeUInt及时计时,循环体后更新的缺点是:循环体很费时,但计时在后,下次循环会误成 没有跳clock_clik, 又要等clock_clik跳时间;
//Inter Loop Codeing...内部循环体
printf("\ni:%lu,",ULLi0);//轮训i次数
printf("No%d ( loop)%ld,\n" ,In0i1,clock()-starTimeSec );//进入循环次数,计时器时间clock_clik次数
//printf("\n");
//
++In0i1; if(In0i1>19) {
usleep(1);//真正 计数循环体 次数,(真循环体)循环后睡觉
break;
}//440if
//
}//for110ULLi0
//=循环完=============================================================
}//main
结果:
i:0,No0 (no loop)72,
i:1,No1 (no loop)81,
i=2
i:3,No2 (no loop)128,
i:4,No3 (no loop)140,
i:5,No4 (no loop)148,
i:6,No5 (no loop)189,
i:7,No6 (no loop)194,
i=8
i:9,No7 (no loop)237,
i:10,No8 (no loop)243,
i=11
i:12,No9 (no loop)288,
i:13,No10 (no loop)297,
i:14,No11 (no loop)302,
i=15
i:16,No12 (no loop)363,