2

因此,经过大约一天半的时间,我取得了零进展。

我需要用 C 语言编写一个用于现有应用程序插件的 DLL。DLL 必须由 Visual Studio 2008 编译器使用以下选项进行编译

cl -DNT40 -DPOMDLL -DCRTAPI1=_cdecl -DCRTAPI2=cdecl -D_WIN32 -DWIN32 -DWIN32_LEA N_AND_MEAN -DWNT -DBYPASS_FLEX -D_INTEL=1 -DIPLIB=none -I。-I"C:\plm\2T-RAC\TcEx press53\include" -I"C:\Program Files (x86)\Microsoft Visual Studio 8\VC\include" -c -nologo -EHsc -W1 -Ox -Oy - -MD C:\mydir\myDll.c

然后将其链接到应用程序库。

它实际上需要做什么以及导致我出现问题的原因是,在其中一种方法中,它需要从 sql server 2008 r2 中提取数据。

从我今天看到的情况来看,您将无法直接在 C 中执行此操作,因为 2005 年以后的 SQL Server 旨在与 CLR 语言(C#、C++、VB.Net)进行通信。

有人建议我使用 VB.Net dll 处理所有数据库通信,然后从 C dll 中调用所述函数。

我在从非托管代码调用托管 dll 的主题上发现的大部分内容都谈到了 pinvoke 或 com 包装器,并且主要是从 c++ 的角度来看的。

我对 COM 或任何提到的技术的经验为零,因此如果有人能提供帮助,将不胜感激。

4

3 回答 3

10

您有很多选择可以做到这一点,但并非所有这些都是微不足道的。

混合模式组装

将托管代码导出到 C 客户端的第一种也是更简单的方法是使用 C++/CLI 编写代码(或使用该语言编写包装器)。您只需像在普通非托管代码中那样导出所需的 C 函数,并在它们的实现中调用所需的托管函数。在MSDN上。

COM 互操作

您将托管类导出为 COM 对象。在非托管代码中,您会看到普通的 COM 对象,请看这里

反向 P/Invoke

你可以用不同的方式来做。更简单的一种是换位思考。如果您有一个 VB.NET 程序集 ( vbnet.dll) 和一个 C 库 ( purec.dll),您可能会想到的第一件事是在 in 中添加一个依赖。如果您这样做,您必须使用 COM 或使您的应用程序成为 .NET 主机。更简单的方法是还原:向in添加依赖项(使用 P/Invoke)。您的 C 接口将导出一个(例如)可以用函数指针填充的,您将在 VB.NET 中填充它(作为委托),您的 C 代码将简单地调用它们。看看这里vbnet.dllpurec.dllpurec.dllvbnet.dllstructstruct

其他选项

本地主机:这是艰难的方式。您的本机应用程序将托管 .NET 应用程序。它又长又复杂,如果你只需要导出几个函数,我想它太多了。我在这里发帖仅供参考:MSDN 上的托管概述
工业电脑。您可以将您的应用程序分开,彼此可以忽略另一个应用程序的编写方式。只需定义一个接口和一个通道来连接它们(命名管道、共享内存或其他任何东西,请在此处查找列表)。如果您的 VB.NET 应用程序是一项服务或它由正在运行的应用程序托管,如果它只是导出一些您无法执行的功能,则此方法有效。

于 2012-05-30T17:38:02.620 回答
1

我解决这个问题的方法只是让 C dll 调用 cmd 并执行编译的 VB.NET 可执行文件并通过管道输出它。虽然这不是一个完全理想的解决方案,但它在我需要的只是一个字符串的情况下工作。

于 2012-06-29T18:43:46.567 回答
0

除非这是您在任何地方都使用的现有 vb.net dll(业务层),否则我可能会建议您不要在 C 应用程序中使用它。

有多种方法可以从 C 中与 MSSQL 进行通信。通过本机驱动程序或 ODBC 等。

于 2012-05-30T17:25:39.720 回答