我编写的程序获取一个文件的大小,从该文件读取partSize字节数,并将partSize字节数写入新创建的文件。问题是它只适用于小文本文件。如果我尝试使用几百行或图片的文本文件运行程序,我会遇到分段错误,并且明显少于partSize字节存储到新文件中。
#include <stdio.h>
#include <stdlib.h>
#include <fcntl.h>
#include <unistd.h>
#include <sys/stat.h>
#include <sys/types.h>
#include <errno.h>
int main()
{
int createDescriptor;
int openDescriptorOriginal;
int closeCreateDescriptor;
// char fileNameOriginal[] = "picture.jpg";
char fileNameOriginal[] = "myFile.txt";
int parts;
int partSize;
parts=2;
int bytesRemaining;
int partNumber;
char BUFFER[512];
int readDescriptor;
int buffer[1];
oid *pbuffer = &buffer;
int bytes, infile, outfile;
if ((openDescriptorOriginal = open(fileNameOriginal, O_RDONLY )) == -1)
{
printf("Error opening %s", fileNameOriginal);
exit(EXIT_FAILURE);
}
struct stat buf;
int r = fstat(openDescriptorOriginal, &buf);
if (r)
{
fprintf(stderr, "error: fstat: %s\n", (char *) strerror(errno));
exit(1);
}
int originalFileSize = buf.st_size;
printf("The file is %.9f bytes large.\n",(double)originalFileSize);
partSize = ((originalFileSize + parts) - 1)/parts;
printf("Part size: %.9f bytes large\n",(double)partSize);
umask(0000);
//create and open new file
if ( (outfile = open("NewPicture.jpg", O_CREAT|O_WRONLY,0777))==-1 )
{
printf("ERROR %s\n", "NewPicture.jpg");
}
ssize_t count, total;
total = 0;
char *bufff = BUFFER;
while (partSize) {
count = read(openDescriptorOriginal, bufff, partSize);
if (count < 0) {
break;
}
if (count == 0)
break;
bufff += count;
total += count;
partSize -= count;
}
write (outfile, BUFFER, total);
printf("\n");
return 0;
}
答案 0 :(得分:2)
您正在使用仅512字节的缓冲区。
BUFFER[512];
如果该文件中的内容超出此限制,则会发生seg错误。
答案 1 :(得分:1)
count = read(openDescriptorOriginal, bufff, partSize);
在这一行中,第三个参数错误,
在您的代码中,您已定义char BUFFER[512];
使用BUFFER
一次只读取511个字节的文件。
count = read(openDescriptorOriginal, BUFFER, 512);
为何不与大喜欢合作的原因:
如果partSize
&gt;然后 512
然后可能会发生缓冲区溢出(buffer overflow)。这就是为什么你的大文件不起作用的原因。因为read()
函数将尝试从与打开文件描述符partSize
相关联的文件中读取openDescriptorOriginal
个字节,并将其填充到BUFFER指向的缓冲区中,该缓冲区仅为{{1} }字节长。此缓冲区溢出是程序中分段错误的原因。
如果文件大小很小,那么代码将起作用。
我已经纠正了你的代码:
512
答案 2 :(得分:1)
你的缓冲区太小了。您需要一个更大的缓冲区变量。如果文件大小超过512字节,则会出现段错误。
理想情况下,您应该以固定的块读取文件。也就是说,在每次读取时读取可能是30-40或一定数量的字符,然后将其写入新文件。重复,直到读完整个文件。
答案 3 :(得分:0)
这没有任何意义
partSize = ((originalFileSize + parts) - 1)/parts;
你已经将parts
初始化为2,然后你将原来的文件大小加2,减去1,然后再分为2,即使在一天结束时你的缓冲区大小为512?
您需要做的是在从文件读取时检查缓冲区大小并检查实际读取的字节数,从原始文件大小中减去此值,重复直到实际读取字节小于缓冲区大小并且/或当原始文件大小为0时。
如果您使用文件缓冲I / O(即fopen/fread/fwrite/fclose
- 可能会更好 - 如果您没有任何特殊原因要使用无缓冲I / O.