C#(.Net) 将非托管dll嵌入exe中

这篇具有很好参考价值的文章主要介绍了C#(.Net) 将非托管dll嵌入exe中。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

前往我的主页以获得更好的阅读体验

C#(.Net) 将非托管dll嵌入exe中 - DearXuan的主页https://blog.dearxuan.com/2021/12/26/C-Net-%E5%B0%86%E9%9D%9E%E6%89%98%E7%AE%A1dll%E5%B5%8C%E5%85%A5exe%E4%B8%AD/

托管dll与非托管dll

托管dll实际上是指C#编写的dll,可以直接右键“引用”导入

而大部分情况下,我们需要引用C++写的dll,如果你的dll是使用 DllImport来导入的,那么它就属于非托管dll,这种dll无法直接嵌入exe中,需要借助工具:Costura.Fody,该工具可以使用VS直接下载

下载与安装

右键引用,选择“管理NuGet程序包”,搜索 "fody"

C#(.Net) 将非托管dll嵌入exe中

 点击Costure.Fody,选择右边详情栏内的“安装”按钮

检查“引用”,发现Costura已经加入到项目中

C#(.Net) 将非托管dll嵌入exe中

添加Dll

右键 解决方案-“添加”-“新建项”

C#(.Net) 将非托管dll嵌入exe中

 新建如图所示的XML文件(如果自动生成了就不需要新建): FodyWeavers.xml

C#(.Net) 将非托管dll嵌入exe中

此时这个XML文件会被添加到项目根目录,以我的dll为例

dll名称为: PicSizer_CUDA.dll

dll位数为: 64位

修改XML文件

<?xml version="1.0" encoding="utf-8"?>
<Weavers
  xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
  xsi:noNamespaceSchemaLocation="FodyWeavers.xsd">
  
  <Costura>
    <Unmanaged64Assemblies>
      PicSizer_CUDA
    </Unmanaged64Assemblies>
  </Costura>
</Weavers>

注意:不要有后缀名,如果是32位只需要把“64”改成“32”

在项目中创建文件夹: Costura64

如果是32位同理改为32

C#(.Net) 将非托管dll嵌入exe中

把dll复制到该文件夹中,在生成时,会自动寻找 Costura64和Costura32文件夹中的dll

将dll设置为“嵌入的资源”

C#(.Net) 将非托管dll嵌入exe中

调用

直接使用DllImport用平常的方式调用即可

const string dll_path = "PicSizer_CUDA.dll";

[DllImport(dll_path, EntryPoint = "SetBrightness", CallingConvention = CallingConvention.Cdecl)]
public static extern bool SetBrightness(IntPtr ori, int length, byte dark);

[DllImport(dll_path, EntryPoint = "IsGPUSupport", CallingConvention = CallingConvention.Cdecl)]
public static extern bool IsGPUSupport();

编译

重新编译出exe,将exe复制到其它路径,可以正常运行文章来源地址https://www.toymoban.com/news/detail-478198.html

到了这里,关于C#(.Net) 将非托管dll嵌入exe中的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • C#利用Costura.Fody制作绿色单文件程序(含多个Dll)合并成一个Exe)

    开发程序的时候经常会引用一些第三方的DLL,然后编译生成的exe文件就不能脱离这些DLL独立运行了。这样交给用户很不方便,希望的效果是直接交付一个exe文件。 这时候就需要借助一款名为Fody.Costura的插件。Fody.Costura是一个Fody框架下的插件,可通过Nuget安装到VS工程中。安装

    2024年02月09日
    浏览(44)
  • VB.NET调用VB6 Activex EXE实现PowerBasic和FreeBasic的标准DLL调用

    VB6写的ActiveX EXE公共对象是外置进程,因此,尽管它是x86 32位的进程,但可以集成到 VB.NET的x64和x32程序中使用。 VS2022的VB.NET程序,调用ActiveX DLL对象我在上篇笔记中写了 VB.NET通过VB6 ActiveX DLL调用PowerBasic及FreeBasic动态库_Mongnewer的博客-CSDN博客 为了简短,调用ActiveX exe就在它上

    2024年02月11日
    浏览(30)
  • C#开发DLL,CAPL调用(CAPL>> .NET DLL)

    ret为dll里函数返回的值。 在visual studio中建立。

    2024年02月08日
    浏览(35)
  • c#调用matlab生成的COM DLL,Matlab GUI程序封装成exe文件并在不安装Matlab的电脑上运行

    最近根据需求用Matlab写了一个简单的软件,但需要安装到其他电脑上运行,倒腾了很久最终成功在其他电脑上运行,现将方法共享给大家。 安装方法: ①程序封装 首先用Matlab写完程序并封装好(我用的是Matlab2018b,封装的时候就用matlab自带的APP封装程序就好[就是黑框框那个

    2024年01月22日
    浏览(39)
  • LabVIEW生成.NET的DLL——C#下调用NI数据采集设备功能的一种方法 [www.cnblogs.com/helesheng]

    Python微信订餐小程序课程视频 https://edu.csdn.net/course/detail/36074 Python实战量化交易理财系统 https://edu.csdn.net/course/detail/35475 LabVIEW是NI公司的数据采集设备的标准平台,在其上调用NI-DAQmx驱动和接口函数能够高效的开发数据采集和控制程序。但作为一种图形化的开发语言,使用L

    2024年02月04日
    浏览(33)
  • C#探索之路(4):浅析C#中的托管、非托管堆栈与垃圾回收

    1、 托管代码: 1、使用 .NET 时,我们经常会遇到“托管代码”这个术语。 2、简而言之,托管代码就是执行过程交由运行时管理的代码。 2、CLR阶段: 1、在托管服务下,相关的运行时称为公共语言运行时 (CLR)。 2、不管使用的是哪种实现(例如 Mono、.NET Framework 或 .NET Core/.NET

    2024年02月05日
    浏览(45)
  • 如何洞察 .NET程序 非托管句柄泄露

    很多朋友可能会有疑问,C# 是一门托管语言,怎么可能会有非托管句柄泄露呢? 其实一旦 C# 程序与 C++ 语言交互之后,往往就会被后者拖入非托管泥潭,让我们这些调试者被迫探究 非托管领域问题 。 为了方便讲述,我们上一个 Event 泄露的案例,使用 C# 调用 C++ ,然后让

    2024年02月12日
    浏览(44)
  • 记一次 .NET某报关系统 非托管泄露分析

    前段时间有位朋友找到我,说他的程序内存会出现暴涨,让我看下是怎么事情?而且还告诉我是在 Linux 环境下,说实话在Linux上分析.NET程序难度会很大,难度大的原因在于Linux上的各种开源工具主要是针对 C/C++, 和 .NET 一毛钱关系都没有,说到底微软在 Linux 上的调试领域支持

    2024年02月14日
    浏览(38)
  • 记一次 .NET某账本软件 非托管泄露分析

    中秋国庆长假结束,哈哈,在老家拍了很多的短视频,有兴趣的可以上B站观看:https://space.bilibili.com/409524162 ,今天继续给大家分享各种奇奇怪怪的.NET生产事故,希望能帮助大家在未来的编程之路上少踩坑。 话不多说,这篇看一个 .NET程序集泄露 导致的CLR私有堆泄露的案例,

    2024年02月08日
    浏览(33)
  • 用 PerfView 洞察.NET程序非托管句柄泄露

    1. 讲故事 前几天写了一篇 如何洞察 .NET程序 非托管句柄泄露 的文章,文中使用 WinDbg 的 !htrace 命令实现了句柄泄露的洞察,在文末我也说了,WinDbg 是以侵入式的方式解决了这个问题,在生产环境中大多数情况下是不能走附加进程的模式,所以这也是它最大的局限性。 那如何

    2024年02月16日
    浏览(31)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包