我正在尝试读取文件并使用内容更新缓冲区。我不希望readToBuffer
返回char *
,因为我需要知道缓冲区大小供以后使用。当我尝试从main
打印buffer
时,它似乎是空的。
#include <stdlib.h>
#include <stdio.h>
long readToBuffer(char* path, char* buffer) {
FILE* handle = fopen(path,"rb");
fseek(handle,0L,SEEK_END);
long bufferSize = ftell(handle);
rewind(handle);
buffer = malloc(bufferSize*sizeof(char));
fread(buffer, sizeof(char), bufferSize, handle);
fclose(handle);
printf("%s",buffer);
return bufferSize;
}
int main(int argc, char* argv[]) {
char* path = argv[1];
char* buffer;
long bufferSize = readToBuffer(path, buffer);
printf("%ldn",bufferSize);
printf("%s",buffer);
return 0;
}
给定helloWorld.txt
输入文件,为什么输出如下:
hello world
12
(null)$
为什么我不能读取在过程readToBuffer
中更新的缓冲区?
当您在readToBuffer()
中分配给buffer
时,这对main()
中的buffer
变量没有影响。在C中,参数是按值传递的,而不是按引用传递的。如果你想修改调用者的变量,你需要传递一个指向变量的指针。
还请注意,fread()
没有向输入添加空终止符,因此以%s
格式打印缓冲区是无效的。您需要在缓冲区中分配一个额外的字节,并将0
放在那里。
#include <stdlib.h>
#include <stdio.h>
long readToBuffer(char* path, char** buffer) {
FILE* handle = fopen(path,"rb");
fseek(handle,0L,SEEK_END);
long bufferSize = ftell(handle)+1;
rewind(handle);
*buffer = malloc(bufferSize*sizeof(char));
fread(*buffer, sizeof(char), bufferSize-1, handle);
buffer[buffersize-1] = 0;
fclose(handle);
printf("%s", *buffer);
return bufferSize;
}
int main(int argc, char* argv[]) {
char* path = argv[1];
char* buffer;
long bufferSize = readToBuffer(path, &buffer);
printf("%ldn",bufferSize);
printf("%s",buffer);
return 0;
}
有关指针的更多信息,请参见理解指针的障碍是什么以及如何克服它们?
因为您没有更改缓冲区指向的数据,所以您试图编辑指针指向的内容。当你的函数退出时,缓冲区的地址是不变的,并且内存当前是泄漏的。
要正确地做到这一点,您需要将指针传递给指针并更改函数签名。
在这种情况下传递&buffer
,修改签名使用**char buffer
和buffer[0]
或*buffer
的赋值,如*buffer = malloc ....