• <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 閱讀(3253) 評論(0)  編輯 收藏 引用
            久久人人爽人爽人人爽av| 新狼窝色AV性久久久久久| 99久久成人18免费网站| 99久久精品免费| 97精品依人久久久大香线蕉97| 色综合久久无码中文字幕| 青草影院天堂男人久久| 国产A级毛片久久久精品毛片| av无码久久久久不卡免费网站| 久久婷婷五月综合色99啪ak| 久久久久久久亚洲Av无码| 国产日韩欧美久久| 久久久亚洲欧洲日产国码二区| 天天综合久久久网| 人妻久久久一区二区三区| 亚洲国产精品综合久久网络| 91久久精一区二区三区大全| 久久99精品久久久大学生| 久久e热在这里只有国产中文精品99| 亚洲狠狠婷婷综合久久久久| 久久综合九色综合久99| segui久久国产精品| 99国产精品久久久久久久成人热| 一本大道久久东京热无码AV| 99久久婷婷国产综合精品草原| 精品乱码久久久久久久| 亚洲精品无码久久一线| 国内精品伊人久久久久777| 亚洲精品国产综合久久一线| 国产精品久久久天天影视香蕉 | 亚洲国产成人久久一区久久| 久久久久一区二区三区| 国产午夜精品理论片久久影视| 久久久久久国产精品免费无码| 伊人久久无码中文字幕| 久久人做人爽一区二区三区| 伊人久久大香线蕉综合网站 | 亚洲AV日韩精品久久久久| 久久中文字幕人妻丝袜| 国产亚洲精品久久久久秋霞| 久久影院综合精品|