C#使用DllImport调用非托管的代码(dll,动态链接库,编程语言)

时间:2024-04-29 00:15:14 作者 : 石家庄SEO 分类 : 编程语言
  • TAG :

    C%23%E4%BD%BF%E7%94%A8DllImport%E8%B0%83%E7%94%A8%E9%9D%9E%E6%89%98%E7%AE%A1%E7%9A%84%E4%BB%A3%E7%A0%81

C#调用非托管代码的方式主要有Com调用、DllImport方式调用、加载非托管动态链接库、直接执行机器码等方式。

现在介绍一下我自己常用的DllImport方式调用MSDN中提到的GetShortPathName方法;找到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

本文:C#使用DllImport调用非托管的代码的详细内容,希望对您有所帮助,信息来源于网络。
上一篇:Swagger-UI的配置与使用下一篇:

5 人围观 / 0 条评论 ↓快速评论↓

(必须)

(必须,保密)

阿狸1 阿狸2 阿狸3 阿狸4 阿狸5 阿狸6 阿狸7 阿狸8 阿狸9 阿狸10 阿狸11 阿狸12 阿狸13 阿狸14 阿狸15 阿狸16 阿狸17 阿狸18