• <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++技術中心 閱讀(7574) 評論(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,限制了其只能創建一個子線程,假若我想創建多個子線程怎么辦?  回復  更多評論
              

            久久久精品久久久久特色影视| 噜噜噜色噜噜噜久久| 久久综合亚洲欧美成人| 精品国产VA久久久久久久冰| 99精品伊人久久久大香线蕉| 久久久久无码专区亚洲av| 亚洲中文字幕久久精品无码喷水| 国产午夜免费高清久久影院| 色播久久人人爽人人爽人人片aV| 久久亚洲国产成人精品性色| 久久久久亚洲av成人无码电影 | 亚洲αv久久久噜噜噜噜噜| 久久99国产综合精品女同| 欧美性大战久久久久久| 久久婷婷五月综合97色一本一本| 国产亚洲美女精品久久久| 人妻精品久久久久中文字幕一冢本| 国产真实乱对白精彩久久| 久久精品一本到99热免费| 日韩人妻无码一区二区三区久久99| 久久91精品久久91综合| 久久丫精品国产亚洲av不卡 | avtt天堂网久久精品| 久久中文字幕人妻熟av女| 大蕉久久伊人中文字幕| jizzjizz国产精品久久| 精品久久久久久久无码| 欧美国产成人久久精品| 久久久人妻精品无码一区 | 亚洲AV日韩精品久久久久| 久久久久国产一区二区| 久久99精品久久久久久9蜜桃| 午夜精品久久久久久久久| 久久精品国产清自在天天线 | 久久福利片| 国产福利电影一区二区三区久久久久成人精品综合 | 亚洲国产精品久久久久久| 久久国产精品免费一区二区三区| 久久久精品国产Sm最大网站| 欧美亚洲国产精品久久蜜芽| 97久久综合精品久久久综合|