gpt4 book ai didi

c - 在 c 中使用 pread() 读取并使用 pwrite() 写入

转载 作者:塔克拉玛干 更新时间:2023-11-02 23:47:15 27 4
gpt4 key购买 nike

我的程序(如下)将文本(使用 pwrite())写入文件并从文件中读取(使用 pread())。我的问题是 pread 函数没有从文件中读取我的文本,而 close 函数有什么问题(程序的最后一部分)?结果在第二部分。我的错误在哪里?

    #include <fcntl.h>
#include <stdio.h>
#include <string.h>
#include <unistd.h>
#include <sys/stat.h>
#include <sys/types.h>

int main()
{

int fd, nr, nr2, nw, nw2;
char fl_nm[]={"file_io/pwrite.txt"};
char buf_wr[]={"hello everyone this is first text\n"};
char buf_wr2[]={"Did you miss me? Don't afraid\n"};
char buf_rd[120];
char buf_rd2[120];

//open file
fd = open(fl_nm, O_RDWR|O_CREAT, 0777);
nw = pwrite(fd, &buf_wr, strlen(buf_wr), 14);

//error checking
if(fd == -1){
perror("[error in open]\n");
}
else if(nw == -1){
perror("[error in write]\n");
}
else{

/*if open and write process are okey, read first write data
* from file*/
nr = read(fd, &buf_rd, sizeof(buf_rd));

//display succeeded message about first write and open process
printf("[file is opened]\n");
printf("[succeeded write(1) process]\n");

//read process error control
if(nr == -1){
perror("[error in read]\n");
} else{
printf("[reading(1) data] from %s\n", fl_nm);
printf("[%s]\n", buf_rd);
}

}

//second write process.
nw2= pwrite(fd, &buf_wr2, strlen(buf_wr2), 30);

//write error checking
if(nw2 == -1){
perror("[error in write 2]\n");
}else{

/*if write process is correct
* second read process*/
nr2 = read(fd, &buf_rd2, sizeof(buf_rd));

printf("-----------------------------------\n");
printf("[succeeded write(2) process]\n");
printf("[reading(2) data] from %s\n", fl_nm);
printf("[%s]\n", buf_rd2);
}

//close file
close(fd);

//error checking for close process
if(close(fd) == -1){
perror("[error in close]\n");
}else{
printf("[succeeded in close]\n");
}

return 0;
}

结果:

$ gcc pwrite.c -o pwrite
$ ./pwrite
[file is opened]
[succeeded write(1) process]
[reading(1) data] from file_io/pwrite.txt
[]
-----------------------------------
[succeeded write(2) process]
[reading(2) data] from file_io/pwrite.txt
[]
[error in close]
: Bad file descriptor

最佳答案

1) close() 失败,因为您关闭了文件两次:

//close file
close(fd);

//error check close process
if(close(fd) == -1){

在第一次调用 close(fd); 后,fd 变得不确定,第二次调用 close(fd) 失败。您只需删除对 close(fd); 的第一次调用。

2) 您正在打印 buf_rd 就好像它是一个 C 字符串一样。 read() 不会以空字节终止 buf_rd

3) 您正在使用 pwrite() 以随机偏移量(14 和 30)写入。但是 read() 从当前偏移量读取 - 这意味着起始字节可能是空字节,因此 %s 立即停止打印(即不打印任何内容)。你读的比你写的多得多。这意味着 read() 将返回少于请求的字节数。所以使用read()的返回值来获取成功读取的字节数。

相反,使用循环打印每个字节:

 for (size_t l = 0; l < nr; l++)
printf("%c", buf_rd[l]);

 for (size_t l = 0; l < nr2; l++)
printf("%c", buf_rd2[l]);

关于c - 在 c 中使用 pread() 读取并使用 pwrite() 写入,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/41362754/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com