小问题·Qt开发之QFlie

描述

        保存log应该是开发必备之一,保存的方法更是千差万别,但是最终肯定都是保存到文件中。

        那就肯定会涉及到写文件的操作,但是写文件又是一个非常耗时的过程,如果再加上操作不当的话,比如一个字节一个字节写等,时间消耗可想而知。所有大多数的解决办法是用缓存临时存储要写的内容,当要写的内容达到一定要求时再一次性写入,这样可以很好的避免了开发人员操作不当,同时加入缓存应用在写文件时,只需要写到缓存就可以返回,给应用一个写到文件的假象,使其可以做更多的事情。

        这样就会存在一个问题,如果对实时性要求比较高的写操作的话,这样肯定是不行的,比如像数据库,如果缓存起来的话,大量数据修改时,必然会存在数据不同步问题,所以缓存一般是可选或者提供方法将缓存写入文件再返回,比如 Linux系统函数-sync。

        使用Qt中QFlie类进行log保存时,发现最新的log总是没有被保存,也就是实时性不高,然后QFlie好像也没有提供类似 sync之类的刷缓存的方法 --- 有可能是我没有找到,有知道的可以告诉我一下 。但是close方法却带了sync,但是就是找不到单独的sync之类的方法,导致无法提高log的实时性,但是频繁调用close开销又比较大。

 解决方法

1、不使用QFlie,使用系统调用write

2、不使用QFlie,使用库调用fwrite,在每次写入操作之后调用sync

3、使用QFlie,找到类似sync之类的方法

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值