• <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,限制了其只能創建一個子線程,假若我想創建多個子線程怎么辦?  回復  更多評論
              

            亚洲国产精品一区二区三区久久 | 狠狠色丁香久久婷婷综合| 品成人欧美大片久久国产欧美| 久久久中文字幕| 久久亚洲AV无码精品色午夜 | 青青久久精品国产免费看| 久久伊人精品一区二区三区| 久久人人爽人人爽人人AV| 久久精品一区二区影院| 久久婷婷成人综合色综合| 久久精品国产精品亜洲毛片| 久久久久亚洲精品天堂| 久久激情五月丁香伊人| 精品综合久久久久久97超人| 亚洲欧美一级久久精品| 麻豆精品久久精品色综合| 亚洲中文字幕无码一久久区| 久久男人AV资源网站| 999久久久国产精品| 青草国产精品久久久久久| 国产精品99久久久久久宅男小说| 精品乱码久久久久久夜夜嗨| 国产婷婷成人久久Av免费高清| 一本大道久久东京热无码AV | 91精品国产色综合久久| 国产成人无码精品久久久性色| 亚洲а∨天堂久久精品| 狠狠精品久久久无码中文字幕| 久久99精品久久久久久| 精品久久久久久亚洲精品| 色综合久久无码五十路人妻| 久久精品中文字幕一区| 亚洲国产天堂久久久久久| 中文字幕久久精品 | 94久久国产乱子伦精品免费| 国产精品久久久久久福利69堂| 国产成人精品白浆久久69| 91久久精一区二区三区大全| 国产精品一区二区久久 | 亚洲中文字幕伊人久久无码 | 97久久久精品综合88久久|