python27.dll放入后无效_缺少Python27_d.lib的解决方法

http://blog.csdn.net/junparadox/article/details/52704287

http://lib.csdn.net/base/python

简介

最近在调用caffe的Python接口训练网络,需要进到caffe代码中调试,编译时需要用Python27_d.lib、Python27_d.dll。但是一般我们下载的都是release版的。怎么办?自己编译一个debug版本当然可以,但是很麻烦啊。很多网友解决方法是把Python27.lib、Python27.dll拷贝为Python27_d.lib、Python27_d.dll。

不过拷贝后可能出现一些错误。这里说一下我的解决方法。

在vs下引用伪造的”debug版本“可能出现链接问题

引用自己伪造的debug版Python27_d.lib、Python27_d.dll可能出现的问题:

extmodule.obj : error LNK2019: unresolved external symbol __imp___Py_Dealloc referenced in function_PySwigObject_format

extmodule.obj: error LNK2019: unresolved external symbol __imp___Py_NegativeRefcount referenced in function_PySwigObject_format

extmodule.obj: error LNK2001: unresolved external symbol __imp___Py_RefTotal

extmodule.obj : error LNK2019: unresolved external symbol __imp___PyObject_DebugFree referenced in function_PySwigObject_dealloc

extmodule.obj: error LNK2019: unresolved external symbol __imp___PyObject_DebugMalloc referenced in function_PySwigObject_New

extmodule.obj: error LNK2019: unresolved external symbol __imp__Py_InitModule4TraceRefs referenced in function_init_extmodule

主要是因为 Py_DEBUG/Py_TRACE_REFS 引起, 修改 Python\include 下的 pyconfig.h, object.h

解决方法

修改 pyconfig.h

#ifdef _DEBUG

# define Py_DEBUG

#endif

#ifdef _DEBUG

//# define Py_DEBUG

#endif

修改

# ifdef _DEBUG

# pragma comment(lib,"python27_d.lib")

# else

# pragma comment(lib,"python27.lib")

# endif /* _DEBUG */

# ifdef _DEBUG

# pragma comment(lib,"python27.lib")

# else

# pragma comment(lib,"python27.lib")

# endif /* _DEBUG */

修改object.h

#if defined(Py_DEBUG) && !defined(Py_TRACE_REFS)

#define Py_TRACE_REFS

#endif

为:

#if defined(Py_DEBUG) && !defined(Py_TRACE_REFS)

// #define Py_TRACE_REFS

#endif

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
这段代码是用来加载一个名为 Octree_python_lib.so 的动态链接库,并定义了一些函数接口和函数参数的类型。下面是对每个定义的函数接口和参数类型的解释: - c_double_p: 定义了一个指向 double 类型的指针。 - c_uint16_p: 定义了一个指向 uint16 类型的指针。 - lib = cdll.LoadLibrary(os.path.dirname(os.path.abspath(__file__))+'/Octree_python_lib.so'): 加载 Octree_python_lib.so 动态链接库,并将其赋值给 lib 变量。 - lib.new_vector: 函数接口,返回类型为 c_void_p,无参数。 - lib.delete_vector: 函数接口,返回类型为 None,参数为 c_void_p。 - lib.vector_size: 函数接口,返回类型为 c_int,参数为 c_void_p。 - lib.vector_get: 函数接口,返回类型为 c_void_p,参数为 c_void_p 和 c_int。 - lib.vector_push_back: 函数接口,返回类型为 None,参数为 c_void_p 和 c_int。 - lib.genOctreeInterface: 函数接口,返回类型为 c_void_p,参数为 c_void_p、c_double_p 和 c_int。 - lib.Nodes_get: 函数接口,返回类型为指向 Node 类型的指针 (POINTER(Node)),参数为 c_void_p 和 c_int。 - lib.Nodes_size: 函数接口,返回类型为 c_int,参数为 c_void_p。 - lib.int_size: 函数接口,返回类型为 c_int,参数为 c_void_p。 - lib.int_get: 函数接口,返回类型为 c_int,参数为 c_void_p 和 c_int。 这些函数接口的具体功能需要根据实际的动态链接库 Octree_python_lib.so 来确定。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值