gpt4 book ai didi

c - C 中数组的奇怪行为

转载 作者:太空宇宙 更新时间:2023-11-04 07:18:52 25 4
gpt4 key购买 nike

抱歉我的英语不好。我是 Linux 系统编程的新手,也是 C 编程的新手。
目前我正在尝试取消链接文件,为此,我必须将文件路径存储在某处。我为每个文件使用 1024 个元素的字符数组。如果我减小数组的大小,文件描述符就会变得一团糟。听起来很愚蠢,但确实如此。
下面是一些代码:

char path[1024], path2[1024];
const char *file_name = "myfile_1", *file_name2 = "myfile_2",*working_directory="/home/Alexander/lab01/";
strcpy(path, working_directory);
strcat(path, file_name);
strcpy(path2, working_directory);
strcat(path2, file_name);

然后我打开一些文件,读\写等等。如果路径和路径 2 的长度为 1024 字节,则一切顺利。. all_ok
但是当我将 path 和 path2 的大小减小到 512 或 256 时,内存和其他文件描述符发生了一些奇怪的事情......
all_crap
我不明白发生了什么,请帮助。

代码,我在哪里读取文件:

fdesc_input = open("/dev/urandom",O_RDONLY);
if (fdesc_input < 0 ) {
perror("Error opening /dev/urandom: ");
}
fdesc_output = open(path, O_RDWR|O_CREAT|O_TRUNC, 0777);
if (fdesc_output < 0 ) {
perror("Error opening my file: ");
}
buffer = (unsigned char*) malloc(buffer_size); // make 1kb buffer

desired_filesize = 1024*10; // 10 kilobytes

int curr_size = 0;
while (curr_size < desired_filesize) {

//AFTER NEXT LINE STRANGE HAPPENS
ssize_t result = read(fdesc_input, &buffer, buffer_size);
if (result < 0) {
perror ("Error reading /dev/urandom: ");
exit(1);
}
curr_size += result;
write(fdesc_output, &buffer, buffer_size);
}

最佳答案

您正在将 &buffer 传递给 read,但是,buffer 本身是一个指针。您传递 buffer 的地址,这是一个局部变量。结果,read 从这个局部变量开始将数据读入内存,从而覆盖其他局部变量。

传递 buffer 而不是 &buffer 应该没问题。

关于c - C 中数组的奇怪行为,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/22672938/

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