- android - RelativeLayout 背景可绘制重叠内容
- android - 如何链接 cpufeatures lib 以获取 native android 库?
- java - OnItemClickListener 不起作用,但 OnLongItemClickListener 在自定义 ListView 中起作用
- java - Android 文件转字符串
我正在使用 visual studio 2010 构建 .dll。我写了一个试验:
// trialDLL.h
#ifndef TRIALDLL_H_
#define TRIALDLL_H_
// ... MyMathFuncs class definition omitted
#ifdef __cplusplus
extern "C"{
#endif
#ifdef TRIALDLL_EXPORT
#define TRIALDLL_API __declspec(dllexport)
#else
#define TRIALDLL_API __declspec(dllimport)
#endif
TRIALDLL_API MyMathFuncs* __stdcall new_MyMathFuncs(double offset);
TRIALDLL_API void __stdcall del_MyMathFuncs(MyMathFuncs *myMath);
TRIALDLL_API double __stdcall MyAdd(MyMathFuncs* myMath, double a, double b);
// some other similar stuff
#ifdef __cplusplus
}
#endif
#endif
还有 triallDLL.cpp 文件:
// trialDLL.cpp
#include "trialDLL.h"
TRIALDLL_API MyMathFuncs* __stdcall new_MyMathFuncs(double offset)
{
return new MyMathFuncs(offset);
}
TRIALDLL_API void __stdcall del_MyMathFuncs(MyMathFuncs *myMath)
{
delete myMath;
}
TRIALDLL_API double __stdcall MyAdd(MyMathFuncs *myMath, double a, double b)
{
return myMath->Add(a, b);
}
// ... some other definitions
项目中有了这两个文件,我通过visual studio 2010 property manager给项目添加了一个property sheet,并在user macros中添加了TRIALDLL_EXPORT
。在所有这些之后,漂亮的 Intellisense 为 .cpp 文件中定义的每个函数都给出了错误,并提示“错误:可能未定义声明为‘dllimport’的函数”。所以看起来 Intellisense 没有找到定义的 TRIALDLL_EXPORT
。我认为如果我实际构建项目可能会有所不同,但结果提示相同的错误:“错误 C2491:'new_MyMathFuncs':不允许定义 dllimport 函数”。那么很明显,编译时仍然没有定义宏TRIALDLL_EXPORT
。
在通过 visual studio 添加宏失败后,我也尝试将代码行:#define TRIALDLL_EXPORT
放在 trialDLL.cpp 中,但它也没有帮助。我想知道这样做的正确方法是什么?我如何通知编译器定义了 micro,以便 TRIALDLL_API
计算为 dllexport
而不是 dllimport
?
另外,如果我可以成功构建.dll,是否有任何系统的方法来测试/验证.dll 的功能?
提前感谢您的帮助! (虽然我知道在 stackoverflow 上对这个问题表示赞赏是一个问题,但我觉得不这样做是不礼貌的。请原谅我因这些行造成的任何低效率。)
最佳答案
VS 属性表中的“用户宏”与预处理器宏无关。将 TRIALDLL_EXPORT
放入属性表的部分 C/C++ > Preprocessor > Preprocessor Definitions
只能在属性表中定义的“用户宏”允许您创建自己的可在 Visual Studio 属性中使用的“变量”,类似于内置的 $(TargetName)
, $(SolutionDir)
等
关于c++:不允许定义 dllimport 函数,使用 visual studio 2010 构建,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/17239506/
我有一个类,里面有一些静态成员函数。假设类 B,这个类有一个基类,它来自第三方库,比如 A。现在类 A 已经用 dllimport 和用mingw 我可以毫不费力地构建 sharedlibs 或那个类
在 C# 中,我有这个: [DllImport("user32.dll", EntryPoint = "GetDesktopWindow")] public static extern Int
我正在尝试编写一个使用 C++ 中定义的函数的 WPF 应用程序。 C++ 应用程序被编译为 DLL。 我正在做的是使用 DllImport 属性导入函数并使用它。这在我的机器上运行良好,但是当我尝试
有没有办法为一组外部函数指定相同的 DllImport 属性,类似于 extern "C"{ … } ?我不想为每个函数声明重复它:-) 最佳答案 没有。避免它的唯一方法是在 C++/CLI 中编写一
我正在尝试将短类型的参数传递给从 DLL 导入的 C++ 非托管函数。在我的 C++ DLL 代码中,我有以下函数: __declspec(dllexport)void ChangeIcon(char
我有一个第三方 c dll,我想在我的 c# 项目中使用它。我设法导入了一种读取文件头的方法。现在我想访问读取数据的方法。我认为问题在于包含字符串数组的结构,因此我尝试了各种方法,例如 StringB
如何使用反射枚举程序集中的所有 DLLImports? 最佳答案 遍历每个类中的每个方法,并检查 GetCustomAttributes(typeof(DllImportAttribute)) 是否返
在 asp.net 中,如果我使用 DLLImport 调用一个 dll,有人知道该实例的范围吗?它是在应用程序级别,所以任何后续调用都会转到 dll 的同一实例,直到应用程序结束? 我有一个 dll
我想了解 DllImport 的真正工作原理。我需要一个通俗易懂的英语解释——意思是简单的解释。 它是否与 DLL 中导出的方法静态链接,如“包含文件”指令/静态库? 还是在C#程序中到达执行点时动态
我正在尝试编写一个 C# 托管类来包装 SHGetKnownFolderPath,到目前为止它可以在 Vista 上运行,但由于在 shell32.dll 中找不到正确的函数而在 XP 上崩溃,正如预
我有一个带有 C++ 组件的 C# 应用程序。我在模块之间使用 DllImport 进行通信。该应用程序可以正常工作很多天,有时会意外崩溃。 [DllImport("recorder", Callin
这个问题在这里已经有了答案: Loading a 32-bit dll in a 64-bit process [duplicate] (1 个回答) 关闭 8 年前。 我希望我的 C# 应用程序有
我正在通过 C# 与 native 第 3 方 C++ DLL 进行交互,所提供的互操作层如下所示: C#: [DllImport("csvcomm.dll")] public static exte
我正在使用 [DLLImport] 属性访问我的 .NET 代码中的一堆 C++ 函数。现在,我通过以下方式拥有所有功能: const string DLL_Path = "path\\to\\my\
假设在 Native.dll 中有一个 c++ 方法 int NativeMethod(double, double *)。我第一次尝试从托管代码调用此方法(假设我不需要指定入口点) [DllImpo
我正在做一个P/Invoke,我正在使用下面的方法 [DllImport("Authz.dll", SetLastError = true)] public static extern BOO
static class Class { public static void methodRequiringStuffFromKernel32() { // c
我正在使用 [DllImport]属性将 native DLL 导入我的应用程序,但它加载的 DLL 不在本地 bin 文件夹中。它是从系统的其他地方加载的,但我不知道在哪里。 它适用于我的开发机器,
我刚刚在 C# 中遇到了 DllImport 的奇怪行为,我无法解释。我想知道它是如何可能的,以及我可以在哪里阅读它。案例是通过 DllImport 可以调用不真正导出表单 dll 的函数。就我而言,
我尝试使用 P/Invoke 将示例 .net 应用程序转换为 javascript JSIL . C# 代码: [DllImport("JSTestLib", EntryPoint = "Get42
我是一名优秀的程序员,十分优秀!