基於C++完成的線程休眠代碼。本站提示廣大學習愛好者:(基於C++完成的線程休眠代碼)文章只能為提供參考,不一定能成為您想要的結果。以下是基於C++完成的線程休眠代碼正文
本文實例講述了基於C++完成的線程休眠代碼,分享給年夜家供年夜家參考。詳細辦法以下:
linux平台示例以下:
/* File : thread1.c Author : Mike E-Mail : [email protected] */ #include <stdio.h> #include <pthread.h> #include <time.h> void m_threadSleep(int sec,int nsec) { struct timespec sleepTime; struct timespec returnTime; sleepTime.tv_sec = sec; sleepTime.tv_nsec = nsec; nanosleep(&sleepTime, &returnTime); } void test1() { m_threadSleep(1,0); printf("I'm thread1 ...\r\n"); } void test2() { m_threadSleep(2,0); printf("I'm thread2 ...\r\n"); } int main() { pthread_t thread1,thread2; void *result; time_t tbegin,tend; tbegin = time(NULL); pthread_create(&thread1,NULL,(void*)&test1,NULL); pthread_create(&thread2,NULL,(void*)&test2,NULL); pthread_join(thread1,&result); pthread_join(thread2,&result); tend = time(NULL); printf("%d\r\n",tend-tbegin); return 0; }
編譯代碼以下:
gcc thread1.c -o thread1 -lpthread
boost庫完成示例以下:
/* File : boost_thread1.cpp Author : Mike E-Mail : [email protected] */ #include <boost/date_time/posix_time/posix_time.hpp> #include <boost/thread/thread.hpp> #include <iostream> boost::xtime getSleepTime(int sec,int nsec) { boost::xtime t; boost::xtime_get(&t, boost::TIME_UTC); t.sec += sec; t.nsec += nsec; return t; } void test1() { boost::this_thread::sleep(getSleepTime(1,500)); std::cout <<"I'm thread1 !"<< std::endl; } void test2() { boost::this_thread::sleep(getSleepTime(3,500)); std::cout <<"I'm thread2 !"<< std::endl; } int main(int argc, char* argv[]) { boost::thread thrd1(&test1); boost::thread thrd2(&test2); std::time_t t_begin,t_end; t_begin = time(NULL); thrd1.join(); thrd2.join(); t_end = time(NULL); std::cout<<t_end-t_begin<<std::endl; return 0; }
編譯敕令以下:
g++ boost_thread1.cpp -o boost_thread1 -lboost_thread-mt
願望本文所述對年夜家的C++法式設計有所贊助。