0

将链表从 C 代码传递到 C++ 是否存在已知问题?我有一个 Qt 对话,我要添加到旧版 C 代码中。Qt 类(在 C++ 库中)调用 C 库函数,该函数返回指向链表的静态指针。该列表是在 C 库中创建的。例如:

C代码:

typedef my_struct_s my_struct_t, *my_struct_p;
struct { 
  int some_data;
  double some_more_data;
  my_struct_p next;
} my_struct_s;
void create_list()
{
  my_struct_p next;
  SP_head = (my_struct_p) calloc(1, sizeof(my_struct_t));
  next = (my_struct_p) calloc(1, sizeof(my_struct_t));
  SP_head->some_data = 1;
  next->some_data = 2;
  SP_head->next = next;
}
static my_struct_p SP_head=(my_struct_p)0;

extern my_struct_p get_list() {
  if(!SP_head)
     create_list();
  return SP_head;
}

C++ 代码:

myclass::do_something()
{
    my_struct_p list = get_list();
    for(my_struct_p ptr = list; ptr; ptr = ptr->next)
    {
         std::cout << ptr->value;
    }
}

SP_head是有效的,并且在我获得它时包含一堆条目。在我的调试器中,我可以看到下一个条目已填充并且在从函数返回时有效get_list()

当我尝试分配ptr=ptr->next时,无论是在 for 循环内还是在 while 循环结束时或通过临时指针,值都是null. IE

temp_ptr = ptr->next;  
// temp_ptr is null
// but I can see ptr->next looks ok in a debugger 

我现在更改了代码,将列表的每个元素复制到一个数组中并返回该数组,它工作正常。这是否与堆栈有关,并且与 C 和 C++ 不兼容,或者只是表明我在其他地方有内存问题?

4

1 回答 1

0

当然,C++ 已经准备好处理 C,那么你应该假设在使用正确的接口时没有不兼容。

毕竟,有很多软件是用 C 实现并从 C++ 接口的。例如,我正在使用来自 Qt 的SWI-Prolog - 用 C 实现。

但是为了编译你的代码,我不得不做一些改变:这里是底线

文件 my_list.h

#ifdef __cplusplus 
extern "C" {
#endif

struct my_struct_s {
  int some_data;
  double some_more_data;
  struct my_struct_s *next;
};
typedef struct my_struct_s my_struct_t, *my_struct_p;

void create_list();
extern my_struct_p get_list();

#ifdef __cplusplus 
}
#endif

文件 my_list.c

#include "my_list.h"
#include <stdio.h>
#include <stdlib.h>

static my_struct_p SP_head=(my_struct_p)0;

void create_list()
{
  my_struct_p next;
  SP_head = (my_struct_p) calloc(1, sizeof(my_struct_t));
  next = (my_struct_p) calloc(1, sizeof(my_struct_t));
  SP_head->some_data = 1;
  next->some_data = 2;
  SP_head->next = next;
}

my_struct_p get_list() { return SP_head; }

文件 main.cpp

#include "my_list.h"
#include <iostream>

class myclass {
public:
    void do_something()
    {
        my_struct_p list = get_list();
        for(my_struct_p ptr = list; ptr; ptr = ptr->next)
         std::cout << ptr->some_data << std::endl;
    }
};

int main() {
    create_list();
    myclass c;
    c.do_something();
}

现在编译并运行:

g++ my_list.c main.cpp
./a.out
1
2
于 2013-04-29T10:29:59.130 回答