0

我正在尝试包装一个我用 c 编写的小型库,我想我正在努力让它工作。该库围绕它进行了一些非常可靠的测试,我已经通过 valgrind 运行它以消除任何内存泄漏和明显的问题。它本身就非常可靠。

但是,当我尝试使用 ruby​​ 包装它时,它会出现段错误。这是一个包装库的示例项目。当该项目中的测试运行时,对库的调用会出现段错误。运行它会导致核心中止,我已将其加载到 gdb 中以进行调试,但我不确定出了什么问题。核心转储说问题出在这条线上,但我不知道是什么原因造成的,因为给出的信息非常稀疏,如果我在 c 中运行测试,代码运行良好。

核心转储所说的行是 segfaulting

assert( yypParser->yytos!=0 );

您可以通过从根目录运行来重现它,rake该根目录会启动最终生成由测试加载的共享对象的进程。我希望在 c 方面有更多经验的人可以看看并有可能为我指明正确的方向。

如果需要更多信息,请告诉我。

来自核心转储的片段

#0  0x00007f150caa2c37 in __GI_raise (sig=sig@entry=6) at ../nptl/sysdeps/unix/sysv/linux/raise.c:56
#1  0x00007f150caa6028 in __GI_abort () at abort.c:89
#2  0x00007f150dba8d8d in die () at error.c:407
#3  rb_bug_context (ctx=ctx@entry=0x7f150f3b1b80, fmt=fmt@entry=0x7f150dbe2f6a "Segmentation fault at %p") at error.c:437
#4  0x00007f150daa45ce in sigsegv (sig=<optimized out>, info=0x7f150f3b1cb0, ctx=0x7f150f3b1b80) at signal.c:890
#5  <signal handler called>
#6  0x00007f150b96b02b in Parse (yyp=0xf9925e0, yymajor=20, yyminor=..., state=0x7ffe17b6a3a0) at parser.c:1919
#7  0x00007f150b96b8e8 in numerize (data=data@entry=0x7f150b96c1aa "one", state=state@entry=0x7ffe17b6a3a0) at ../../../../ext/example_project/fast_numerizer/fast_numerizer.c:102
#8  0x00007f150b960e0b in example_project_c_code_function () at ../../../../ext/example_project/./example_project.c:11
4

0 回答 0