我正在尝试读取文件并使用内容更新缓冲区。我不希望readToBuffer
返回char *
因为我需要知道缓冲区大小以供以后使用。当我尝试从buffer
打印main
时,它似乎是空的。
#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("%ld\n",bufferSize);
printf("%s",buffer);
return 0;
}
给定helloWorld.txt
输入文件,为什么输出如下:
hello world
12
(null)$
为什么我不能读取过程readToBuffer
中更新的缓冲区?
答案 0 :(得分:1)
当您分配到buffer
中的readToBuffer()
时,这对buffer
中的变量main()
没有影响。参数通过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("%ld\n",bufferSize);
printf("%s",buffer);
return 0;
}
有关指针的更多信息,请参阅What are the barriers to understanding pointers and what can be done to overcome them?
答案 1 :(得分:0)
因为您没有更改缓冲区指向的数据,所以您正在尝试编辑指针指向的数据。 当你的函数退出时,缓冲区的地址没有改变,那个内存当前都被泄露了。
要正确执行此操作,您需要将指针传递给指针并更改函数签名。
在这种情况下,传递&buffer
更改签名以使用**char buffer
并将作业分配到buffer[0]
或*buffer
,如*buffer = malloc ....