青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

posts - 4, comments - 6, trackbacks - 0, articles - 0
  C++博客 :: 首頁 :: 新隨筆 :: 聯系 :: 聚合  :: 管理

關于windows、線程、消息的一點體會

Posted on 2008-01-02 19:35 hongsion 閱讀(2094) 評論(5)  編輯 收藏 引用 所屬分類: Windows

以下內容完全把window 操作系統當作一個黑盒,因此所有內容只能作為對其內部的一個猜測。

1. windows操作系統內部在創建一個線程的時候,會自動為它創建一個消息隊列。

2.每當一個線程創建一個窗口的時候,操作系統內部都會把該窗口的Handle和線程相關聯。很有可能在操作系統內部會維護一個窗口handle到線程的map. 還有一種可能就是窗口的成員變量里面有一個指針,指向創建它的線程。

3.窗口本身并沒有消息隊列,所有發到窗口的消息,都會自動被發到創建該窗口的線程的消息隊列中。

4.每個線程只能處理自己線程隊列里面的消息,不能處理其他線程消息隊列里面的消息。
所以PeekMessage(LPMSG lpMsg, HWND hWnd, UINT,UINT,UINT)函數中,如果hWnd不是本線程創建的窗口,則該函數調用失敗。

5.由于在線程消息隊列里面的消息會包含有窗口句柄,所以PeekMessage可以專門處理某個特殊窗口的消息。


6. 曾經有疑問線程是不是只有創建了窗口才具有消息隊列,但又覺得應該不是這樣,因為在windows的API里面有個函數叫PostThreadMessage,可以直接把消息投遞到線程的消息隊列里面,而不需要任何窗口句柄。后來在MSDN里面有這么一段描述,覺得解釋的很詳細:
“The system maintains a single system message queue and one thread-specific message queue for each graphical user interface (GUI) thread. To avoid the overhead of creating a message queue for non–GUI threads, all threads are created initially without a message queue. The system creates a thread-specific message queue only when the thread makes its first call to one of the User or Windows Graphics Device Interface (GDI) functions".
 這里唯一的疑問我想應該是”makes its first call to one of the User or Windows Graphics Device Interface (GDI) functions", 這句話的意思是不是等同于創建一個窗口呢?

Feedback

# re: 關于windows、線程、消息的一點體會  回復  更多評論   

2009-04-03 22:22 by rico
有見地!

The system creates a thread-specific message queue only when the thread makes its first call to one of the User or Windows Graphics Device Interface (GDI) functions".

非常有意思的地方,也就是說,程序不能顯示的為自己的一個線程創建消息隊列。更有意思的是一篇文章說,如果你給一個線程postthreadmessage如果失敗,那么對不起,等等再試,直到成功,非常滑稽的設計。最想不通的是,其他操作系統上,你愛怎么創建消息隊列,你就創建,也沒有什么限制,為啥微軟的消息隊列就必須要受限?

恐怕是早期,微軟假設,一個進程一個消息隊列足以。后來支持多線程了,又缺省的認為,工作線程,你別關心UI的事情,不給你消息隊列。等到最后來,覺得線程消息也不錯啊,這樣又允許非主線程擁有消息隊列,并可以在上面完成UI??傊杏X在微軟看來,消息隊列除了干UI的事情,沒啥用。你要在進程之間發個自定義消息,那也不是他很期望的事情。

純屬推測。

# re: 關于windows、線程、消息的一點體會  回復  更多評論   

2009-04-03 22:40 by rico
另外,PostThreadMessage,都不可以帶窗口Handle的喔。當然,如果是發給窗體的,微軟認為,postmessage就可以了。這就讓人納悶了,我消息不是直接發給窗體的,而是直接發給一個線程的,雖然那個窗體屬于某個線程,并最終會被dispatch到對應的窗口,因為操作系統自己也登記了窗口屬于那個線程(博主的推測)。

所以微軟想開發者,老老實實的,你要發消息到另外一個窗口,不用告訴我窗口所在的線程,告訴我窗口句柄就可以了,我(os)曉得該怎么轉發,不用你脫了褲子放屁(對我os來說)。

但是,如果程序自己保存得有窗口所在線程的Handle,你postthreadmessage就不消到操作系統查map,豈不是快些?不過感覺這是微軟的慣例了,盡量封裝多一點,封裝死一點,這樣系統看起來更復雜和高深。同時這樣安裝盤可以做的更大些,這樣,可以可以消耗更多塑料,拉動GDP,而且是圍繞微軟的GDP。

# re: 關于windows、線程、消息的一點體會  回復  更多評論   

2009-05-22 11:47 by 飛鴿傳書
有點難理解。

# re: 關于windows、線程、消息的一點體會  回復  更多評論   

2009-05-22 11:53 by 飛鴿傳書
哈哈,表達得太好了。@rico

# re: 關于windows、線程、消息的一點體會[未登錄]  回復  更多評論   

2012-01-16 17:39 by 葡萄
1. windows操作系統內部在創建一個線程的時候,會自動為它創建一個消息隊列。

這個說的不對。在線程創建的時候,所有線程都是沒有消息隊列的。
只有這個線程中顯式的調用GUI相關函數(例如創建窗口)時或者PostThreadMessage時,才會給這個線程創建消息隊列。

只有注冊用戶登錄后才能發表評論。
網站導航: 博客園   IT新聞   BlogJava   博問   Chat2DB   管理


青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            欧美午夜精品电影| 亚洲精品视频在线播放| 亚洲一二三四久久| 国产精品乱码妇女bbbb| 亚洲影视在线播放| 亚洲图片欧洲图片日韩av| 国产精品日韩专区| 久久精品99| 久久中文在线| 在线亚洲自拍| 欧美怡红院视频| 亚洲国产美女久久久久| 亚洲精品中文字幕有码专区| 欧美午夜片在线观看| 欧美在线免费一级片| 久久影音先锋| 在线一区亚洲| 久久精品国产一区二区三| 亚洲福利视频一区二区| 亚洲精品欧美激情| 国产欧美一区二区精品忘忧草| 欧美h视频在线| 欧美日韩网站| 久久夜色精品国产欧美乱极品| 欧美国产日韩视频| 性欧美大战久久久久久久免费观看| 久久精品99国产精品酒店日本| 日韩视频―中文字幕| 亚洲欧美国产精品专区久久| 国产精品va| 欧美成人亚洲成人日韩成人| 国产精品成人播放| 美女在线一区二区| 国产精品电影网站| 欧美激情一区二区三区在线视频 | 久久精品亚洲一区二区| 久久天天躁狠狠躁夜夜av| 亚洲五月六月| 欧美mv日韩mv国产网站| 久久国产视频网站| 欧美三日本三级三级在线播放| 另类图片综合电影| 国产精品毛片在线| 亚洲欧洲一区二区三区在线观看| 国产精自产拍久久久久久蜜| 亚洲国产影院| 亚洲激情综合| 久久久午夜视频| 欧美一区在线看| 欧美亚洲第一页| 亚洲第一中文字幕在线观看| 久久亚洲春色中文字幕| 欧美一区二区三区日韩视频| 欧美日韩三区| 日韩亚洲视频在线| 亚洲欧洲精品一区| 久久一区国产| 久久美女性网| 伊甸园精品99久久久久久| 一本一本久久| 亚洲欧美日韩国产中文| 欧美网站在线| 一区二区电影免费在线观看| 亚洲视频在线一区观看| 欧美日韩国产限制| 日韩视频在线观看免费| 日韩视频三区| 欧美日韩国产欧| 一区二区三区日韩| 亚洲女同在线| 国产日韩在线亚洲字幕中文| 欧美亚洲日本一区| 久久久久青草大香线综合精品| 国产精品一区二区三区观看| 亚洲欧美日韩在线不卡| 久久精品国产清高在天天线| 国产原创一区二区| 久久精品日韩| 亚洲国产片色| 亚洲天堂视频在线观看| 国产精品午夜在线观看| 欧美影片第一页| 欧美国产一区二区| 一区二区三区日韩在线观看| 国产精品乱子乱xxxx| 午夜精品一区二区在线观看| 久久婷婷久久一区二区三区| 亚洲日韩中文字幕在线播放| 欧美伦理91| 亚洲欧美色婷婷| 男人插女人欧美| 中国成人在线视频| 国产偷国产偷精品高清尤物| 久久综合国产精品| 999在线观看精品免费不卡网站| 性8sex亚洲区入口| 1769国产精品| 国产精品国产福利国产秒拍| 欧美在线三区| 亚洲人成绝费网站色www| 亚洲欧美日产图| 亚洲电影免费| 国产精品天美传媒入口| 久久在精品线影院精品国产| 在线视频你懂得一区二区三区| 久久久精彩视频| 亚洲少妇一区| 在线国产日韩| 国产精品色婷婷| 欧美成人一区二区在线| 亚洲欧美电影在线观看| 欧美激情一区二区三区蜜桃视频 | 亚洲日本一区二区三区| 国产精品久久久免费| 老巨人导航500精品| 亚洲影院免费观看| 亚洲精品美女在线观看| 久久综合伊人77777蜜臀| 中文日韩在线| 亚洲乱码精品一二三四区日韩在线| 国产精品一区在线观看| 欧美日韩精品国产| 美女国内精品自产拍在线播放| 亚洲欧美日韩一区二区| 99热这里只有成人精品国产| 欧美激情在线狂野欧美精品| 久久视频一区| 久久精品成人| 欧美一级精品大片| 亚洲欧美日韩国产一区| 一区二区三区国产盗摄| 亚洲精品1区2区| 在线观看成人av| 国产在线国偷精品产拍免费yy| 国产精品国产三级国产a| 欧美激情第1页| 欧美风情在线观看| 免费久久99精品国产自在现线| 欧美在线亚洲综合一区| 欧美伊人久久大香线蕉综合69| 亚洲欧美日韩在线不卡| 亚洲欧美国产另类| 午夜激情亚洲| 欧美一区二区精品在线| 亚洲一区二区三区精品在线| 亚洲永久在线观看| 亚洲欧美国产不卡| 亚洲欧美一区二区三区在线| 午夜精品成人在线| 午夜精品剧场| 久久国产婷婷国产香蕉| 久久午夜精品一区二区| 久久综合五月| 欧美激情视频网站| 欧美全黄视频| 国产精品一区二区久激情瑜伽| 国产日韩av一区二区| 狠狠色狠狠色综合日日五| 韩日欧美一区二区三区| 亚洲国产成人精品女人久久久| 亚洲第一区在线| 亚洲美女中文字幕| 亚洲视频精品| 久久国产欧美| 欧美国产视频在线| 9l国产精品久久久久麻豆| 亚洲欧美日产图| 久久免费视频一区| 欧美国产激情| 国产麻豆午夜三级精品| 亚洲大胆av| 亚洲一区二区视频在线| 久久精品卡一| 欧美高清自拍一区| 国产精品99久久久久久久女警| 午夜精品一区二区三区四区| 免费成人黄色av| 国产精品亚洲网站| 亚洲国产成人av好男人在线观看| 中日韩美女免费视频网址在线观看| 亚洲专区一区二区三区| 美日韩精品视频| 一区二区三区视频在线看| 久久成人人人人精品欧| 欧美日韩第一区| 国产亚洲在线| 在线一区二区三区做爰视频网站| 久久久999国产| 日韩午夜精品视频| 久久综合福利| 国产美女精品免费电影| 亚洲九九精品| 免费观看成人网| 亚洲在线成人| 欧美日韩免费一区二区三区视频| 韩国精品在线观看| 亚洲欧美国内爽妇网| 亚洲国产日韩一区二区| 欧美一区久久| 国产欧美一区二区精品仙草咪|