所以我正在开发一个c#Windows Form应用程序,我的部分代码使用user32.dll中的一些方法 . 在下面列出它们 .
public static extern IntPtr SendMessage(IntPtr hWnd,UInt32 Msg,IntPtr wParam,IntPtr lParam);
public static extern bool ReleaseCapture();
public static extern IntPtr GetForegroundWindow();
public static extern int GetWindowText(IntPtr hWnd,[MarshalAs(UnmanagedType.LPWStr)] StringBuilder lpString,int nMaxCount);
public static extern uint GetWindowThreadProcessId
public static extern bool GetLastInputInfo(ref LASTINPUTINFO plii)
起初我把它们放在文件中,所有主要表单代码都是 public partial class MainForm 的一部分,这一切都有效 . 然后,当我在Visual Studio Community 2015中运行代码分析时,它抱怨说“因为它们是P / Invoke方法,所以它们应该在名为NativeMethods,SafeNativeMethods或UnsafeNativeMethods的类中定义 .
因此,作为一名优秀的编码员,我总是服从他的IDE的想法,我立即制作一个新的类文件,并遇到第一个问题 .
包含这些函数的类是否不安全(它是否也是不受管理的)?我应该使用哪个名称,并且应该使用[DebuggerNonUserCode]属性将类声明为内部静态?
当我做更多阅读以试图解决这个问题时,我不断地参考为代码创建一个包装器类,所以我开始研究它 . 这产生了大量关于c或c的安全性和包装,原型以及大量其他信息的东西,这些信息似乎没有用,让自己完全迷失了 .
所以我想我想知道的是两件事 . 1,我是否需要(或者最好这样做)制作一个包装类来使用这些方法,如果是这样,我将如何去做呢? 2,如果我将课程设为Unsafe / SafeNativeMethods,我应该将其称为安全还是不安全?是否应该公开所有方法?或者应该将方法声明为private并编写一些getters / setter,如:
public IntPtr getGetForegroundWindow()
{
return GetForegroundWindow()
}
要么
public setSendMessage(IntPtr hWnd, UInt32 Msg, IntPtr wParam, IntPtr, lParam)
{
SendMessage(hWnd, Msg, wParam, lParam);
}
或者我是否需要使用代表或其他东西而不是setter和getter?
很抱歉这个问题有点大脑转储 . 每当我想到我找到答案时,我最终会得到更多问题,所有关于安全/不安全/安全的讨论让我感到担心 . 我不介意谷歌搜索和阅读主题,但阅读清单只是为了弄清楚要读什么是如此想象我想停下来问这里,看看我是否甚至问正确的问题 . 提前致谢 .