分别是栈上分配内存 和 堆上分配内存
有时候我们如果遇到 频繁调用这个函数 要不停的去动态分配内存很麻烦 还得手动释放
可以考虑用static buf[BUF_LEN] 在函数内部 或者是用全局变量数组 但是问题又来了 如果你的程序是守护进程 必定会一直占用内存
有时候我们如果遇到 频繁调用这个函数 要不停的去动态分配内存很麻烦 还得手动释放
可以考虑用static buf[BUF_LEN] 在函数内部 或者是用全局变量数组 但是问题又来了 如果你的程序是守护进程 必定会一直占用内存
或者你可以考虑全局变量来动态申请内存 用完了就释放
#include <stdio.h>
#include <stdlib.h>
#include <unistd.h>
#include <string.h>
#define EXIT exit(-1)
#define BUF_LEN (512)
void readFile(const char* fileName,char* out)
{
FILE* fp;
if(NULL == fileName) {
printf("error fileName.\n");
EXIT;
}
if(0 != (access(fileName,F_OK)))
{
printf("this file is not exsit.\n");
EXIT;
}
if(NULL == (fp= fopen(fileName,"r"))) {
printf("open fileName fail.\n");
EXIT;
}
if(fread(out,1,BUF_LEN,fp) < 1) {
printf("read %s file error.\n",fileName);
EXIT;
}
}
int main()
{
char out[BUF_LEN]={0};
char* buf;
/* examples 1 */
readFile("/opt/test",out);
printf("%s\n",out);
/* examples 2 */
buf = (char*)malloc(sizeof(char)*BUF_LEN);
memset(buf,'\0',sizeof(char)*BUF_LEN);
readFile("/opt/test",buf);
printf("%s\n",buf);
free(buf);
return 0;
}