/*** type define class template for extern "C" ***/
typedef Mpoly<double> MpolyDouble;
// Declare functions as extern "C" for ctypes
//
// >> compiler statement (mac/linux): g++ -shared -o libPoly.so -fPIC libPoly.cpp
// >> compiler statement (windows): g++ -shared -o libPoly.dll libPoly.cpp
//
extern "C" {
/*** libPoly Constructor/Destructor Routines ***/
MpolyDouble* Poly_new(int size, int dim) { return new(nothrow) MpolyDouble(size,dim); }
void Poly_del(MpolyDouble* foo) { delete foo; }
/*** libPoly Miscellaneous Routines ***/
void PolyPrint(MpolyDouble* foo) {
// print out address of object pointer
std::cout << "address of foo: " << foo << std::endl;
// call MpolyDouble.print() method
foo->print();
}
}
#*** import python libraries ***#
from ctypes import *
from numpy.ctypeslib import ndpointer
import numpy as np
import weakref
#**************************************#
#*** load the libPoly shared object ***#
#**************************************#
lib = CDLL('./libPoly.so') #! for Mac/Linux
#lib = CDLL('./libPoly.dll') #! for Windows
#********************************************************#
#*** set the argument types for each member attribute ***#
#********************************************************#
## Poly_new
lib.Poly_new.argtypes = [c_int, c_int]
lib.Poly_new.restype = c_void_p
## Poly_del
lib.Poly_del.argtypes = [c_void_p] #<---edit
lib.Poly_del.restype = None
## PolyPrint
lib.PolyPrint.argtypes = [c_void_p] #<---edit
lib.PolyPrint.restype = None
#********************************************************#
#*** define a python class Poly ***#
#********************************************************#
class Poly(object):
# GHV Instantiation Routine:
def __init__(self,size=1,dim=2):
# ensure that the input args are of correct type
size = int(size)
dim = int(dim)
# call the C/C++ function
self.obj = lib.Poly_new(size,dim)
def __del__(self):
lib.Poly_del(self.obj)
self._obj = None
# GHV Print Routine:
def Print(self):
print 'address of self.obj',hex(id(self.obj))
# call the C/C++ function
lib.PolyPrint(self.obj)
$ python
from PolyWrapper import *
P = Poly()
P.Print()
address of self.obj 0x10038fc08
address of foo: 0x1804810
Segmentation fault: 11
Process: python2.7 [3359]
Path: /Users/USER/*/python2.7
Identifier: python2.7
Code Type: X86-64 (Native) Parent Process: bash [3341] Responsible: Terminal [235]
Date/Time: 2016-02-16 12:48:22.220 -0500 OS Version: Mac OS X 10.11.3 (15D21)
Exception Type: EXC_BAD_ACCESS (SIGSEGV)
Exception Codes: KERN_INVALID_ADDRESS at 0x0000000001804810
为什么这在我的 Windows 平台上有效,但在其他任何地方都无效?
我在这两个平台上都没有遇到任何编译器错误。此外,我使用 typedef 来通过函数模板并没有给我在其他类似项目中带来问题。
请注意,从 .cpp 文件中打印的“foo 的地址”与在控制台“异常代码”中引发警报的地址相同。 python 在创建新对象时是否收到正确的地址?如何判断,这怎么可能?
报告了类似的问题 here ,但我不认为这是这里的问题,因为我已经明确设置了 restype、argtype 和 argtypes。
g++ --version -- Apple LLVM 版本 7.0.2 (clang-700.1.81) (OS X) 和 g++ (GCC ) 2.9.3 (Windows CygWIN)。如果您认为编译器可能是问题所在,请注意我使用了同一个编译器来生成 lib.so 和 lib.dll。从 Spyder (Python (x,y)) 执行有效;从 CygWIN shell 执行 lib.so 给出 SIG11。
最佳答案
这是我的最终解决方案。我在 C++ 方面没有做任何重大更改——只有 Python ctypes 绑定(bind)。我还添加了一些逻辑来处理动态库(共享对象)的导入,这不是通用的。它适用于我的两个工作站和我必须协作的其他几个工作站,但 Python2.7 的 32 位版本除外。
__del__ 例程可以轻松链接到 c++ 对象的析构函数例程,这在传递对象时必不可少来回作为指针。lib 作为全局调用,直到调用 __del__ 才给我带来问题;然而,当 lib.Poly_del(self.obj) 被调用时,lib 不再被定义。#*************************************#
#*** import python libraries ***#
#*************************************#
from ctypes import *
from numpy.ctypeslib import ndpointer
import numpy as np
import weakref
import platform
#**************************************#
#*** load the libPoly shared object ***#
#**************************************#
print.system()
if (platform.system() == "Windows" or platform.system() == "CYGWIN-6.1"):
lib = CDLL('./libPoly.dll')
else:
lib = CDLL('./libPoly.so')
#********************************************************#
#*** set the argument types for each member attribute ***#
#********************************************************#
## Poly_new
lib.Poly_new.argtypes = [c_int, c_int]
lib.Poly_new.restype = c_void_p
## Poly_del
lib.Poly_del.argtypes = [c_void_p]
lib.Poly_del.restype = None
## PolyPrint
lib.PolyPrint.argtypes = [c_void_p]
lib.PolyPrint.restype = None
#********************************************************#
#*** define a python class Poly ***#
#********************************************************#
class Poly(object):
_obj = None
_local = lib
# Poly Instantiation Routine:
def __init__(self,size=1,dim=1):
# ensure that the input args are of correct type
size = int(size)
dim = int(dim)
# call the C/C++ function
self._obj = c_void_p(self._lib.Poly_new(size,dim))
# Poly Destructor Routine:
def __del__(self):
if (self._obj is not None):
self._lib.Poly_del(self._obj)
del self._obj
# Poly Print Routine:
def Print(self):
# call the C/C++ function
self._lib.PolyPrint(self._obj)
关于python - ctypes:使用 lib.so(在 Mac 上)时指针地址修改,但在使用 lib.dll(在 Windows 上)时不修改,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/35441612/
我正在学习如何使用Nokogiri,根据这段代码我遇到了一些问题:require'rubygems'require'mechanize'post_agent=WWW::Mechanize.newpost_page=post_agent.get('http://www.vbulletin.org/forum/showthread.php?t=230708')puts"\nabsolutepathwithtbodygivesnil"putspost_page.parser.xpath('/html/body/div/div/div/div/div/table/tbody/tr/td/div
我有一个Ruby程序,它使用rubyzip压缩XML文件的目录树。gem。我的问题是文件开始变得很重,我想提高压缩级别,因为压缩时间不是问题。我在rubyzipdocumentation中找不到一种为创建的ZIP文件指定压缩级别的方法。有人知道如何更改此设置吗?是否有另一个允许指定压缩级别的Ruby库? 最佳答案 这是我通过查看rubyzip内部创建的代码。level=Zlib::BEST_COMPRESSIONZip::ZipOutputStream.open(zip_file)do|zip|Dir.glob("**/*")d
类classAprivatedeffooputs:fooendpublicdefbarputs:barendprivatedefzimputs:zimendprotecteddefdibputs:dibendendA的实例a=A.new测试a.foorescueputs:faila.barrescueputs:faila.zimrescueputs:faila.dibrescueputs:faila.gazrescueputs:fail测试输出failbarfailfailfail.发送测试[:foo,:bar,:zim,:dib,:gaz].each{|m|a.send(m)resc
很好奇,就使用rubyonrails自动化单元测试而言,你们正在做什么?您是否创建了一个脚本来在cron中运行rake作业并将结果邮寄给您?git中的预提交Hook?只是手动调用?我完全理解测试,但想知道在错误发生之前捕获错误的最佳实践是什么。让我们理所当然地认为测试本身是完美无缺的,并且可以正常工作。下一步是什么以确保他们在正确的时间将可能有害的结果传达给您? 最佳答案 不确定您到底想听什么,但是有几个级别的自动代码库控制:在处理某项功能时,您可以使用类似autotest的内容获得关于哪些有效,哪些无效的即时反馈。要确保您的提
假设我做了一个模块如下:m=Module.newdoclassCendend三个问题:除了对m的引用之外,还有什么方法可以访问C和m中的其他内容?我可以在创建匿名模块后为其命名吗(就像我输入“module...”一样)?如何在使用完匿名模块后将其删除,使其定义的常量不再存在? 最佳答案 三个答案:是的,使用ObjectSpace.此代码使c引用你的类(class)C不引用m:c=nilObjectSpace.each_object{|obj|c=objif(Class===objandobj.name=~/::C$/)}当然这取决于
我正在尝试使用ruby和Savon来使用网络服务。测试服务为http://www.webservicex.net/WS/WSDetails.aspx?WSID=9&CATID=2require'rubygems'require'savon'client=Savon::Client.new"http://www.webservicex.net/stockquote.asmx?WSDL"client.get_quotedo|soap|soap.body={:symbol=>"AAPL"}end返回SOAP异常。检查soap信封,在我看来soap请求没有正确的命名空间。任何人都可以建议我
我需要在客户计算机上运行Ruby应用程序。通常需要几天才能完成(复制大备份文件)。问题是如果启用sleep,它会中断应用程序。否则,计算机将持续运行数周,直到我下次访问为止。有什么方法可以防止执行期间休眠并让Windows在执行后休眠吗?欢迎任何疯狂的想法;-) 最佳答案 Here建议使用SetThreadExecutionStateWinAPI函数,使应用程序能够通知系统它正在使用中,从而防止系统在应用程序运行时进入休眠状态或关闭显示。像这样的东西:require'Win32API'ES_AWAYMODE_REQUIRED=0x0
关闭。这个问题是opinion-based.它目前不接受答案。想要改进这个问题?更新问题,以便editingthispost可以用事实和引用来回答它.关闭4年前。Improvethisquestion我想在固定时间创建一系列低音和高音调的哔哔声。例如:在150毫秒时发出高音调的蜂鸣声在151毫秒时发出低音调的蜂鸣声200毫秒时发出低音调的蜂鸣声250毫秒的高音调蜂鸣声有没有办法在Ruby或Python中做到这一点?我真的不在乎输出编码是什么(.wav、.mp3、.ogg等等),但我确实想创建一个输出文件。
我在我的项目目录中完成了compasscreate.和compassinitrails。几个问题:我已将我的.sass文件放在public/stylesheets中。这是放置它们的正确位置吗?当我运行compasswatch时,它不会自动编译这些.sass文件。我必须手动指定文件:compasswatchpublic/stylesheets/myfile.sass等。如何让它自动运行?文件ie.css、print.css和screen.css已放在stylesheets/compiled。如何在编译后不让它们重新出现的情况下删除它们?我自己编译的.sass文件编译成compiled/t
我想将html转换为纯文本。不过,我不想只删除标签,我想智能地保留尽可能多的格式。为插入换行符标签,检测段落并格式化它们等。输入非常简单,通常是格式良好的html(不是整个文档,只是一堆内容,通常没有anchor或图像)。我可以将几个正则表达式放在一起,让我达到80%,但我认为可能有一些现有的解决方案更智能。 最佳答案 首先,不要尝试为此使用正则表达式。很有可能你会想出一个脆弱/脆弱的解决方案,它会随着HTML的变化而崩溃,或者很难管理和维护。您可以使用Nokogiri快速解析HTML并提取文本:require'nokogiri'h