CN108776627A - 一种数据存储方法、装置、读取方法及装置 - Google Patents

一种数据存储方法、装置、读取方法及装置 Download PDF

Info

Publication number
CN108776627A
CN108776627A CN201810529392.9A CN201810529392A CN108776627A CN 108776627 A CN108776627 A CN 108776627A CN 201810529392 A CN201810529392 A CN 201810529392A CN 108776627 A CN108776627 A CN 108776627A
Authority
CN
China
Prior art keywords
target data
memory block
written
data
module
Prior art date
Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
Granted
Application number
CN201810529392.9A
Other languages
English (en)
Other versions
CN108776627B (zh
Inventor
郑建堂
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
Qingdao Haier Technology Co Ltd
Original Assignee
Qingdao Haier Technology Co Ltd
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by Qingdao Haier Technology Co Ltd filed Critical Qingdao Haier Technology Co Ltd
Priority to CN201810529392.9A priority Critical patent/CN108776627B/zh
Publication of CN108776627A publication Critical patent/CN108776627A/zh
Application granted granted Critical
Publication of CN108776627B publication Critical patent/CN108776627B/zh
Active legal-status Critical Current
Anticipated expiration legal-status Critical

Links

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F11/00Error detection; Error correction; Monitoring
    • G06F11/07Responding to the occurrence of a fault, e.g. fault tolerance
    • G06F11/14Error detection or correction of the data by redundancy in operation
    • G06F11/1402Saving, restoring, recovering or retrying
    • G06F11/1446Point-in-time backing up or restoration of persistent data
    • G06F11/1448Management of the data involved in backup or backup restore
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F3/00Input arrangements for transferring data to be processed into a form capable of being handled by the computer; Output arrangements for transferring data from processing unit to output unit, e.g. interface arrangements
    • G06F3/06Digital input from, or digital output to, record carriers, e.g. RAID, emulated record carriers or networked record carriers
    • G06F3/0601Interfaces specially adapted for storage systems
    • G06F3/0602Interfaces specially adapted for storage systems specifically adapted to achieve a particular effect
    • G06F3/0614Improving the reliability of storage systems
    • G06F3/0619Improving the reliability of storage systems in relation to data integrity, e.g. data losses, bit errors
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F3/00Input arrangements for transferring data to be processed into a form capable of being handled by the computer; Output arrangements for transferring data from processing unit to output unit, e.g. interface arrangements
    • G06F3/06Digital input from, or digital output to, record carriers, e.g. RAID, emulated record carriers or networked record carriers
    • G06F3/0601Interfaces specially adapted for storage systems
    • G06F3/0628Interfaces specially adapted for storage systems making use of a particular technique
    • G06F3/0638Organizing or formatting or addressing of data
    • G06F3/0644Management of space entities, e.g. partitions, extents, pools
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F3/00Input arrangements for transferring data to be processed into a form capable of being handled by the computer; Output arrangements for transferring data from processing unit to output unit, e.g. interface arrangements
    • G06F3/06Digital input from, or digital output to, record carriers, e.g. RAID, emulated record carriers or networked record carriers
    • G06F3/0601Interfaces specially adapted for storage systems
    • G06F3/0668Interfaces specially adapted for storage systems adopting a particular infrastructure
    • G06F3/0671In-line storage system
    • G06F3/0673Single storage device
    • G06F3/0679Non-volatile semiconductor memory device, e.g. flash memory, one time programmable memory [OTP]

Landscapes

  • Engineering & Computer Science (AREA)
  • Theoretical Computer Science (AREA)
  • Physics & Mathematics (AREA)
  • General Engineering & Computer Science (AREA)
  • General Physics & Mathematics (AREA)
  • Human Computer Interaction (AREA)
  • Computer Security & Cryptography (AREA)
  • Quality & Reliability (AREA)
  • Techniques For Improving Reliability Of Storages (AREA)

Abstract

本发明公开了一种数据存储方法、装置、读取方法及装置,此方法包括:为目标数据设置N个存储区;将所述目标数据循环地写入各存储区中,其中,将所述目标数据写入一存储区后,判断是否满足换区写入条件,在满足换区写入条件时,确定下一存储区,将所述目标数据写入下一存储区。本发明能够实现数据的掉电不丢失,确保在写过程中掉电后,则在下次上电时,仍可以得到基本没有损失的累积式历史数据。

Description

一种数据存储方法、装置、读取方法及装置
技术领域
本发明涉及互联网技术领域,尤其涉及一种数据存储方法、装置、读取方法及装置。
背景技术
在单片机应用系统中,长期存储数据的存储媒介为数据存储模块,数据存储模块的质量以及对数据存储模块的控制会影响数据存储的有效性,尤其是涉及到失电的情况。
通过单片机读写数据时,经由接口和数据存储模块进行通信交互实现数据读写,在单片机的正常工作中这样的交互会比较频繁,在交互过程中,如果遇到干扰,甚至突然断电,会造成当次交互失败,使数据存储模块存储的数据不完整或者存储错误从而导致历史数据永久性完全丢失,更严重的会使该单片机所属设备不能正常工作。
电可擦除可编程ROM(Electrically Erasable Programmable ROM,简称EEPROM)是一种常用的数据存储模块。一般通过I2C通信接口对EEPROM进行读写访问,并且可以对其地址范围内的任意字节进行读写操作。EEPROM在失去电源的情况下,可以保持内部已存储的数据长时间不丢失(一般可长达10年以上),在下次上电后,可以正常访问内部数据。
目前,对数据存储模块进行访问时,一般根据下述步骤执行:
1)定义好需要保存的数据(块)在数据存储模块中的绝对开始地址的位置。
2)按I2C通信要求,将数据(块)写入到指定开始地址以后的一段区域。
3)为了保证数据写入的可靠性,把刚写入的数据(块),再读取出来,和写入原始数据(块)比对是否一致,在一致的情况下,确认写入操作正确。
4)为进一步保证数据写入准确,在写入到数据存储模块内的数据(块)内附加校验字节,在下次读取时候,通过此检验字节验证是否数据可信。
5)读取数据,按预知的位置,读取数据(块)并验证校验字节,决定是否采纳该数据(块),如果校验正确,则采纳,否则抛弃。
上述方法具有以下缺点:当在对数据存储模块写入数据的过程中出现系统断电的情况时,会导致正写入的数据写入不完整或者写入错误,断电后无法通过读出数据进行比较的办法验证是否出现错误,从而进行重新写入,那么在下次上电后,读取该地址则得不到正确的数据只能抛弃读取操作。于是,会丢失历史数据,如果丢失的是比较重要的历史累积数据,则会造成严重损失,甚至造成设备不能正常工作。
发明内容
为了解决上述技术问题,本发明提供了一种数据存储方法、装置、读取方法及装置。
本发明提供的数据存储方法,包括:
为目标数据设置N个存储区,其中,N为大于1的整数;
将所述目标数据循环地写入各存储区中,其中,将所述目标数据写入一存储区后,判断是否满足换区写入条件,在满足换区写入条件时,确定下一存储区,将所述目标数据写入下一存储区。
上述数据存储方法还具有以下特点:
所述换区写入条件包括:所述目标数据的变化程度大于预设变化阈值和/或所述目标数据在当前存储区保存的时长大于预设时长规则中的相应时长。
上述数据存储方法还具有以下特点:
所述将目标数据写入一存储区包括:
第一过程:缓存目标数据,将所述目标数据写入所述存储区,从所述存储区读取出目标数据;
第二过程:判断缓存的目标数据和读取出的目标数据是否相同,在缓存的目标数据和读取出的目标数据相同时,确定将所述目标数据写入存储区成功,在缓存的目标数据和读取出的目标数据不相同时,多次执行所述第一过程直至缓存的目标数据和读取出的目标数据相同。
上述数据存储方法还具有以下特点:
所述预设时长规则包括以下规则中的一种:
所述目标数据保存在各存储区的预设时长均相同;
所述目标数据保存在各存储区的预设时长均不相同;
所述目标数据保存在一存储区的预设时长与所述目标数据写入此存储区的次数呈正相关;
所述目标数据保存在一存储区的预设时长与所述目标数据写入所有存储区的总次数呈正相关。
上述数据存储方法还具有以下特点:
所述方法还包括以下方式的中的一种:
方式一,将所述目标数据写入存储区时,还写入所述目标数据的时间戳信息;
方式二,所述目标数据中包括时间戳信息;
其中,所述时间戳信息是循环累加的时间戳信息,将所述目标数据写入存储区之前,将所述目标数据的当前时间戳信息累加预设间隔,在累加到最大值时,在再次累加时回归最小值。
本发明提供的数据读取方法,包括:
确定目标数据在各存储区的存储位置;
从各存储区读取所述目标数据的内容;
校验读取出的目标数据的内容正确后,选择读取出的内容中的一个作为读取结果。
上述数据存储方法还具有以下特点:
所述方法还包括:从各存储区读取目标数据的时间戳信息;
所述选择读取出的内容中的一个作为读取结果包括:选择最新的时间戳信息对应的内容作为读取结果。
本发明提供的数据存储装置,包括:
设置装置,用于为目标数据设置N个存储区;其中N为大于1的整数;
控制装置,用于将目标数据循环地写入各存储区中;
所述控制装置包括写入模块、判断模块、确定模块;
所述写入模块,用于将目标数据写入所述确定模块确定的存储区;
所述判断模块,用于判断是否满足换区写入条件;
所述确定模块,用于确定下一存储区。
上述数据存储装置还具有以下特点:
所述换区写入条件包括:所述目标数据的变化程度大于预设变化阈值和/或所述目标数据在当前存储区保存的时长大于预设时长规则中的相应时长。
上述数据存储装置还具有以下特点:
所述写入模块包括执行模块和判断单元,所述执行模块包括缓存单元、写入单元、读取单元;
所述缓存单元,用于缓存目标数据;
所述写入单元,用于将所述目标数据写入存储区;
读取单元,用于从所述存储区读取出目标数据;
判断单元,用于判断缓存的目标数据和读取出的目标数据是否相同,在缓存的目标数据和读取出的目标数据相同时,确定将所述目标数据写入存储区成功,在缓存的目标数据和读取出的目标数据不相同时,触发所述执行模块再次执行。
上述数据存储装置还具有以下特点:
所述预设时长规则包括以下规则中的一种:
所述目标数据保存在各存储区的预设时长均相同;
所述目标数据保存在各存储区的预设时长均不相同;
所述目标数据保存在一存储区的预设时长与所述目标数据写入此存储区的次数呈正相关;
所述目标数据保存在一存储区的预设时长与所述目标数据写入所有存储区的总次数呈正相关。
上述数据存储装置还具有以下特点:
所述写入模块,还用于将所述目标数据写入存储区时,还写入所述目标数据的时间戳信息;或者,还用于将所述目标数据写入存储区时,所述目标数据中包括时间戳信息;
其中,所述时间戳信息是循环累加的时间戳信息,将所述目标数据写入第一存储区或第二存储区之前,将所述目标数据的当前时间戳信息累加预设间隔,在累加到最大值时,在再次累加时回归最小值。
本发明提供的数据读取装置,包括:
位置确定模块,用于确定目标数据在各存储区的存储位置;
读取模块,用于从各存储区读取所述目标数据的内容;
校验模块,用于校验读取出的目标数据的内容是否正确;
选择模块,用于在所述校验模块校验读取出的目标数据的内容正确后,选择读取出的内容中的一个作为读取结果。
上述数据读取装置还具有以下特点:
所述读取模块,还用于从各存储区读取目标数据的时间戳信息;
所述选择模块,还用于选择最新的时间戳信息对应的内容作为读取结果。
本发明中在数据存储模块中为每个需存储的数据分配一个以上存储区域,实现多备份,主控单元(例如单片机)与数据存储模块交互时,分别对多个存储区域进行操作,可以确保数据写入正确。本发明能够实现数据的掉电不丢失,确保在写过程中掉电后,则在下次上电时,仍可以得到基本没有损失的累积式历史数据。典型的,本发明在数据存储模块中为每个需存储的数据分配两个存储区域,实现双备份。
本发明还实现了独立的广义时间戳设计,不依赖自然时间系统,能够独立识别数据存储次序。
本发明还使用校验信息,通过新定义的数据结构和算法,实现了在存储器模块写操作过程中掉电,也能够保证数据信息基本没有损失的高可靠数据保存的优点。
附图说明
构成本发明的一部分的附图用来提供对本发明的进一步理解,本发明的示意性实施例及其说明用于解释本发明,并不构成对本发明的不当限定。在附图中:
图1是实施例一中数据存储方法的流程图;
图2是实施例二中数据存储装置的结构图;
图3是实施例三中数据读取方法的流程图;
图4是实施例四中数据读取装置的结构图。
具体实施方式
为使本发明实施例的目的、技术方案和优点更加清楚,下面将结合本发明实施例中的附图,对本发明实施例中的技术方案进行清楚、完整地描述,显然,所描述的实施例是本发明一部分实施例,而不是全部的实施例。基于本发明中的实施例,本领域普通技术人员在没有做出创造性劳动前提下所获得的所有其他实施例,都属于本发明保护的范围。需要说明的是,在不冲突的情况下,本申请中的实施例及实施例中的特征可以相互任意组合。
实施例一
如图1所示,数据存储方法包括:
步骤101,为目标数据设置N个存储区;其中,N为大于1的整数;
步骤102,将目标数据循环地写入各存储区中,其中,将目标数据写入一存储区后,判断是否满足换区写入条件,在满足换区写入条件时,确定下一存储区,将目标数据写入下一存储区。
存储区的个数典型的为2个,但不限于2个,2个以上的存储区的情况与存储区的个数为2个的方法同理。
此方法中,在任何一个存储区进行存储时,都需确认保存成功后,才会在下一存储区进行新的次保存,保证数据的有效存储,在断电情况下,使存储设备仍然能保存完整的数据。
其中,
步骤101中,将目标数据写入一存储区包括:
第一过程:缓存目标数据,将目标数据写入存储区,从存储区读取出目标数据;
第二过程:判断缓存的目标数据和读取出的目标数据是否相同,在缓存的目标数据和读取出的目标数据相同时,确定将目标数据写入存储区成功,在缓存的目标数据和读取出的目标数据不相同时,多次执行第一过程直至缓存的目标数据和读取出的目标数据相同。
步骤102中将目标数据循环地写入各存储区可以是依次写入,也可以是无顺序式写入。依次写入时,为存储区设置编号,按照编号的顺序依次写入,例如按编号从大到小的顺序或者按编号从小到大的顺序。无顺序式写入时,在一存储区写入目标数据后,从其它存储区中选择一存储区,将目标数据写入选中的存储区中。
步骤102中,换区写入条件包括:目标数据的变化程度大于预设变化阈值和/或目标数据在当前存储区保存的时长大于预设时长规则中的相应时长。
单片机系统中,对累积数据的保存是不间断进行的,也就是说,每间隔一些时间就对该累积数据保存一次,一般保存间隔能够保证数据的精度误差,例如如果精度要求10,则该数据变化差值接近10间距,则就会立即保存一次,从而保证两个备份区的数据都能够保证精度需要。目标数据的变化程度大于预设变化阈值的换区写入条件时为保证数据存储的精度值,例如目标数据为温度值,预设变化阈值为1摄氏度,则目标数据更新后,更新的值大于1度时,则需要在下一存储区进行存储,从而满足用户对数据的精度要求,从而保证了累积历史数据的可靠。从上述内容已可知,系统稳定运行一段时间后(如果系统还没有稳定运行一定时间,则累积历史数据也没有意义),两个备份区的数据,必然会有一个是正确的。从刚才的精度保障机制可以得知,取出任意一个区内的数据,都可以保证满足用户数据精度。如果由于掉电损失,则最大只是损失了一个精度范围的差值,从而最大限度确保了历史数据的可靠。
步骤102中的预设时长规则包括以下规则中的一种:
第一种,目标数据保存在各存储区的预设时长均相同;例如,以存储区的个数为2个为例,目标数据保存在第一存储区的预设时长和保存在第二存储区的预设时长均100毫秒。
第二种,目标数据保存在各存储区的预设时长均不相同;例如,以存储区的个数为2个为例,目标数据保存在第一存储区的预设时长为100豪秒,保存在第二存储区的预设时长均为200毫秒。
第三种,目标数据保存在一存储区的预设时长与目标数据写入此存储区的次数呈正相关,例如,以存储区的个数为2个为例,目标数据第一次保存在第一存储区后,对应的预设时长为100毫秒,第二次保存在第一存储区后,对应的预设时长为101毫秒,第二次保存在第一存储区后,对应的预设时长为102毫秒,以此类推。目标数据第一次保存在第二存储区后,对应的预设时长为200毫秒,第二次保存在第一存储区后,对应的预设时长为201毫秒,第二次保存在第一存储区后,对应的预设时长为202毫秒,以此类推。
第四种,目标数据保存在一存储区的预设时长与目标数据写入所有存储区的总次数呈正相关。例如,以存储区的个数为2个为例,目标数据第一次保存在第一存储区后,对应的预设时长为100毫秒,目标数据第一次保存在第二存储区后,对应的预设时长为101毫秒,目标数据第二次保存在第一存储区后,对应的预设时长为102毫秒,目标数据第二次保存在第二存储区后,对应的预设时长为103毫秒。以此类推。
为了使读取数据时,获取最新的和最准确的数据,使用时间戳信息来表示数据的更新程序,此方法包括以下两种方式:
方式一,将目标数据写入存储区时,还写入目标数据的时间戳信息;
方式二,目标数据包括时间戳信息。
此时间戳信息是一种独立的广义的时间戳信息。所谓独立,是指该信息只是在该数据应用范畴内有效,而且不依赖具体时钟系统,所谓广义,是指该时间不是通常的全息的自然时间(年月日时分秒格式的时间),而只是从自然时间的信息中提取对数据保存有用的一部分信息来使用,其本质是也是时间,是特别的时间信息。此处只是提取时间的先后次序信息作为时间戳。来标志两个备份区内数据保存的先后次序,以保障能够读取到最新的数据。
时间戳信息是循环累加的时间戳信息,将目标数据写入一存储区之前,将目标数据的当前时间戳信息累加预设间隔,在累加到最大值时,在再次累加时回归最小值。本方法中,每次保存数据时都会在时间戳初始信息基础是加1,然后保存,这样,两次保存的数据块的时间戳一定是整数连续的,最新的一定按连续累加特性比前一个大1,则可以判断出最新的数据。一种典型的例子为:时间戳信息的最大值是255,最小值是0,当时间戳累计到255,再加1则变成0,这里按循环累加原则(例如时钟0-24小时循环),0大于255且差值为1,即可判断最新为0标记数据块。这样的好处是,不依赖时钟系统获取时间信息,而且使用最小数据量来标志次序,一般只需要一个字节即可,就可以判断数据保存的次序。
本方法中,在进行数据存储时,只有存储操作正确后,才能对时间戳信息进行累加,如果不正确,或者过程掉电,则下次还是在对第同一存储区进行写操作,直到该存储区写入正确,再对时间戳信息进行累加。如果系统能够稳定运行一段时间(如果系统还没有稳定运行一定时间,则累积历史数据也没有意义),这个操作一定会实现。后续才能对另外的存储区进行写操作,也就是说在进入另外一个区的写入操作时,则必然上一次写入是正确的。这也正是该方案能够保证掉电后一定能够读取到正确历史数据的关键。因为不可能出现多个存储区的数据都出现错误,所以本方法可以保障存储模块中已写入至少一正确的数据。
为了保证存储的准确性,本方法中还包括使用校验数据进行数据检验,包括以下两种方式:
方式一,将目标数据写入一存储区时,还写入目标数据的校验数据;
方式二,目标数据包括校验数据。
实施例二
如图2所示,与上述方法对应的数据存储装置包括:
设置装置,用于为目标数据设置N个存储区;其中N为大于1的整数;
控制装置,用于将目标数据循环地写入各存储区中;
控制装置包括写入模块、判断模块、确定模块;
写入模块,用于将目标数据写入确定模块确定的存储区;
判断模块,用于判断是否满足换区写入条件;
确定模块,用于确定下一存储区。
存储区的个数典型的为2个,但不限于2个,2个以上的存储区的情况与存储区的个数为2个的方法同理。下面主要以存储区的个数为2个的情况进行说明。
换区写入条件包括:目标数据的变化程度大于预设变化阈值和/或目标数据在当前存储区保存的时长大于预设时长规则中的相应时长。
写入模块包括执行模块和判断单元,执行模块包括缓存单元、写入单元、读取单元;
缓存单元,用于缓存目标数据;
写入单元,用于将目标数据写入存储区;
读取单元,用于从存储区读取出目标数据;
判断单元,用于判断缓存的目标数据和读取出的目标数据是否相同,在缓存的目标数据和读取出的目标数据相同时,确定将目标数据写入存储区成功,在缓存的目标数据和读取出的目标数据不相同时,触发执行模块再次执行。
预设时长规则包括以下规则中的一种:
目标数据保存在各存储区的预设时长均相同;
目标数据保存在各存储区的预设时长均不相同;
目标数据保存在一存储区的预设时长与目标数据写入此存储区的次数呈正相关;
目标数据保存在一存储区的预设时长与目标数据写入所有存储区的总次数呈正相关。
具体的,
写入模块,还用于将目标数据写入存储区时,还写入目标数据的时间戳信息;或者,还用于将目标数据写入存储区时,目标数据中包括时间戳信息;
其中,时间戳信息是循环累加的时间戳信息,将目标数据写入第一存储区或第二存储区之前,将目标数据的当前时间戳信息累加预设间隔,在累加到最大值时,在再次累加时回归最小值。
实施例三
如图3所示,数据读取方法包括:
步骤301,确定目标数据在各存储区的存储位置;
步骤302,从各存储区读取目标数据的内容;
步骤303,校验读取出的目标数据的内容正确后,选择读取出的内容中的一个作为读取结果此读取方法还包括:从各存储区读取目标数据的时间戳信息,选择最新的时间戳信息对应的目标数据作为读取出的目标数据。
此方法还包括:从各存储区读取目标数据的时间戳信息;步骤303中选择读取出的内容中的一个作为读取结果包括:选择最新的时间戳信息对应的内容作为读取结果。
实施例四
如图4所示,数据读取装置包括:
位置确定模块,用于确定目标数据在各存储区的存储位置;
读取模块,用于从各存储区读取目标数据的内容;
校验模块,用于校验读取出的目标数据的内容是否正确;
选择模块,用于在校验模块校验读取出的目标数据的内容正确后,选择读取出的内容中的一个作为读取结果。
其中,
读取模块,还用于从各存储区读取目标数据的时间戳信息;
选择模块,还用于选择最新的时间戳信息对应的内容作为读取结果。
上面描述的内容可以单独地或者以各种方式组合起来实施,而这些变型方式都在本发明的保护范围之内。
本领域普通技术人员可以理解上述方法中的全部或部分步骤可通过程序来指令相关硬件完成,程序可以存储于计算机可读存储介质中,如只读存储器、磁盘或光盘等。可选地,上述实施例的全部或部分步骤也可以使用一个或多个集成电路来实现,相应地,上述实施例中的各模块/单元可以采用硬件的形式实现,也可以采用软件功能模块的形式实现。本发明不限制于任何特定形式的硬件和软件的结合。
需要说明的是,在本文中,术语“包括”、“包含”或者其任何其他变体意在涵盖非排他性的包含,从而使得包括一系列要素的物品或者设备不仅包括那些要素,而且还包括没有明确列出的其他要素,或者是还包括为这种物品或者设备所固有的要素。在没有更多限制的情况下,由语句“包括……”限定的要素,并不排除在包括要素的物品或者设备中还存在另外的相同要素。
以上实施例仅用以说明本发明的技术方案而非限制,仅仅参照较佳实施例对本发明进行了详细说明。本领域的普通技术人员应当理解,可以对本发明的技术方案进行修改或者等同替换,而不脱离本发明技术方案的精神和范围,均应涵盖在本发明的权利要求范围当中。

Claims (14)

1.一种数据存储方法,其特征在于,包括:
为目标数据设置N个存储区,其中,N为大于1的整数;
将所述目标数据循环地写入各存储区中,其中,将所述目标数据写入一存储区后,判断是否满足换区写入条件,在满足换区写入条件时,确定下一存储区,将所述目标数据写入下一存储区。
2.如权利要求1所述的数据存储方法,其特征在于,
所述换区写入条件包括:所述目标数据的变化程度大于预设变化阈值和/或所述目标数据在当前存储区保存的时长大于预设时长规则中的相应时长。
3.如权利要求1所述的数据存储方法,其特征在于,
所述将目标数据写入一存储区包括:
第一过程:缓存目标数据,将所述目标数据写入所述存储区,从所述存储区读取出目标数据;
第二过程:判断缓存的目标数据和读取出的目标数据是否相同,在缓存的目标数据和读取出的目标数据相同时,确定将所述目标数据写入存储区成功,在缓存的目标数据和读取出的目标数据不相同时,多次执行所述第一过程直至缓存的目标数据和读取出的目标数据相同。
4.如权利要求2所述的数据存储方法,其特征在于,
所述预设时长规则包括以下规则中的一种:
所述目标数据保存在各存储区的预设时长均相同;
所述目标数据保存在各存储区的预设时长均不相同;
所述目标数据保存在一存储区的预设时长与所述目标数据写入此存储区的次数呈正相关;
所述目标数据保存在一存储区的预设时长与所述目标数据写入所有存储区的总次数呈正相关。
5.如权利要求1所述的数据存储方法,其特征在于,
所述方法还包括以下方式的中的一种:
方式一,将所述目标数据写入存储区时,还写入所述目标数据的时间戳信息;
方式二,所述目标数据中包括时间戳信息;
其中,所述时间戳信息是循环累加的时间戳信息,将所述目标数据写入存储区之前,将所述目标数据的当前时间戳信息累加预设间隔,在累加到最大值时,在再次累加时回归最小值。
6.一种数据读取方法,其特征在于,包括:
确定目标数据在各存储区的存储位置;
从各存储区读取所述目标数据的内容;
校验读取出的目标数据的内容正确后,选择读取出的内容中的一个作为读取结果。
7.如权利要求6所述的数据读取方法,其特征在于,
所述方法还包括:从各存储区读取目标数据的时间戳信息;
所述选择读取出的内容中的一个作为读取结果包括:选择最新的时间戳信息对应的内容作为读取结果。
8.一种数据存储装置,其特征在于,包括:
设置装置,用于为目标数据设置N个存储区;其中N为大于1的整数;
控制装置,用于将目标数据循环地写入各存储区中;
所述控制装置包括写入模块、判断模块、确定模块;
所述写入模块,用于将目标数据写入所述确定模块确定的存储区;
所述判断模块,用于判断是否满足换区写入条件;
所述确定模块,用于确定下一存储区。
9.如权利要求8所述的数据存储装置,其特征在于,
所述换区写入条件包括:所述目标数据的变化程度大于预设变化阈值和/或所述目标数据在当前存储区保存的时长大于预设时长规则中的相应时长。
10.如权利要求8所述的数据存储装置,其特征在于,
所述写入模块包括执行模块和判断单元,所述执行模块包括缓存单元、写入单元、读取单元;
所述缓存单元,用于缓存目标数据;
所述写入单元,用于将所述目标数据写入存储区;
读取单元,用于从所述存储区读取出目标数据;
判断单元,用于判断缓存的目标数据和读取出的目标数据是否相同,在缓存的目标数据和读取出的目标数据相同时,确定将所述目标数据写入存储区成功,在缓存的目标数据和读取出的目标数据不相同时,触发所述执行模块再次执行。
11.如权利要求9所述的数据存储装置,其特征在于,
所述预设时长规则包括以下规则中的一种:
所述目标数据保存在各存储区的预设时长均相同;
所述目标数据保存在各存储区的预设时长均不相同;
所述目标数据保存在一存储区的预设时长与所述目标数据写入此存储区的次数呈正相关;
所述目标数据保存在一存储区的预设时长与所述目标数据写入所有存储区的总次数呈正相关。
12.如权利要求8所述的数据存储装置,其特征在于,
所述写入模块,还用于将所述目标数据写入存储区时,还写入所述目标数据的时间戳信息;或者,还用于将所述目标数据写入存储区时,所述目标数据中包括时间戳信息;
其中,所述时间戳信息是循环累加的时间戳信息,将所述目标数据写入第一存储区或第二存储区之前,将所述目标数据的当前时间戳信息累加预设间隔,在累加到最大值时,在再次累加时回归最小值。
13.一种数据读取装置,其特征在于,包括:
位置确定模块,用于确定目标数据在各存储区的存储位置;
读取模块,用于从各存储区读取所述目标数据的内容;
校验模块,用于校验读取出的目标数据的内容是否正确;
选择模块,用于在所述校验模块校验读取出的目标数据的内容正确后,选择读取出的内容中的一个作为读取结果。
14.如权利要求13所述的数据读取装置,其特征在于,
所述读取模块,还用于从各存储区读取目标数据的时间戳信息;
所述选择模块,还用于选择最新的时间戳信息对应的内容作为读取结果。
CN201810529392.9A 2018-05-29 2018-05-29 一种数据存储方法、装置、读取方法及装置 Active CN108776627B (zh)

Priority Applications (1)

Application Number Priority Date Filing Date Title
CN201810529392.9A CN108776627B (zh) 2018-05-29 2018-05-29 一种数据存储方法、装置、读取方法及装置

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
CN201810529392.9A CN108776627B (zh) 2018-05-29 2018-05-29 一种数据存储方法、装置、读取方法及装置

Publications (2)

Publication Number Publication Date
CN108776627A true CN108776627A (zh) 2018-11-09
CN108776627B CN108776627B (zh) 2021-08-24

Family

ID=64027911

Family Applications (1)

Application Number Title Priority Date Filing Date
CN201810529392.9A Active CN108776627B (zh) 2018-05-29 2018-05-29 一种数据存储方法、装置、读取方法及装置

Country Status (1)

Country Link
CN (1) CN108776627B (zh)

Cited By (4)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN110209523A (zh) * 2019-05-31 2019-09-06 Oppo广东移动通信有限公司 数据读写异常处理方法及装置、存储介质和电子设备
CN110888605A (zh) * 2019-12-11 2020-03-17 重庆超力高科技股份有限公司 Eeprom的数据写入方法、装置和电子设备
CN113488082A (zh) * 2021-07-02 2021-10-08 山东恒宇电子有限公司 一种针对嵌入式设备机械硬盘的音视频储存方法
CN113918578A (zh) * 2020-07-10 2022-01-11 成都秦川物联网科技股份有限公司 一种物联网智能燃气表掉电数据补齐存储方法

Citations (6)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20070088737A1 (en) * 2005-10-18 2007-04-19 Norihiko Kawakami Storage system for managing a log of access
CN102385902A (zh) * 2010-09-01 2012-03-21 建兴电子科技股份有限公司 固态储存装置及其数据控制方法
CN105760112A (zh) * 2016-02-01 2016-07-13 惠州市蓝微新源技术有限公司 延长存储器使用时间的数据存储方法、读取方法及系统
CN106951186A (zh) * 2017-03-07 2017-07-14 合肥兆芯电子有限公司 数据程序化方法、存储器存储装置及存储器控制电路单元
CN107180102A (zh) * 2017-05-25 2017-09-19 北京环境特性研究所 一种目标特性数据的存储方法和系统
CN107315659A (zh) * 2017-06-27 2017-11-03 郑州云海信息技术有限公司 一种元数据的冗余备份方法及装置

Patent Citations (6)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20070088737A1 (en) * 2005-10-18 2007-04-19 Norihiko Kawakami Storage system for managing a log of access
CN102385902A (zh) * 2010-09-01 2012-03-21 建兴电子科技股份有限公司 固态储存装置及其数据控制方法
CN105760112A (zh) * 2016-02-01 2016-07-13 惠州市蓝微新源技术有限公司 延长存储器使用时间的数据存储方法、读取方法及系统
CN106951186A (zh) * 2017-03-07 2017-07-14 合肥兆芯电子有限公司 数据程序化方法、存储器存储装置及存储器控制电路单元
CN107180102A (zh) * 2017-05-25 2017-09-19 北京环境特性研究所 一种目标特性数据的存储方法和系统
CN107315659A (zh) * 2017-06-27 2017-11-03 郑州云海信息技术有限公司 一种元数据的冗余备份方法及装置

Cited By (6)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN110209523A (zh) * 2019-05-31 2019-09-06 Oppo广东移动通信有限公司 数据读写异常处理方法及装置、存储介质和电子设备
CN110888605A (zh) * 2019-12-11 2020-03-17 重庆超力高科技股份有限公司 Eeprom的数据写入方法、装置和电子设备
CN110888605B (zh) * 2019-12-11 2023-10-20 重庆超力高科技股份有限公司 Eeprom的数据写入方法、装置和电子设备
CN113918578A (zh) * 2020-07-10 2022-01-11 成都秦川物联网科技股份有限公司 一种物联网智能燃气表掉电数据补齐存储方法
CN113918578B (zh) * 2020-07-10 2024-05-24 成都秦川物联网科技股份有限公司 一种物联网智能燃气表掉电数据补齐存储方法
CN113488082A (zh) * 2021-07-02 2021-10-08 山东恒宇电子有限公司 一种针对嵌入式设备机械硬盘的音视频储存方法

Also Published As

Publication number Publication date
CN108776627B (zh) 2021-08-24

Similar Documents

Publication Publication Date Title
CN108776627A (zh) 一种数据存储方法、装置、读取方法及装置
US20070180000A1 (en) Storage apparatus and storage system
CN100409186C (zh) 信息处理设备和信息处理方法
CN102024502B (zh) 闪存器件测试方法、装置及板卡和网络设备
CN101124639B (zh) 访问非易失性计算机存储器的系统和方法
US7725646B2 (en) Method of using a flash memory for a circular buffer
CN101714391B (zh) 一种数据存储方法及装置
CN103399826A (zh) 一种基于nor flash的数据存储方法
CN109240622B (zh) 一种eeprom数据写入的方法及系统
CN106155915A (zh) 数据存储的处理方法及装置
CN101344868A (zh) 数据备份和获取的方法和装置
CN111611108A (zh) 虚拟数据库还原的方法及装置
CN112612775B (zh) 一种数据存储方法、装置、计算机设备及存储介质
CN106095612A (zh) 使用wal的数据库回滚
CN106354652A (zh) 非易失性存储器读写控制电路及方法
CN101699476A (zh) 智能卡的数据处理方法及装置
US5765211A (en) Segmenting non-volatile memory into logical pages sized to fit groups of commonly erasable data
CN100465910C (zh) 对产品中闪存数据的防错、纠错方法
CN103176920A (zh) Nor flash掉电保护方法及装置
CN113419897B (zh) 一种文件处理方法、装置、电子设备及其存储介质
CN109901862A (zh) 一种bmc配置参数存储方法
CN105988899B (zh) 实现数据缓存的方法和装置
CN109445991A (zh) 一种数据存储方法、系统、智能可穿戴设备及存储介质
CN115509466B (zh) 一种数据管理方法、装置及电子设备和存储介质
US8825600B2 (en) File backup apparatus and method for backing up one or more directories

Legal Events

Date Code Title Description
PB01 Publication
PB01 Publication
SE01 Entry into force of request for substantive examination
SE01 Entry into force of request for substantive examination
GR01 Patent grant
GR01 Patent grant