在C中的过程期间更新指针

时间:2015-09-18 21:53:36

标签: c pointers

我正在尝试读取文件并使用内容更新缓冲区。我不希望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中更新的缓冲区?

2 个答案:

答案 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 ....