• <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++技術中心 閱讀(7532) 評論(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国产精品亚洲| 久久久久高潮毛片免费全部播放 | 狠狠色伊人久久精品综合网 | 久久亚洲AV永久无码精品| 久久久无码精品亚洲日韩蜜臀浪潮| 久久久精品人妻一区二区三区蜜桃| 四虎国产精品免费久久5151| 三级三级久久三级久久| 久久99国产精品久久| 久久精品极品盛宴观看| 国产一区二区精品久久| 一本色道久久综合亚洲精品| 久久精品国产99国产精品| 久久精品国产亚洲av高清漫画| 久久久久久久综合日本| 丁香五月网久久综合| 久久午夜无码鲁丝片秋霞 | 五月丁香综合激情六月久久| 久久综合久久伊人| 91精品国产91久久久久久青草| 久久精品国产男包| 国产精品久久久久久久app| 久久久久亚洲AV无码专区网站 | 亚洲国产精品久久久久久| 亚洲国产精品无码久久久秋霞2| 久久亚洲AV无码西西人体| 国产精品综合久久第一页| 97r久久精品国产99国产精| 久久亚洲AV成人无码电影| 人妻久久久一区二区三区| 一本一本久久a久久综合精品蜜桃 一本一道久久综合狠狠老 | 久久国产精品99精品国产| 中文字幕无码免费久久| 久久精品国产亚洲AV香蕉| 久久久久人妻一区二区三区| 久久九九兔免费精品6| 国产成年无码久久久免费|