• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>

               C++ 技術中心

               :: 首頁 :: 聯系 ::  :: 管理
              160 Posts :: 0 Stories :: 87 Comments :: 0 Trackbacks

            公告

            鄭重聲明:本BLOG所發表的原創文章,作者保留一切權利。必須經過作者本人同意后方可轉載,并注名作者(天空)和出處(CppBlog.com)。作者Email:coder@luckcoder.com

            留言簿(27)

            搜索

            •  

            最新隨筆

            最新評論

            評論排行榜

            一.創建線程函數
                 常用的創建線程的函數是CreateThread,還有MFC中的AfxBeginThread方法.另一種函數是_beginthreadex,
            其實它在內部調用了CreateThread,在調用之前_beginthreadex做了很多的工作,從而使得它比CreateThread更
            安全.所以一般使用_beginthreadex來創建線程.于是以下使用_beginthreadex函數來創建線程類.

            二.線程類示例
            1.Thread.h文件如下:
            #ifndef _THREAD_H__
            #define _THREAD_H__
            #include 
            <process.h>
            #include 
            <windows.h>

            class CThread
            {
            public:
            public:
                CThread();
                
            virtual ~CThread();
                
                BOOL StartThread();   
            //開始線程
                BOOL SuspendThread(); //掛起線程
                virtual BOOL Run();   //線程的入口
                BOOL StopThread();    //等待線程退出再返回
                
                
            static unsigned __stdcall start_address( void * obj);

            public:
                HANDLE m_hthread;        
            //線程句柄
                HANDLE m_hEventSuspend;  //用于標識線程是工作,還是掛起狀態
                BOOL m_status;           //線程狀態,FALSE表示線程退出狀態,TRUE表示未提出狀態
                unsigned  m_thrdaddr;
            }
            ;

            #endif/*_THREAD_H__*/


            2.Thread.cpp文件如下:
            #include "Thread.h"


            CThread::CThread()
            {
                m_hEventSuspend 
            = CreateEvent(0,TRUE,FALSE,NULL);//創建事件句柄,且為非激發狀態
                m_status 
            = TRUE;

                
            //創建線程
                m_hthread = (HANDLE)_beginthreadex(NULL,0,CThread::start_address,this,0,&m_thrdaddr);
            }


            CThread::
            ~CThread()
            {
                CloseHandle(m_hEventSuspend);
                CloseHandle( m_hthread );
            }


            BOOL CThread::StartThread()
            {
                
            return SetEvent(m_hEventSuspend);
            }


            BOOL CThread::SuspendThread()
            {
                
            return ResetEvent(m_hEventSuspend);
            }


            BOOL CThread::Run()
            {
                
            return TRUE;
            }


            BOOL CThread::StopThread()
            {
                m_status 
            = FALSE;//將線程狀態置為退出
                StartThread();   //把線程喚醒,以免掛死在休眠處
                WaitForSingleObject(m_hthread,INFINITE); //等待線程退出

                
            return TRUE;
            }


            unsigned __stdcall CThread::start_address( 
            void * obj)
            {
                CThread
            * pthread = static_cast<CThread*>(obj);

                
            while(pthread->m_status)
                
            {
                    WaitForSingleObject(pthread
            ->m_hEventSuspend,INFINITE);//控制掛起,運行
                    
            //如果自動退出
                    if (!pthread->Run())
                        
            break;
                }

                _endthreadex(
            0);

                
            return 0;
            }



            三.線程類的使用
            1. 新建一個win32控制臺工程,代碼如下:
            #include "Thread.h"
            #include 
            <iostream>
            #include 
            <conio.h>


            using namespace std;


            class CMyThread:public CThread
            {
            public:
                BOOL Run()
                
            {
                    cout
            <<"hello!"<<endl;
                    Sleep(
            5000);
                    
            return TRUE;
                }

            }
            ;

            int main(int argc,char *argv[])
            {
                
            //創建線程
                CMyThread mythread;

                
            //讓線程啟動
                mythread.StartThread();
                
                
            //按任意鍵,線程掛起
                _getch();
                mythread.SuspendThread();
                cout
            <<"thread suspend"<<endl;

                
            //接任意鍵,線程停止
                _getch();
                mythread.StopThread();
                cout
            <<"thread stop"<<endl;

                
            //按任意鍵,程序退出
                _getch();

                
            return 0;
            }



            posted on 2011-03-11 14:45 C++技術中心 閱讀(7534) 評論(7)  編輯 收藏 引用 所屬分類: Windows 編程

            Feedback

            # re: 一個封裝好的線程類[未登錄] 2011-03-12 10:16 Lucifer
            我覺得你應該把static unsigned __stdcall start_address( void * obj);設置為private的  回復  更多評論
              

            # re: 一個封裝好的線程類 2011-04-24 01:15 dongxu
            如果線程需要傳入參數時這個封裝類比較難做到
            可以改進一下
              回復  更多評論
              

            # re: 一個封裝好的線程類 2011-04-24 08:24 C++技術中心
            @dongxu
            你好,該類是封裝好的類。如果自己的類需要擁用線程的特征,可以繼承之。然后覆蓋父類的virtual Run()函數。在里面實現你需要的功能。您如果需要傳入任何對象或指針,可以在你繼承的類中任何新增函數設置。  回復  更多評論
              

            # re: 一個封裝好的線程類 2013-09-30 17:57 歲月漫步
            非常之好,收藏了  回復  更多評論
              

            # re: 一個封裝好的線程類 2014-09-02 23:32 abc
            WaitForSingleObject(m_hthread,INFINITE); //等待線程退出

            這里是不是寫錯了?不起作用的?
              回復  更多評論
              

            # re: 一個封裝好的線程類 2014-11-06 18:43 freelege
            我覺得你的m_hEventSuspend最好改為m_hEventResume, 否則意思正好相反。  回復  更多評論
              

            # re: 一個封裝好的線程類 2015-08-27 10:21 Mis毛
            使用了static,限制了其只能創建一個子線程,假若我想創建多個子線程怎么辦?  回復  更多評論
              

            日韩乱码人妻无码中文字幕久久 | 久久久久无码精品国产| 久久99九九国产免费看小说| 日本高清无卡码一区二区久久| 亚洲国产精品综合久久网络 | 伊人 久久 精品| 无码国内精品久久人妻| 久久精品嫩草影院| 久久久久亚洲AV无码专区桃色 | 久久99国产精品成人欧美| 久久精品国产福利国产琪琪| 久久久久久久综合狠狠综合| 久久99久久99小草精品免视看| 热99RE久久精品这里都是精品免费 | 久久精品成人免费看| 精品久久久久国产免费| 久久精品aⅴ无码中文字字幕重口| 久久99精品国产麻豆蜜芽| 国产综合久久久久久鬼色| 色欲综合久久躁天天躁| 国产精品免费福利久久| 久久婷婷午色综合夜啪| 久久99亚洲综合精品首页| 久久久精品免费国产四虎| 午夜精品久久久久久久| 亚洲国产精品无码久久九九| 爱做久久久久久| 日本精品久久久久中文字幕8| 无码精品久久久天天影视| 国内精品人妻无码久久久影院导航| 久久久久久av无码免费看大片| 久久福利青草精品资源站免费| 嫩草伊人久久精品少妇AV| 久久www免费人成看片| 2020久久精品亚洲热综合一本| 老司机午夜网站国内精品久久久久久久久 | 久久久久高潮毛片免费全部播放| 香蕉久久av一区二区三区| 日韩人妻无码一区二区三区久久 | 久久有码中文字幕| 久久久综合香蕉尹人综合网|