私はCythonのドキュメントを歩き、それぞれのサンプルアプリケーションを構築しています。私はCライブラリの使用法でちょっと立ち往生しています。 .soファイルを正常にビルドし、それをpythonファイル(test.py)にインポートしようとすると、次のエラーがスローされます。Cythonで生成された.soファイルをインポートするとき、このImportErrorの意味は何ですか?
$ python3.2 test.py
Traceback (most recent call last):
File "test.py", line 12, in <module>
from queue import Queue
ImportError: dlopen(/Users/jeremy/Development/labs/python/cython_lib_wrapper/queue.so, 2): Symbol not found: _queue_free
Referenced from: /Users/jeremy/Development/labs/python/cython_lib_wrapper/queue.so
Expected in: flat namespace
in /Users/jeremy/Development/labs/python/cython_lib_wrapper/queue.so
.soファイルは、test.pyファイルのすぐ隣にあります。だから、見つけられるかのように見えます。 これは、Cythonの最新バージョンを、OSX 10.6でPython 3.2で実行しています。
洞察?
編集 - コマンドと出力を構築追加
$ python3.2 setup.py build_ext --inplace
running build_ext
cythoning queue.pyx to queue.c
building 'queue' extension
gcc-4.2 -fno-strict-aliasing -fno-common -dynamic -DNDEBUG -g -O3 -isysroot /Developer/SDKs/MacOSX10.6.sdk -arch i386 -arch x86_64 -isysroot /Developer/SDKs/MacOSX10.6.sdk -I/Library/Frameworks/Python.framework/Versions/3.2/include/python3.2m -c queue.c -o build/temp.macosx-10.6-intel-3.2/queue.o
queue.c: In function ‘__pyx_f_5queue_5Queue_append’:
queue.c:627: warning: cast to pointer from integer of different size
queue.c: In function ‘__pyx_f_5queue_5Queue_extend’:
queue.c:740: warning: cast to pointer from integer of different size
queue.c: In function ‘__pyx_f_5queue_5Queue_peek’:
queue.c:813: warning: cast from pointer to integer of different size
queue.c: In function ‘__pyx_f_5queue_5Queue_pop’:
queue.c:965: warning: cast from pointer to integer of different size
gcc-4.2 -bundle -undefined dynamic_lookup -arch i386 -arch x86_64 -isysroot /Developer/SDKs/MacOSX10.6.sdk -isysroot /Developer/SDKs/MacOSX10.6.sdk -g build/temp.macosx-10.6-intel-3.2/queue.o -o
編集2 - cmdはコメントで要求された "コマンドotool" 追加
queue.so:
/usr/lib/libSystem.B.dylib (compatibility version 1.0.0, current version 125.2.0)
編集3 - 追加 "nm" で出力
U ___stack_chk_fail
U ___stack_chk_guard
U _queue_free
U _queue_is_empty
U _queue_new
U _queue_peek_head
U _queue_pop_head
U _queue_push_tail
U dyld_stub_binder
の
grepのCMDの出力この:
(undefined) external _queue_free (dynamically looked up)
これはリンクの問題のようです。再ビルドしてビルド出力とここにビルドするために使用したコマンドの両方を含めることができますか? – stderr
@Mike Stederこれを見ていただきありがとうございます。ビルドコマンドと出力を追加しました。 – JeremyFromEarth
さて、幸運を再現していないので、もう少しデバッグを試してみましょう。 'nm queue.so'を試して、_queue_freeの隣に表示されているものを見てください。また 'otool -L queue.so'を使ってDYLD_LIBRARY_PATH(' echo $ DYLD_LIBRARY_PATH')を見てください。 – stderr