c#中使用消息循环机制发送接收字符串的方法和数据类型转换
在定義消息時忘記了用戶可定義消息的邊界值,在網上一陣瘋找后來發現是const int WM_USER = 0x400。接著是SendMessage的lParam類型不能決定(默認是IntPtr),我想發送字符串信息,就將它定為了string型,然后通過重寫DefWndProc接收自定義消息。問題出現:(string) message.lParam提示不能轉換,然后使用另一種方法:(string)message.GetLParam(typeof(string)),依然有錯,提示應該重載string的構造函數建立string的無參構造函數(夠狠)。
后來在網上見到一篇文章“C#用WM_COPYDATA消息來實現兩個進程之間傳遞數據”,經提示想到一方法:用結構體封裝string字段,然后傳結構體就可以了(結構體有自己的無參構造函數--其實原本想自己寫個無參構造函數,卻發現在vs2005下無法編譯通過,提示不能夠創建結構體的無參構造函數)。這樣就可以在DefWndProc中通過?(tagStructStr)message.GetLParam(typeof(tagStructStr))?將LParam轉換為結構體類型,然后取出它的字符串字段就實現了string的傳送了。
事還沒完,一次偶爾碰到有人說可以使用Marshal轉換string。自己查了下MSDN于是一個傳送string的另一方法產生:SendMessage仍然是傳string,在DefWndProc中可以用?string str = Marshal.PtrToStringAnsi(m.LParam)?將IntPtr類型的LParam轉換為string類型,其實還可以使用?IntPtr p = Marshal.StringToHGlobalAnsi(s)?將string類型轉換為IntPtr類型。
進一步深究,發現這其中還有內情:SendMessage使系統API,IntPtr屬于非托管類型,而我們在C#中使用的string等類型是托管類型,使用Marshal轉換其實真正意義是實現了托管與非托管類型的轉換。看來在C#與非托管的C++/C進行交互傳遞數據時,要少不了Marshal的身影了。
總結
以上是生活随笔為你收集整理的c#中使用消息循环机制发送接收字符串的方法和数据类型转换的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 解决: 网站访问报错 AccessDen
- 下一篇: C#WebApi路由机制详解