gpt4 book ai didi

C 另一个内存/段故障错误

转载 作者:行者123 更新时间:2023-11-30 20:47:37 25 4
gpt4 key购买 nike

[编辑:]我现在已经删除了很多代码。我已将其简化为一个更直接的问题。

传递这个变量可以吗...

char Record_Info[file_length + 1];

到另一个函数,如下所示:

listdir(tempdesc, 0, sockid, Record_Info);

它使用此 header :

int listdir(char *dirname, int lvl, int sockid, char Record_Info[])

listdir() 可以多次调用自身吗?

.

* 原始问题 *

我想知道是否有另一双眼睛可以看看这个。它正在工作,但我添加了更多代码(可能更多 sprintf ,靠近底部),现在是 Segmentation fault发生。

该程序正确地创建/发送网页,但当它从send_recordings_list()返回时崩溃。函数返回parsing_request()功能。我认为没有必要了解它如何格式化文件中的数据,但无论如何我都包含了这一点。

在大多数情况下,我使用静态变量,当我尝试free()时任何事情,它都会导致另一个 seg 错误,或 gcc lib 错误。另外我不确定在函数()之间传递变量是否可能导致问题?

还值得一提的是,一个不同的函数(此处未显示)发送了一个大约 4MB 的网页,我可以多次调用它并且它不会崩溃。我放了几个// ******在某些可能感兴趣的行?

哦,是的,我还没有做太多标准错误处理......(我稍后会做),所以假设它是真空中的球形鸡。

.

所以它从 parsing_request() 开始

转到send_recordings_list()

转到listdir() 。 (这多次调用自身)

返回send_recordings_list()

。 (此处出现段错误)

返回parsing_request()

.

我希望有些人会说“啊我看到你做了什么fool” ......'

嵌入式 Linux 2.6.27、GCC 4.2.4、32MB RAM

void parsing_request(int sockid, char *buff)
{
char *res_line=malloc(MAXLINE), path[MAXLINE], *line;
// Cut code
if (strcmp(line, "/recordings_body.htm") == 0)
{
send_recordings_list (sockid); // ****** IT GOES HERE 1st ******
return;
}
free (res_line);
return;
}




int send_recordings_list(int sockid)
{
int hnd;
int hnd2;
char tempdesc[MAX_PATH_LENGTH];


// Copy all of the data <1 MiB (Slow reading)
int file_length = lseek (hnd2, 0, SEEK_END);
char Record_Info[file_length + 1]; // ******
lseek (hnd2, 0, SEEK_SET);
read (hnd2, Record_Info, file_length);
close (hnd2);

// Cut out code

del_file_cnt = 0;
sprintf (tempdesc, "%s/Recordings", TOPPY_DIR);
listdir(tempdesc, 0, sockid, Record_Info); // ***** Major 2nd call here
return 0;
}





int listdir(char *dirname, int lvl, int sockid, char Record_Info[])
{

int i;
DIR* d_fh;
struct dirent* entry;
char longest_name[4096];
char tempdesc[4096], morespace[128];
int row_col;
char chan_name[128], alt_name[128], desc[500], category[128], rec_time[14], start_time[14], end_time[14];
char trim_file_name[128], trim_file_name2[128], trim_alt_name[128], file_links[1535];
char logo[128];
int length, u_score, dot;
char *looky_pos1, *looky_pos2;
int is_match;

struct tm tm_rec, tm_start, tm_end;
time_t tim_rec, tim_start, tim_end;

// Cut out code

return 0;
}

最佳答案

抱歉,这真是一团糟。了解如何使用 valgrind 和 gdb 等 Linux 工具。仔细检查您请求的内存是否最终被释放一次并且在使用完毕后。检查是否没有将指针传递给函数外的局部变量。检查您的字符串是否足够长以容纳预期的数据(或检查您目前不存在的错误处理的一部分)。

泰迪熊顾问是一种非常有效的调试策略:找一只泰迪熊并逐步向它解释您的问题。只有当这没有帮助时,才需要真正的人类。 [它之所以有效,是因为整理你的理解来解释它会迫使你真正思考它。]

关于C 另一个内存/段故障错误,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/14602354/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com