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

            狠狠色婷婷久久一区二区三区| 久久国产精品久久久| 超级97碰碰碰碰久久久久最新| 97精品伊人久久久大香线蕉| 狠狠色婷婷综合天天久久丁香| 久久青青草原精品国产软件| 久久久久亚洲Av无码专| 久久精品国产亚洲AV不卡| 日韩人妻无码精品久久久不卡| 国产精品久久久久乳精品爆 | 狠狠综合久久综合中文88| 久久天天躁狠狠躁夜夜av浪潮| 蜜臀久久99精品久久久久久小说| 91精品久久久久久无码| 国产成人久久精品一区二区三区 | 亚洲欧洲中文日韩久久AV乱码| 波多野结衣中文字幕久久 | 99久久99久久精品免费看蜜桃| 色婷婷狠狠久久综合五月| 国内精品久久久久影院优| 怡红院日本一道日本久久| 亚洲精品国产美女久久久| 人妻无码久久精品| 国产99久久久国产精品~~牛| 久久久无码精品亚洲日韩蜜臀浪潮| 久久精品亚洲福利| 国产成人精品久久一区二区三区av| 久久久女人与动物群交毛片| 久久久久久久97| 久久五月精品中文字幕| 国产精品激情综合久久| 91精品婷婷国产综合久久| 久久久91精品国产一区二区三区| 97精品伊人久久久大香线蕉| 国产亚洲美女精品久久久2020| 亚洲欧美国产日韩综合久久 | 国产A三级久久精品| 久久精品人妻中文系列| 一本一本久久a久久综合精品蜜桃| 久久久久免费精品国产| 亚洲精品无码久久久久久|