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

            記錄一些學習小事

            Work hard

            統(tǒng)計

            留言簿

            閱讀排行榜

            評論排行榜

            進程通信——剪貼板

            由于在啟動一個進程后,操作系統(tǒng)會給這個進程分配 4GB 的私有地址空間,至于為何有 4GB 這么大,

            那得考慮進程的私有地址空間和實際物理內存地址空間之間的映射以及頁交換等等細節(jié)問題了,這里不予討論,

            既然操作系統(tǒng)給每一個進程分配的是私有地址空間,自然,這段地址空間也只有這個進程自己才能訪問了,
            既然這段私有地址空間只能由進程本身訪問,那也就說明別的進程是不能夠隨意的訪問這個進程的地址空間的,

            而上面又說任意兩個進程之間是并能夠互相訪問對方的私有地址空間的,都不能訪問了,那還通信個屁啊 ?

            自然上面的訪問對方進程的私有地址空間是行不通了,那應該還有其他辦法的 !!!

            如果我在物理內存中劃分出一塊內存,這一塊內存不為任何的進程所私有,但是任何的進程又都可以訪問這塊內存,

            那么 進程 A 就可以往這塊內存中存放數(shù)據(jù) Data ,然后 進程 B 也是可以訪問這塊內存的,從而 進程 B 就可以訪問到數(shù)據(jù) Data 了,

            這樣不就實現(xiàn)了 進程 A 進程 B 之間的通信了 !!!

            而上面的這種思路就是剪貼板了。

            當然解決進程間通信還有好幾種思路,本文暫只介紹利用剪貼板來實現(xiàn)進程間的通信。
            前面
            這段話是我抄過來的,呵呵,自己寫不了這種書面語。
            我寫一下我對剪貼板的使用,我也是新學的,有不對的地方還請大家指點。

            向剪貼板中寫入數(shù)據(jù)
            打開剪貼板 OpenClipboard
            清空剪貼板 EmptyClipboard
            設置剪貼板數(shù)據(jù)SetClipboardData
            關閉剪貼板CloseClipboard

            從剪貼板讀取數(shù)據(jù)
            打開剪貼板 OpenClipboard
            判斷數(shù)據(jù)類型IsClipboardFormatAvailable
            得到剪貼板數(shù)據(jù)GetClipboardData
            關閉剪貼板CloseClipboard

            我在說下具體的函數(shù)怎么用
            Openclipboard大家在msdn上可以看到 僅有一個參數(shù)hWndNewOwner
            這個參數(shù)表明那個窗口擁有剪貼板的使用權 已在此窗口中打開,別的窗口中調用openclipboard就會失敗
            這個參數(shù)可以設置成null。If this parameter is NULL, the open clipboard is associated with the current task
            呵呵,這個設成null之后 在后邊的 setclipboarddata 就不能采用延遲發(fā)送了。因為……等會說延遲發(fā)送就會知道了。(這是我試驗得出的結論,應該沒問題)
            這個參數(shù)我們暫且設為窗口句柄 m_hWnd(我用的MFC編的)
            EmptyClipboard這個函數(shù)就沒什么說的了。就是清空剪貼板的數(shù)據(jù) 還有就是The function then assigns ownership of the clipboard to the window that currently has the clipboard open.
            SetClipboardData( UINT uFormat, HANDLE hMem);
            有兩個參數(shù)第一個參數(shù)是數(shù)據(jù)類型 我們設置成CF_UNICODETEXT。
            第二個參數(shù)是the hMem parameter identifies a memory object, the object must have been allocated using the function with the GMEM_MOVEABLE flag.
            這句話得意思就是 hmem是塊內存對象的句柄 這塊內存要是GMEM_MOVEABLE 型的。這又要引進一個申請內存的函數(shù)。平常我們用的malloc new 等都是
            在自己的進程中申請空間,如果用他們 我們的通信也就通不成了。所以我們要申請個全局的內存空間
            GlobalAlloc(GMEM_MOVEABLE,dwBytes);第一個參數(shù)就是可移動的意思(當別人申請一塊大空間的時候 比如我們申請的空間比較散亂占用了一部分空間 別人就申請不了一整塊大的空間了。這樣我們的空間如果是可移動的,就會被移動的凝聚一些,別人就有地方申請大的空間了,紅色是我們申請的凌亂的空間,綠色是又想申請的一大塊)。

            這個我不在這里多講,內存管理我懂的也不太多。不懂的可以找找內存管理方面的書。 第二個參數(shù)就是空間大小。

            這樣我們完成了設置剪貼板數(shù)據(jù) ,然后我們關閉剪貼板就行了。
            讀取簡單一些。
            ::OpenClipboard(m_hWnd)
            IsClipboardFormatAvailable(CF_UNICODETEXT)//判斷剪貼板內數(shù)據(jù)類型
            HANDLE hClip=::GetClipboardData(CF_UNICODETEXT)//得到剪貼板的句柄
            然后就是使用里面的數(shù)據(jù)了。這里要注意,一定要給數(shù)據(jù)上鎖 ,就是說我們在使用數(shù)據(jù)的這個時間內,別人不準移動我們的內存。這個大家能理解吧。
            TCHAR * p=(TCHAR *)GlobalLock(hClip);//強制裝換成我們的寬字符  上鎖
            MessageBox(p);輸出即可
              GlobalUnlock(hClip);  解鎖
              ::CloseClipboard();
            這就完成了,我貼一段代碼上來哦

            //這個是寫入剪貼板
                if(!::OpenClipboard(m_hWnd))
                
            {
                    MessageBox(_T(
            "打開剪切板失敗"));
                }

                ::EmptyClipboard();
                  CString str
            =_T("hahaaha");
                  HGLOBAL  hG
            =GlobalAlloc(GMEM_MOVEABLE,sizeof(_T("hahaaha"))+2);
                  _tcscpy_s((wchar_t 
            *)GlobalLock(hG),sizeof(_T("hahaaha"))/2+1,str);
                  GlobalUnlock(hG);
                ::SetClipboardData(CF_UNICODETEXT,hG);
                ::C
            //這個是從剪貼板中讀出數(shù)據(jù)
            if(!::OpenClipboard(m_hWnd))
                     
            {
                         MessageBox(_T(
            "打開剪切板失敗"));
                        
            return ;
                     }

                    
            if (::IsClipboardFormatAvailable(CF_UNICODETEXT))
                
            {

                    HANDLE hClip
            =::GetClipboardData(CF_UNICODETEXT);
                    TCHAR 
            * p=(TCHAR *)GlobalLock(hClip);
                    MessageBox(p);
                    GlobalUnlock(hClip);
                    ::CloseClipboard();
                }

                
            else
                
            {
                    MessageBox(_T(
            "剪貼板的內容不是unicode"));
                }


            然后最后我在說說延遲發(fā)送setclipboarddata 的第二個參數(shù)傳為null 就為延遲發(fā)送
            延遲發(fā)送就是一開始點寫入剪貼板的時候不寫入,然后另一個進程想要得到剪貼板里的信息的時候也就是在getclipboarddata時
            系統(tǒng)會發(fā)個消息給我們以前的那個窗口 還記得openclipboard傳的那個m_hWnd了吧,就是給這個窗口發(fā)個消息WM_RENDERFORMAT
            然后你在這個消息響應函數(shù)中進行把數(shù)據(jù)寫入剪貼板。
            還有一種情況就是你在想粘貼的時候  你的原先寫入的那個程序已經(jīng)關閉了,這樣的話你就帖不了了。 這樣 還有一個消息
            如果你選擇了延遲發(fā)送 然后關閉應用程序的話,就會響應一個WM_RENDERALLFORMATS消息 那么你在這個響應函數(shù)中把你要寫入剪貼板得數(shù)據(jù)
            寫入 就可以避免這種情況了。
            啊 累死我了,可下寫完了。。。。




            posted on 2011-07-31 17:11 陳曉 閱讀(2051) 評論(0)  編輯 收藏 引用

            少妇内射兰兰久久| 亚洲国产日韩欧美久久| 日韩人妻无码精品久久免费一| 日韩久久久久久中文人妻| 国产精品成人久久久久三级午夜电影 | 亚洲欧美精品一区久久中文字幕| 热久久视久久精品18| 国产精品无码久久综合| 国产欧美久久久精品影院| 一级做a爰片久久毛片人呢| 女人高潮久久久叫人喷水| 97久久精品人人澡人人爽| 亚洲精品乱码久久久久久中文字幕| 97久久精品人人澡人人爽| 色综合久久中文字幕无码| 香蕉99久久国产综合精品宅男自| 国产欧美久久一区二区| 久久无码人妻一区二区三区午夜| 久久综合九色综合欧美就去吻 | 久久99国产一区二区三区| 色欲综合久久中文字幕网| 久久亚洲国产成人影院| 久久久国产精品| 韩国三级中文字幕hd久久精品| 国产精品久久久久…| 国产亚洲精久久久久久无码| 影音先锋女人AV鲁色资源网久久| 亚洲午夜久久久| 麻豆久久久9性大片| 国内精品伊人久久久久妇| 久久久精品无码专区不卡| 久久久久国产精品麻豆AR影院 | 久久久久久免费一区二区三区| 久久婷婷成人综合色综合| 人妻无码αv中文字幕久久| 亚洲女久久久噜噜噜熟女| 综合久久国产九一剧情麻豆| 性做久久久久久久| 99精品国产在热久久| 久久久久成人精品无码中文字幕 | 久久亚洲精品国产精品|