大佬教程收集整理的这篇文章主要介绍了加载 DLL 会导致错误 193,即使它可以在 ctypes 和 JNA 中加载,大佬教程大佬觉得挺不错的,现在分享给大家,也给大家做个参考。
我正在将 Python 程序移植到 C++(在 windows 上)。由于所述代码依赖于 DLL,因此我需要加载 DLL。但是,当我调用 LoadlibraryA
指定我的 DLL 的完整路径(带反斜杠)时,它无法加载并且 GetLastError
返回 193。
这是一个示例程序来演示:
#include <iostream>
#include <windows.h>
using std::cout,std::endl;
int main(int argc,char* argv[]) {
if (argc != 2) {
cout << "You only need to specify one argument,path to DLl." << endl;
exit(2);
}
HMODulE dll = LoadlibraryA(argv[1]);
if (dll == NulL) {
cout << "DLL at " << argv[1] << " Could not be loaded." << endl;
}
FREELIbrary(dll);
return 0;
}
我指定了我的 DLL 的完整路径(如“C:\path\to\somewhere\test.dll”)作为第一个命令行参数,但它失败了。为什么它不会加载,即使它在 JNA 和 ctypes 等外部函数接口中加载?
编辑 1:DLL 是 64 位。
检查您是在编译 64 位还是 32 位代码的一种简单方法是使用以下代码 (C++17):
#include <iostream>
using std::cout,std::endl;
int main(int argc,char* argv[]) {
cout << "Your compiler compiled for " << sizeof(void*) * 8 << "-bit systems." << endl;
}
上面的代码通过检查指针的大小来工作。 32 位应用程序使用 4 字节指针,而 64 位应用程序使用 8 字节指针。
编辑:您可以使用 dumpbin
(在 Visual studio 中可用)进行检查。见this answer。您还可以使用预处理器宏:
#include <iostream>
using std::cout,char* argv[]) {
#ifdef __MINGW64__
cout << "MinGW-w64" << endl;
#endif
}
如果它是由 MinGW-w64 编译的,它只会打印 "MinGW-w64"
。这些方法比我最初使用的指针方法可靠得多。
就我而言,我使用的是 @H_859_30@minGW 而不是 @H_859_30@minGW-w64。因此,生成的 .exe
是一个 32 位应用程序,它与 64 位 .dll
发生冲突,从而导致错误 193。
以上是大佬教程为你收集整理的加载 DLL 会导致错误 193,即使它可以在 ctypes 和 JNA 中加载全部内容,希望文章能够帮你解决加载 DLL 会导致错误 193,即使它可以在 ctypes 和 JNA 中加载所遇到的程序开发问题。
如果觉得大佬教程网站内容还不错,欢迎将大佬教程推荐给程序员好友。
本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。