解決C# X64應(yīng)用程序中讀取WParam溢出的問題
在X86的環(huán)境下,
var wParam = (int)msg.WParam;
工作得很好。
在X64的環(huán)境下,
快速滾動滾輪會出現(xiàn)msg.WParam 轉(zhuǎn)換為int的時候溢出,(WParam=4263510016)。
信息為:
未處理System.OverflowException
Message=算術(shù)運算導(dǎo)致溢出。
Source=mscorlib
StackTrace:
在 System.IntPtr.op_Explicit(IntPtr value)
在 TIM.MouseWheelHandler.MouseWheelMessageFilter.PreFilterMessage(Message& m) 位置。。。
查證WParam是IntPtr,MSDN說
IntPtr 類型被設(shè)計成整數(shù),其大小適用于特定平臺。即是說,此類型的實例在 32 位硬件和操作系統(tǒng)中將是 32 位,在 64 位硬件和操作系統(tǒng)上將是 64 位。
所以,上面的代碼應(yīng)該為:
var wParam = (IntPtr.Size == 8) ? (int)((long)msg.WParam << 32 >> 32) : (int)msg.WParam;
測試通過。
相關(guān)文章
WPF PasswordBox進行數(shù)據(jù)綁定方法
有的時候會遇見PasswordBox的Password屬性不是依賴屬性,因此無法進行數(shù)據(jù)綁定。本文介紹如何通過添加附加屬性解決該問題,有此問題的同學(xué)可以參考下本文2021-06-06
C#操作Byte數(shù)組和十六進制進行互轉(zhuǎn)
這篇文章介紹了C#操作Byte數(shù)組和十六進制進行互轉(zhuǎn)的的方法,文中通過示例代碼介紹的非常詳細。對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2022-05-05
C#控制IE進程關(guān)閉和緩存清理的實現(xiàn)代碼
這篇文章主要介紹了C#控制IE進程關(guān)閉和緩存清理的實現(xiàn)代碼,需要的朋友可以參考下2014-04-04

