不知道出了什么问题,我似乎没有从 fread 中得到任何东西。
端口.h
#pragma once
#ifndef _PORT_
#define _PORT_
#include <string>
#ifndef UNICODE
typedef char chr;
typedef string str;
#else
typedef wchar_t chr;
typedef std::wstring str;
inline void fopen(FILE ** ptrFile, const wchar_t * _Filename,const wchar_t * _Mode)
{
_wfopen_s(ptrFile,_Filename,_Mode);
}
#endif
#endif
main() 内部
File * f = new File(fname,FileOpenMode::Read);
chr *buffer;
buffer = (wchar_t*)malloc(f->_length*2);
for(int i=0;i<f->_length;i++)
{
buffer[i] = 0;
}
f->Read_Whole_File(buffer);
f->Close();
for(int i=0;i<f->_length;i++)
{
printf("%S",buffer[i]);
}
free(buffer);
内部文件类
void Read_Whole_File(chr *&buffer)
{
//buffer = (char*)malloc(_length);
if(buffer == NULL)
{
_IsError = true;
return;
}
fseek(_file_pointer, 0, SEEK_SET);
int a = sizeof(chr);
fread(&buffer,_length ,sizeof(chr) , _file_pointer);
}
最佳答案
您到处混合了指针和引用。
您的函数只需要获取指向缓冲区的指针:
void Read_Whole_File(char *buffer) { ... }
并且您应该将该指针按原样传递给 fread()
,不要获取指针的地址:
size_t amount_read = fread(buffer, _length, sizeof *buffer, _file_pointer);
还请记住:
- 如果您有一个指向某种类型的指针
ptr
,则可以使用sizeof *ptr
并消除重复类型名称的需要。 - 如果您已经知道文件的长度,请将其传递给函数,这样您就不需要计算两次。
- 在 C 语言中,不要转换
malloc()
的返回值。 - 在进行内存分配和 I/O 时检查错误,否则可能会失败。
关于c++ - malloc 指针函数传递 fread,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/1886358/