Linux文件读写之得到重复的内容

在Linux系统中,我们经常需要对问文件进行操作,文件的读写时又经常会出现各种各样的问题。在这里我就讲一下我在进行文件读写操作时遇到的问题。

背景:首先向文件中写入内容,然后从文件中从后往前读取文件中的内容;

在Qt环境下的编程

代码如下:

#include "mainwidget.h"

#include "ui_mainwidget.h"

#include<stdio.h>

#include<string.h>

#include <unistd.h>

#include <sys/types.h>

#include <sys/stat.h>

#include <fcntl.h>

#define    FILENAME  "alamDetailList"     //文件名

#define  ARRAYSIZE 200

typedef struct alarmMessage{

int msgSize;                           //数据大小

char mesInfo[ARRAYSIZE];    //数据内容

}msg_t;

void mainWidget::saveMessageToFile()     //把内容写入文件中

{

int isFileExist = access(FILENAME,F_OK);       //判断文件是否存在

int fd;

if (isFileExist == 0)   //文件存在

{

fd = open(FILENAME,O_WRONLY);

qDebug() <<"打开文件";

}else {

qDebug()<<"创建并打开文件";

fd = open(FILENAME,O_RDWR|O_CREAT,S_IRUSR|S_IWUSR);

}

if(fd == -1)

{

qDebug() << tr("打开文件失败");

}

lseek(fd,0,SEEK_END);    //每次写入文件之前,都移到文件的最后的位置

//alarmMSGDeatil 是QString类型,也就是要写入文件中的内容,下面是将QString类型转换为char *类型

const char *detailTime = alarmMSGDeatil.toStdString().c_str();

msg_t msg;

memset(msg.mesInfo,‘\0‘,sizeof(msg.mesInfo));

msg.msgSize = strlen(detailTime);

strcpy(msg.mesInfo,detailTime);

int bytesWrite = write(fd,&msg,sizeof(msg));

qDebug() << "==bytesWrite111=="<<bytesWrite;

::close(fd);

}

//读取文件内容,从后往前读

void mainWidget::readFile()

{

qDebug("11111111111");

//ui->listWidget->setVisible(true);

int fd = open(FILENAME,O_RDONLY);

if(fd == -1)

{

qDebug() << "打开文件失败";

return;

}

lseek(fd, 0 ,SEEK_END);      //位置指向文件的最后

off_t  offset = 0;

int readBytes = 0;

//ui->listWidget->clear();

while(1)                           //通过死循环来完成文件中所有内容的读写

{

offset += sizeof(msg_t);

qDebug() << "===offset=====" <<offset;

//得到当前位置距离文件头的距离

off_t   curFromHead = lseek(fd, 0 - offset,SEEK_END);

if(curFromHead < 0)    //如果不加上这一判断的话,就会出现文件中内容重复读取                                              的情况

{

break;

}

//qDebug() <<"====curFromHead====" <<curFromHead;

msg_t  readBuf;

readBytes = read(fd, &readBuf, sizeof(msg_t));

qDebug() <<"===readBytes===" << readBytes;

if(readBytes <= 0)         //

{

qDebug() << "文件读取完成";

break;

}

QString timeString = QString(readBuf.mesInfo);

qDebug() << timeString;

// ui->listWidget->addItem(timeString);

readBytes = 0;

}

::close(fd);

qDebug()<<"222222";

}

时间: 2024-08-03 16:12:03

Linux文件读写之得到重复的内容的相关文章

Linux文件读写机制及优化方式

导读 Linux是一个可控性强的,安全高效的操作系统.本文只讨论Linux下文件的读写机制,不涉及不同读取方式如read,fread,cin等的对比,这些读取方式本质上都是调用系统api read,只是做了不同封装.以下所有测试均使用open, read, write这一套系统api. 缓存 缓存是用来减少高速设备访问低速设备所需平均时间的组件,文件读写涉及到计算机内存和磁盘,内存操作速度远远大于磁盘,如果每次调用read,write都去直接操作磁盘,一方面速度会被限制,一方面也会降低磁盘使用寿

linux入门教程(六) Linux文件与目录管理

在linux中什么是一个文件的路径呢,说白了就是这个文件存在的地方,例如在上一章提到的/root/.ssh/authorized_keys 这就是一个文件的路径.如果你告诉系统这个文件的路径,那么系统就可以找到这个文件.在linux的世界中,存在着绝对路径和相对路径. 绝对路径:路径的写法一定由根目录”/”写起,例如/usr/local/mysql 这就是绝对路径. 相对路径:路径的写法不是由根目录”/”写起,例如,首先用户进入到/ 然后再进入到home ,命令为 cd /home 然后 cd

Linux C 文件与目录3 文件读写

文件读写 文件读写是指从文件中读出信息或将信息写入到文件中.Linux文件读取可使用read函数来实现的,文件写入可使用write函数来实现.在进行文件写入的操作时,只是在文件的缓冲区中操作,可能没有立即写入到文件中.需要使用sync或fsync函数将缓冲区的数据写入到文件中. 文件写操作: 函数write可以把一个字符串写入到一个已经打开的文件中,这个函数的使用方法如下: ssize_t  write  (int fd , void *buf , size_t  count); 参数: fd:

Linux环境下实现对文件读写操作

---- 今天分享一下在linux系统在实现对文件读写一些基本的操作,在这之前我们要掌握一些基本的技能在Linux环境下.比如查看命令和一个函数的具体用法,就是相当于查手册,在Linux下有一个man手册非常有用:man查询手册man 1 +命令 这里的1表示为查询的是Linux命令man 2 xxx 这里的2表示为查询的是linux apiman 3 xxx 这里的3表示为查询的是c库函数在了解了这个后我们就可以开始来实现标题说的操作了.一.在linux环境下常用文件接口函数:open.clo

linux下查看修改文件读写执行权限

查看文件权限的语句: 在终端输入:ls -l xxx.xxx (xxx.xxx是文件名) 那么就会出现相类似的信息,主要都是这些:-rw-rw-r-- 一共有10位数 其中: 最前面那个 - 代表的是类型 中间那三个 rw- 代表的是所有者(user) 然后那三个 rw- 代表的是组群(group) 最后那三个 r-- 代表的是其他人(other) 然后我再解释一下后面那9位数: r 表示文件可以被读(read) w 表示文件可以被写(write) x 表示文件可以被执行(如果它是程序的话) -

Linux系统下如何查看及修改文件读写权限

查看文件权限的语句: 在终端输入:ls -l xxx.xxx (xxx.xxx是文件名) 那么就会出现相类似的信息,主要都是这些:-rw-rw-r-- 一共有10位数 其中: 最前面那个 - 代表的是类型 中间那三个 rw- 代表的是所有者(user) 然后那三个 rw- 代表的是组群(group) 最后那三个 r-- 代表的是其他人(other) 然后我再解释一下后面那9位数: r 表示文件可以被读(read) w 表示文件可以被写(write) x 表示文件可以被执行(如果它是程序的话) -

Linux 内核编程 or 内核模块编程的文件读写与信号传输问题

Linux内核编程时,内核代码执行只能直接访问内存上的数据,硬盘上的文件系统必须通过间接的方式才能被内核读写.一般内核操作文件读写的方式有三种:1.通过/proc/文件作为桥梁完成硬盘文件系统与内核的交互:2.通过ioctl方式实现交互:3.直接利用虚拟文件系统的函数vfs_read().vfs_write()读写文件.三种方式的具体实现方法网上有很多详细教程,可以参考.这里对三种方法做出比较. proc机制是一种很老的文件读写方式,通用性好,实现也算成熟,使用时需要自己实现内核上层的读写函数,

Linux笔记_Linux系统下如何查看及修改文件读写权限

查看文件权限的语句: 在终端输入: ls -l xxx.xxx (xxx.xxx是文件名) 那么就会出现相类似的信息,主要都是这些: -rw-rw-r-- 一共有10位数 其中: 最前面那个 - 代表的是类型 中间那三个 rw- 代表的是所有者(user) 然后那三个 rw- 代表的是组群(group) 最后那三个 r-- 代表的是其他人(other) 然后我再解释一下后面那9位数: r 表示文件可以被读(read) w 表示文件可以被写(write) x 表示文件可以被执行(如果它是程序的话)

Linux Direct 文件读写(文件DIO)

有时候,读写文件并不想要使用系统缓存(page cache),此时 direct 文件读写就派上了用场,使用方法: (1)打开文件时,添加O_DIRECT参数: 需要定义_GNU_SOURCE,否则找不到O_DIRECT宏定义 示例片段: #define _GNU_SOURCE #include <sys/types.h> #include <sys/stat.h> #include <fcntl.h> int fd = open("test.out"