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

            厚積薄發. 勤為槳,思為帆

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

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

            目下的問題是我想把這個共享數據區做成可變化的動態區,當讀入數據大時,一次讀入全部讀完。當數據量小時,則在規范范圍的空間中運行。

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

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

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


            #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 閱讀(3252) 評論(0)  編輯 收藏 引用
            青青草原综合久久大伊人导航 | 青青草原综合久久大伊人精品| 理论片午午伦夜理片久久 | 日韩一区二区三区视频久久 | 精品久久人妻av中文字幕| 69久久精品无码一区二区| 久久久久久噜噜精品免费直播| yy6080久久| 久久精品无码一区二区三区| 国产精品亚洲综合久久| 国内精品久久久久久99| 久久一区二区免费播放| 国产99精品久久| 欧美日韩精品久久久久| 少妇久久久久久久久久| 久久亚洲国产成人影院网站 | 亚洲国产精品久久久久| 2021久久精品免费观看| 久久青草国产精品一区| 久久一日本道色综合久久| 亚洲精品tv久久久久| 久久久99精品一区二区| 久久99精品国产自在现线小黄鸭| 久久久久国产视频电影| 国产精品久久久久乳精品爆| 青青草原综合久久大伊人精品| 久久久久精品国产亚洲AV无码| 国产69精品久久久久APP下载| 九九99精品久久久久久| 丰满少妇人妻久久久久久| 久久精品免费一区二区| 久久婷婷色香五月综合激情| 久久亚洲AV无码西西人体| 91精品国产综合久久四虎久久无码一级| 中文字幕乱码人妻无码久久| 日韩精品无码久久久久久| 一本久久综合亚洲鲁鲁五月天亚洲欧美一区二区 | 久久婷婷是五月综合色狠狠| 日本精品久久久久久久久免费| 91麻豆精品国产91久久久久久 | 99久久无色码中文字幕|