在实际项目中用到了二进制文件的读取功能,就彻底研究一下。我们只注意read整个二进制文件有没有问题,而不关心效率和时间。
看下面的代码,注意几点:
1.read函数的使用,它的返回值是每次读取的字符个数,小于第三个参数时,则返回试驾读取到数值。
2.while循环有两个结束条件,1)刚好read的第三个参数是整个文件的整数倍,2)不是整数倍则需要自己加判读。
#include #include #include #include #include #include #include #include #include #include int ReadBinaryFile(const char* _fileName, void* _buf, int _bufLen); int WriteBinaryFile(const char* _fileName, void* _buf, int _bufLen); int main(int argc, char *argv[]) { if(argc < 2) { printf("main argc < 2\r\n"); exit(0); } printf("input file=%s\n", argv[1]); int nReadnum = 512; int nfilenum = 512; int nReadretnum = 0; unsigned char sendBuffer[512]; int fp;// * fp = NULL; fp = open(argv[1], O_RDONLY); // 必须确保是以 二进制写入的形式打开 if( NULL == fp ) { return (-1); } int read_num = 0; while(1) { printf("=0=fread nReadnum=%d\n", nReadnum); nReadretnum = read(fp, &sendBuffer, nReadnum); // nReadretnum有可能小雨512 printf("=1=fread nReadretnum=%d nfilenum=%d read_num=%d\n", nReadretnum, nfilenum, read_num); if(nReadretnum != 0) { read_num ++; printf("=11=fread nReadretnum=%d\n", nReadretnum); WriteBinaryFile("./1.h264", sendBuffer, nReadretnum); if(nReadretnum != nReadnum) break; } else { printf("=121=fread nReadretnum=%d\n", nReadretnum); break; } printf("=2=fread nReadretnum=%d\n", nReadretnum); } close(fp); //fromLen = sizeof(fromAddr); //if(recvfrom(sock,sendBuffer,128,0,(struct sockaddr*)&fromAddr,&fromLen)<0) //{ //printf("()recvfrom() error\r\n"); //close(sock); //exit(1); //} //printf("recvfrom() result:%s\r\n",sendBuffer); return 0; } /* * 函数说明: 写二进制文件 * 参数描述: _fileName, 文件名称 * _buf, 要写的内存缓冲。 * _bufLen, 内存缓冲的长度 * 返回值: 0, 成功 * -1, 失败 * */ int WriteBinaryFile(const char* _fileName, void* _buf, int _bufLen) { FILE * fp = NULL; if( NULL == _buf || _bufLen <= 0 ) return (-1); fp = fopen(_fileName, "ab+"); // 必须确保是以 二进制写入的形式打开 if( NULL == fp ) { return (-1); } fwrite(_buf, _bufLen, 1, fp); //二进制写 fclose(fp); fp = NULL; return 0; }