• <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>
            隨筆-341  評論-2670  文章-0  trackbacks-0
                此管道非彼管道,不是unix用來做命令行的那個。

                Windows的管道可以訪問本機或已知機器名的機器上的命名管道,自己也可以建立命名管道。一個命名管道就跟一個server socket一樣,可以進行listen,并產生很多實例來跟很多個client交談。主要函數有:

                CallNamedPipe:連接、讀、寫、關閉,TimeOut
                ConnectNamedPipe:等待client連接
                CreateNamedPipe:創建named pipe
                DisconnectNamedPipe:斷開連接
                PeekNamedPipe:試探pipe輸入緩沖區
                WaitNamedPipe:等待直到named pipe可以開始連接,client用
                Client使用CreateFile、WriteFile與ReadFile進行必要的操作。

                最近實習用wcf做項目,驚訝于wcf對網絡的封裝用起來非常舒服,因此也想在C++上實現一個過過癮。當然,我并不打算支持SOAP,而且我也想加上遠程對象訪問的功能,也就是說A產生的對象,傳到另一臺機器B上,B發給C,C仍然能夠調用對象的函數,只要接口正確。wcf可以在同一個端口上host很多屬于不同應用程序的服務,Pipe應該可以解決這個消息分派的問題,因為一個端口只能host一個server socket,至少我是這么想的。

                因此封裝了一下。上面列出的函數具體用法就自己看msdn了。
             1 #include "..\..\..\..\VL++\Library\Platform\VL_Console.h"
             2 #include "..\..\..\..\VL++\Library\Data\VL_System.h"
             3 #include "..\..\..\..\VL++\Library\Data\VL_Comm.h"
             4 
             5 using namespace vl;
             6 using namespace vl::platform;
             7 using namespace vl::system;
             8 using namespace vl::system::synchronization;
             9 using namespace vl::communication;
            10 
            11 void vlmain(VL_Console& Con)
            12 {
            13     Con.SetTitle(L"Vczh Pipe");
            14     Con.SetTestMemoryLeaks(true);
            15     Con.SetPauseOnExit(true);
            16 
            17     VBool ServerProcess=false;
            18     VL_SynEvent Event;
            19     switch(Event.Create(false,true,L"VCZH_EVENT"))
            20     {
            21     case VL_SynObject::arSucceed:
            22         ServerProcess=true;
            23         Con.Write(L"Server\r\n");
            24         Con.Write(L"Press [ENTER] to start.\r\n");
            25         Con.WaitForEnter();
            26         break;
            27     case VL_SynObject::arAlreadyExists:
            28         Con.Write(L"Client\r\n");
            29         Con.Write(L"Waiting for signal");
            30         Event.WaitFor();
            31         Con.Write(L"Signaled\r\n");
            32         break;
            33     case VL_SynObject::arFail:
            34         Con.Write(L"Fail\r\n");
            35         return;
            36     }
            37     if(ServerProcess)
            38     {
            39         VL_PipeServer Server(L"\\\\.\\pipe\\VczhPipe",true,true,1024,1024);
            40         Event.Signal();
            41         VL_AutoPtr<VL_ServerPipe> Pipe=Server.WaitForConnection();
            42         if(Pipe)
            43         {
            44             Con.Write(L"消息鏈接來自:"+Pipe->GetClientComputerName()+L"\r\n");
            45             VWChar Buffer[1024];
            46             while(true)
            47             {
            48                 VInt Read=Pipe->ReadData((VBuffer)Buffer,1024);
            49                 if(Read==-1)
            50                 {
            51                     Con.Write(L"Read Fail.\r\n");
            52                     break;
            53                 }
            54                 else if(Read==0)
            55                 {
            56                     break;
            57                 }
            58                 else
            59                 {
            60                     Con.Write(L"*");
            61                     Buffer[Read]=0;
            62                     Con.Write(Buffer);
            63                     Con.Write(L"\r\n");
            64                 }
            65             }
            66         }
            67         else
            68         {
            69             Con.Write(L"Fail.\r\n");
            70         }
            71         Event.Signal();
            72     }
            73     else
            74     {
            75         VL_AutoPtr<VL_ClientPipe> Pipe=new VL_ClientPipe(L"\\\\.\\pipe\\VczhPipe");
            76         if(Pipe->Connect())
            77         {
            78             VWChar Message1[]=L"This is the first message.";
            79             VWChar Message2[]=L"This is the second message.";
            80             Pipe->WriteData((VBuffer)Message1,sizeof(Message1)-2);
            81             Pipe->WriteData((VBuffer)Message2,sizeof(Message2)-2);
            82         }
            83         else
            84         {
            85             Con.Write(L"Fail.\r\n");
            86         }
            87         Event.WaitFor(1000);
            88     }
            89     Con.Write(L"Stop");
            90 }

                這個程序啟動兩次不關閉,第一個啟動的變成server,第二個啟動的變成client。在server上按回車過程開始。client發兩條消息給server,server接受并打印在屏幕上。過程完成之后過一秒鐘兩個程序結束。之所以要等待一秒鐘是因為,如果直接結束的話會關閉管道,這個時候沒有讀出來的消息也就都不見了。
            posted on 2008-07-31 09:07 陳梓瀚(vczh) 閱讀(4341) 評論(1)  編輯 收藏 引用

            評論:
            # re: Windows中的Pipe 2008-07-31 16:38 | 酸菜
            unix的管道不是光作命令行的,只能說unix shell提供了使用管道的途徑。  回復  更多評論
              
            99久久精品国产一区二区三区| 亚洲国产成人久久精品99 | 国内高清久久久久久| 亚洲精品视频久久久| 亚洲乱码精品久久久久..| 久久九九亚洲精品| 狠狠色丁香久久婷婷综合蜜芽五月| 久久综合久久综合亚洲| 97久久国产亚洲精品超碰热| 久久91综合国产91久久精品| 久久精品国产只有精品2020 | 欧美亚洲国产精品久久| 99国产欧美久久久精品蜜芽| 久久精品无码一区二区日韩AV| 欧美午夜精品久久久久免费视| 精品久久久久久国产牛牛app| 无码国内精品久久人妻蜜桃| 久久人人爽人人精品视频| 蜜臀av性久久久久蜜臀aⅴ麻豆| 久久国产热这里只有精品| 91精品国产综合久久久久久| 久久露脸国产精品| 精品国产青草久久久久福利| 性欧美大战久久久久久久久 | 久久免费精品一区二区| 亚洲国产精品久久久天堂| 久久天天婷婷五月俺也去| 国内精品久久久久久久久电影网| 久久久久亚洲Av无码专| 国内精品人妻无码久久久影院导航| 麻豆久久| 伊人久久成人成综合网222| 久久夜色撩人精品国产| 亚洲国产精品嫩草影院久久 | 69国产成人综合久久精品| 欧美黑人激情性久久| 国产69精品久久久久9999APGF| 久久人人爽人人爽人人片AV东京热 | 亚洲国产精品嫩草影院久久 | 久久国产精品一区二区| 国产亚洲欧美成人久久片|