C 如何调试Lua扩展随机分段故障
我目前正在尝试编写一个小的Lua扩展来处理矩阵乘法。 工作的矩阵部分相当简单,我不费吹灰之力就把它展示给了Lua。但现在我面临一个奇怪的问题,我的Lua脚本随机地出现了不同类型的错误 这里是一个概述C 如何调试Lua扩展随机分段故障,c,memory-leaks,lua,lua-api,C,Memory Leaks,Lua,Lua Api,我目前正在尝试编写一个小的Lua扩展来处理矩阵乘法。 工作的矩阵部分相当简单,我不费吹灰之力就把它展示给了Lua。但现在我面临一个奇怪的问题,我的Lua脚本随机地出现了不同类型的错误 这里是一个概述 (lldb) run Process 44058 launched: '/usr/local/bin/luad' (x86_64) Process 44058 stopped * thread #1, queue = 'com.apple.main-thread', stop reason = EX
(lldb) run
Process 44058 launched: '/usr/local/bin/luad' (x86_64)
Process 44058 stopped
* thread #1, queue = 'com.apple.main-thread', stop reason = EXC_BAD_ACCESS (code=1, address=0x1f8)
frame #0: 0x000000010001cd19 luad`luaH_getn(t=0x00000001002024f0) at ltable.c:643
640 */
641 int luaH_getn (Table *t) {
642 unsigned int j = t->sizearray;
-> 643 if (j > 0 && ttisnil(&t->array[j - 1])) {
644 /* there is a boundary in the array part: (binary) search for it */
645 unsigned int i = 0;
646 while (j - i > 1) {
Target 0: (luad) stopped.
(lldb) run
Process 44062 launched: '/usr/local/bin/luad' (x86_64)
Process 44062 stopped
* thread #1, queue = 'com.apple.main-thread', stop reason = EXC_BAD_ACCESS (code=1, address=0x100503bbe)
frame #0: 0x00007fff513e8e87 libsystem_malloc.dylib`tiny_free_list_add_ptr + 108
libsystem_malloc.dylib`tiny_free_list_add_ptr:
-> 0x7fff513e8e87 <+108>: movw %r11w, -0x2(%rdx,%rax)
0x7fff513e8e8d <+114>: movw %r11w, 0x10(%rdx)
0x7fff513e8e92 <+119>: jmp 0x7fff513e8ea0 ; <+133>
0x7fff513e8e94 <+121>: testw %r11w, %r11w
Target 0: (luad) stopped.(lldb) run
Process 45023 launched: '/usr/local/bin/luad' (x86_64)
Process 45023 stopped
* thread #1, queue = 'com.apple.main-thread', stop reason = EXC_BAD_ACCESS (code=EXC_I386_GPFLT)
frame #0: 0x000000010000e79e luad`sweeplist(L=0x0000000101000008, p=0x00000001003059a0, count=51) at lgc.c:740
737 int white = luaC_white(g); /* current white */
738 while (*p != NULL && count-- > 0) {
739 GCObject *curr = *p;
-> 740 int marked = curr->marked;
741 if (isdeadm(ow, marked)) { /* is 'curr' dead? */
742 *p = curr->next; /* remove 'curr' from list */
743 freeobj(L, curr); /* erase 'curr' */
Target 0: (luad) stopped.
(lldb)运行
启动进程44058:“/usr/local/bin/luad”(x86_64)
进程44058已停止
*线程#1,队列='com.apple.main thread',停止原因=EXC#U BAD#U访问(代码=1,地址=0x1f8)
帧#0:0x000000010001cd19 luad`luaH_getn(t=0x000000010024F0)位于ltable.c:643
640 */
641国际卢阿图(表*t){
642无符号整数j=t->sizearray;
->643 if(j>0&&ttisnil(&t->数组[j-1])){
644/*数组部分中有一个边界:(二进制)搜索它*/
645无符号整数i=0;
646 while(j-i>1){
目标0:(luad)已停止。
(lldb)运行
启动进程44062:“/usr/local/bin/luad”(x86_64)
进程44062已停止
*线程#1,队列='com.apple.main thread',停止原因=EXC#U BAD#U访问(代码=1,地址=0x100503bbe)
帧0:0x00007fff513e8e87 libsystem_malloc.dylib`tiny_free_list_add_ptr+108
libsystem_malloc.dylib`tiny_free_list_add_ptr:
->0x7fff513e8e87:movw%r11w,-0x2(%rdx,%rax)
0x7fff513e8e8d:movw%r11w,0x10(%rdx)
0x7fff513e8e92:jmp 0x7fff513e8ea0;
0x7fff513e8e94:testw%r11w,%r11w
目标0:(luad)已停止。(lldb)运行
启动进程45023:“/usr/local/bin/luad”(x86_64)
进程45023已停止
*线程#1,队列='com.apple.main thread',停止原因=EXC_BAD_访问(代码=EXC_I386_GPFLT)
lgc处的帧0:0x000000010000e79e luad`扫描列表(L=0x0000000101000008,p=0x00000001003059a0,计数=51)。c:740
737内部白色=luaC_白色(g);/*当前白色*/
738 while(*p!=NULL&&count-->0){
739 GCObject*curr=*p;
->740 int marked=当前->已标记;
741如果(isdeadm(ow,标记)){/*是“curr”死了吗*/
742*p=curr->next;/*从列表中删除“curr”*/
743 freeobj(L,curr);/*删除“curr”*/
目标0:(luad)已停止。
它似乎与内存管理和垃圾收集有关,但我已经照本宣科了。那么我如何才能找到我的错误呢?因为随机性,我似乎无法构建一个最小的代码。除了阅读所有Lua源代码之外,我不知道我能做些什么
如果你很好奇,你可以看看我的库,它有少量的代码要读
欢迎任何形式的帮助。无关。但是您的
矩阵\u是有效的
正在检查相同的条件两次。感谢您发现这个输入错误,我刚刚和您一起得到了相同的错误。您解决了这个错误吗?您可以查看我的GitHub,看看我仍然没有任何线索。我改变了使用矩阵的方式。在add返回新矩阵之前,现在它要求一个对象来写结果。然后在脚本的开头没有更多的矩阵创建。我讨厌这个解决方案,因为我的Lua代码现在很糟糕,不可读。但是如果你找到一种方法,我会很高兴有一些方向。