python中使用ctypes調用so傳參設置遇到的問題及解決方法
問題
近日在做一組聲紋聚類時,使用了另一團隊同學開發(fā)的聲紋距離算法。該算法對外提供的是一組so包,需要使用方自己去使用。在python中調用純so包一般使用ctypes類庫,用起來看起來簡單但也有不少細節(jié)容易犯錯。本次使用過程中,就遇到傳參的問題。
目標so庫中對外export的函數是大致如下的三個函數:
void* create_handler(); int extract_feature(void* hander); bool destroy(void* handler);
這三個函數使用起來倒也簡單,順序使用就可以了。但發(fā)現寫成如下形式的python代碼后,執(zhí)行會直接segment fault。
import sys
import ctypes
so = ctypes.CDLL("./lib/libbase.so")
p = so.create_handler()
feature = so.extract_feature(p)
so.destroy(p)
解決
這段代碼中p是int類型,由void*自動轉來,在ctyeps中這種轉型本身是沒問題的。segment fault發(fā)生在extract_feature函數調用中,問題應當出在參數上,回傳的handler已經不是原來的pointer了,導致訪問指針出錯。
查閱ctypes的文檔后,發(fā)現ctypes可以聲明so庫中函數的參數,返回類型。試了試,顯示聲明后問題得到了解決,證明我們的猜想是對的,確實指針發(fā)生了變化。修改后代碼如下:
import sys
import ctypes
so = ctypes.CDLL("./lib/libbase.so")
so.create_handler.restype=ctypes.c_void_p
so.extract_feature.argtypes=[ctypes.c_void_p]
so.destroy.argtypes=[ctypes.c_void_p]
p = so.create_handler()
feature = so.extract_feature(p)
so.destroy(p)
結論:
ctypes中傳遞指針類型參數需要顯示聲明c函數的參數,返回類型。
總結
以上所述是小編給大家介紹的python中使用ctypes調用so傳參設置遇到的問題及解決方法,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對腳本之家網站的支持!
如果你覺得本文對你有幫助,歡迎轉載,煩請注明出處,謝謝!
相關文章
Python文本統(tǒng)計功能之西游記用字統(tǒng)計操作示例
這篇文章主要介紹了Python文本統(tǒng)計功能之西游記用字統(tǒng)計操作,結合實例形式分析了Python文本讀取、遍歷、統(tǒng)計等相關操作技巧,需要的朋友可以參考下2018-05-05

