• <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>

            kenlistian

            厚積薄發(fā). 勤為槳,思為帆

               :: 首頁 :: 新隨筆 ::  :: 聚合  :: 管理 ::
              73 隨筆 :: 4 文章 :: 22 評論 :: 0 Trackbacks

            這是我做的測試例子,考慮到一個線程用于去讀數(shù)據(jù)庫,一次性插入多條數(shù)據(jù)到共享數(shù)據(jù)區(qū),另外搞2個上的線程去讀這個共享數(shù)據(jù)區(qū),以后打算搞個線程池來處理讀部分。

            目下的問題是我想把這個共享數(shù)據(jù)區(qū)做成可變化的動態(tài)區(qū),當讀入數(shù)據(jù)大時,一次讀入全部讀完。當數(shù)據(jù)量小時,則在規(guī)范范圍的空間中運行。

            采用vector<mystructData>方式動態(tài)變化,比如要刪除超過長度之外的設(shè)置,只需要earse就可以了,在線程中每次通過begin,end自動掃描處理中數(shù)據(jù)部分。

            如果把線程部分放到dll中,那么考慮到如何讀取共享數(shù)據(jù)區(qū),采用導(dǎo)出函數(shù)方式,把主線程中的一個函數(shù)地址傳入到dll中,然后在這個函數(shù)中通過

            find_if(a.begin(),a.end(),myfunc)照樣可以處理dll中跑線程的問題,之所以考慮用dll分離各個線程部分,是考慮到業(yè)務(wù)不同時,每個dll處理掃描共享數(shù)據(jù)區(qū),發(fā)現(xiàn)自己的業(yè)務(wù)就去處理,不是則不理會,這樣考慮設(shè)計可以通過編寫dll方式來擴展不同的業(yè)務(wù)。


            #include "stdafx.h"
            #include <vector>
            #include <iostream>
            #include <windows.h>
            #include <process.h>
            #include <algorithm>

            using namespace std;

            struct te
            {
             int IsGet;
             int a1;
             int s1;
             char b1[20];
            };

            bool isget(te t)
            {
             return t.IsGet ==1;
            }
            bool getdata(te t)
            {
             return t.IsGet==0;
            }
            vector<te> a; 
            HANDLE hMutex;

            void myprint(te t)

             cout<<"   ALL "<< (t.IsGet == 0? "Have": "No ")<< "("<<t.a1<<")"<<t.s1<<" " << t.b1 <<endl;
              
            }

            DWORD WINAPI insertdata( LPVOID lpParam )

             vector<te>::iterator p; 
             int i = 0;
             while (1)
             {  

              do{
               
                p = find_if(a.begin(), a.end(), isget);  
                if (p!= a.end())
                {      
               WaitForSingleObject(hMutex, INFINITE);
               i++;
               p->IsGet = 0; 
               p->s1 = i;
               sprintf(p->b1, "%s- %d", "thread_insert" , i); 
                  cout<<" insert("<<p->a1<<") " << p->s1<<"  " << p->b1 <<endl;  
                  ReleaseMutex(hMutex);
                }
                //Sleep(1000);
               
              }
              while(p != a.end());
              
              WaitForSingleObject(hMutex, INFINITE);
              cout<<"---------------------------"<<endl;
              for_each(a.begin(), a.end(), myprint);
              ReleaseMutex(hMutex);  
              Sleep(11000);
             }


             return 0;
            }

            //讀線程,讀完對IsGet標志為1
            DWORD WINAPI processdata( LPVOID lpParam )
            {
             vector<te>::iterator p;
             
             while(1)
             {
              WaitForSingleObject(hMutex, INFINITE);
              p = find_if(a.begin(), a.end(), getdata);
              if (p != a.end())
              {   
                cout<<"("<< (char*)lpParam << ") get (" << p->a1<<") " << p->s1 <<" " << p->b1 <<endl;   
                p->IsGet = 1;   
                p->s1 = 0;
                p->b1[0] = '\0';
              
              }  
              ReleaseMutex(hMutex);
              Sleep(500);
             }

             return 0;
            }

            int main(int argc, char* argv[])
            {
             
             HANDLE hInsertHandle, hProcessHandle1,hProcessHandle2;
             DWORD dwThreadId;

             te tt1;
             for(int i = 0; i < 10;i++)
             {
              tt1.IsGet = 1;             //可以寫入標志
              tt1.a1 = i;
              tt1.s1 = 0;
              sprintf(tt1.b1,"%d", i);
              a.push_back(tt1);
             }

             hMutex = CreateMutex(NULL, false, "mutex");

              hInsertHandle = CreateThread(
                    NULL,                 
                    0,                    
              insertdata,        
                    NULL,                   // argument to thread function
                    0,                           // use default creation flags
                    &dwThreadId);
             
              hProcessHandle1 = CreateThread(  //讀出線程1
                    NULL,                 
                    0,                    
              processdata,        
                    "proc1" ,              
                    0,                     
                    &dwThreadId);
                hProcessHandle2 = CreateThread(
                    NULL,                 
                    0,                    
              processdata,        
                    "proc2",            
                    0,                  
                    &dwThreadId);

             
             while(1)
             { 
              printf("main thread ...\n");
              char c = getchar();
              if (c== 'q')
               break;
             }

             return 0;
            }

            posted on 2006-05-28 15:27 kenlistian 閱讀(3262) 評論(0)  編輯 收藏 引用
            一本一本久久aa综合精品| 99久久精品日本一区二区免费| 久久精品成人免费观看97| 久久久久亚洲AV成人网| 久久婷婷五月综合色99啪ak| 久久国产欧美日韩精品| 久久久噜噜噜久久中文字幕色伊伊| 欧美亚洲国产精品久久高清| 国产精品久久亚洲不卡动漫| 国产精品成人久久久| a级毛片无码兔费真人久久| 色诱久久久久综合网ywww| 婷婷久久综合九色综合绿巨人| 色综合久久久久无码专区| 一级女性全黄久久生活片免费 | 国内精品伊人久久久久777| 久久香蕉一级毛片| 久久www免费人成看片| 精品久久久久久国产免费了| 国产69精品久久久久9999APGF| 久久精品成人欧美大片| 色综合久久综精品| 99久久99久久久精品齐齐| 精品国产乱码久久久久久人妻| 久久激情五月丁香伊人| 91精品国产高清久久久久久91 | 91精品无码久久久久久五月天| 亚洲日本va中文字幕久久| 国内精品伊人久久久久妇| 亚洲国产成人精品久久久国产成人一区二区三区综 | 国产精品欧美久久久久无广告| 国产精品视频久久| 国产精品一久久香蕉产线看 | 青青青国产精品国产精品久久久久 | 国产国产成人久久精品| 久久综合综合久久狠狠狠97色88| 国内精品伊人久久久久AV影院| 久久婷婷五月综合97色| 2021少妇久久久久久久久久| 97久久香蕉国产线看观看| 91麻精品国产91久久久久|