时间:2021-05-20
找到GetShortPathName的方法签名,
DWORD GetShortPathName(LPCTSTR tpszLongPath,TPTSTR lpszShortPath,DWORD cchBuffer);
非托管及托管数据类型对应关系:
LPCTSTR String
LPTSTR StringBuilder
DWORD int
DllImport的导入规则:
1、方法名与Win API完全一样。如果在C#中调用时显示完全不同的方法名称,则需要引入EntryPoint属性,使用别名显示。
2、函数除需要DllImport类修饰符外,还需要声明public static extern类型。
3、函数返回值和参数必须和调用的API的完全一样。
4、必须引入System.Runtime.InteropServices命名空间。
代码:
复制代码 代码如下:
using System.Runtime.InteropServices;
public class Test
{
[DllImport("kernel32.dll",CharSet=CharSet.Auto,EntryPoint="GetShort")]
public static extern int GetShortPathName(
[MarshalAs(UnmanagedType.LPTStr)] String path,
[MarshalAs(UnmanagedType.LPTStr)] StringBuilder shortPath,
int shortPathLength);
}
代码调用中kernel32.dll的路径之所以没写是因为DllImport会按照以下三种顺序查找Dll:
1、exe所在目录;2、System32目录;3、环境变量目录。
MarshalAs为可选类型,因为每个数据类型都有默认的封送行为,该属性指示如何在托管代码和非托管代码之间的封送数据,可将该属性用于参数、字段和返回值。大多数情况下该属性只是用UnmanagedType枚举类型就能满足大多数非托管的数据类型,如默认情况下字符会被当作BStr传入到Dll中,可以使用MarshalAs将字符串指定为LPTStr、LPWStr或LPStr等。
DllImport可选属性解释
EntryPoint 可对方法采用不同的名称,使用别名
CharSet 函数调用使用Unicode还是Ansi
ExactSpelling False,表示让编译器自己选择使用Unicode或Ansi
CallingConvetnion 它的参数指示入口点调用的约定;不指定默认为CallingConvention.WinAPI
PreserveSig 指示方法签名应当被保留还是被转换,当被转换时它被转换为一个具有HRESULT返回值和该返回值的一个名为retval的附加输出参数的签名,默认为true。
SetLastError 指定是否保留上一次错误,默认为false
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
IDispose模式在C++中用的很多,用来清理资源,而在C#里,资源分为托管和非托管两种,托管资源是由C#的CLR帮助我们清理的,它是通过调用对象的析构函数完
C#如何调用一个非托管动态库中的函数呢,比如用VC6写的动态库,总之C#调用动态库的过程是比Java调用DLL动态库方便快捷多了,下面举例说明这个过程。1、创建
C#中如何合理的释放非托管内存?在本文中我们将讲解使用IDisposable释放托管内存和非托管内存。 A.首先需要让类实现IDisposable接口,然
一、托管代码/非托管代码C#代码通过C#编译器编译成程序集,程序集由微软中间语言组成,CLR会为程序集开辟一个应用程序域,程序集就是运行在这个应用程序域里面的,
1、调用系统dll使用其提供的方法。引用的dll,复制代码代码如下:[DllImport("kernel32.dll")]publicstaticexterni