CN105955821A - 预读方法及装置 - Google Patents

预读方法及装置 Download PDF

Info

Publication number
CN105955821A
CN105955821A CN201610252019.4A CN201610252019A CN105955821A CN 105955821 A CN105955821 A CN 105955821A CN 201610252019 A CN201610252019 A CN 201610252019A CN 105955821 A CN105955821 A CN 105955821A
Authority
CN
China
Prior art keywords
state information
storage state
internal storage
data size
tag memory
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
CN201610252019.4A
Other languages
English (en)
Other versions
CN105955821B (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.)
Beijing Xiaomi Mobile Software Co Ltd
Original Assignee
Beijing Xiaomi Mobile Software 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 Beijing Xiaomi Mobile Software Co Ltd filed Critical Beijing Xiaomi Mobile Software Co Ltd
Priority to CN201610252019.4A priority Critical patent/CN105955821B/zh
Publication of CN105955821A publication Critical patent/CN105955821A/zh
Application granted granted Critical
Publication of CN105955821B publication Critical patent/CN105955821B/zh
Active legal-status Critical Current
Anticipated expiration legal-status Critical

Links

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F9/00Arrangements for program control, e.g. control units
    • G06F9/06Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
    • G06F9/46Multiprogramming arrangements
    • G06F9/50Allocation of resources, e.g. of the central processing unit [CPU]
    • G06F9/5005Allocation of resources, e.g. of the central processing unit [CPU] to service a request
    • G06F9/5011Allocation of resources, e.g. of the central processing unit [CPU] to service a request the resources being hardware resources other than CPUs, Servers and Terminals
    • G06F9/5016Allocation of resources, e.g. of the central processing unit [CPU] to service a request the resources being hardware resources other than CPUs, Servers and Terminals the resource being the memory
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F12/00Accessing, addressing or allocating within memory systems or architectures
    • G06F12/02Addressing or allocation; Relocation
    • G06F12/0223User address space allocation, e.g. contiguous or non contiguous base addressing
    • G06F12/023Free address space management
    • G06F12/0253Garbage collection, i.e. reclamation of unreferenced memory

Abstract

本公开提供了一种预读方法及装置,属于终端技术领域。所述方法包括:获取内存状态信息,所述内存状态信息用于指示终端内存的使用情况;根据所述内存状态信息,从内存状态信息与预读数据大小的对应关系中,确定目标数据大小;按照所述目标数据大小,进行预读操作。本公开通过对内存状态进行实时获取,以获知终端内存的实际使用情况,由于该实际使用情况可以反映更精确的系统状态,因此,根据这种实际使用状态所确定的预读数据大小,可以有利的指导后续预读操作,使得预读操作能够不对系统内存造成负担,能够更适应于终端的实际运行,在加快应用运行速度的同时,保证了终端的正常运行。

Description

预读方法及装置
技术领域
本公开涉及终端技术领域,尤其涉及一种预读方法及装置。
背景技术
随着终端技术的发展,终端上可以安装的应用越来越多,对于一个终端来说,其上所安装的应用的运行速度是用于衡量终端性能的一个重要指标。
为了提高应用的运行速度,相关技术在应用运行过程中经常会采用预读的方式,数据预读是指为应用程序一次读出比预期更多的数据,并缓存在内存中。这样,下一次读请求到来时,部分数据可以直接从内存读取,有效的减少应用的读写等待时间,加快了应用的运行速度。
发明内容
为克服相关技术中存在的问题,本公开提供一种预读方法及装置。
根据本公开实施例的第一方面,提供一种预读方法,包括:
获取内存状态信息,所述内存状态信息用于指示终端内存的使用情况;根据所述内存状态信息,从内存状态信息与预读数据大小的对应关系中,确定目标数据大小;按照所述目标数据大小,进行预读操作。
本公开所提供的技术方案,通过对内存状态进行实时获取,以获知终端内存的实际使用情况,由于该实际使用情况可以反映更精确的系统状态,因此,根据这种实际使用状态所确定的预读数据大小,可以有利的指导后续预读操作,使得预读操作能够不对系统内存造成负担,能够更适应于终端的实际运行,在加快应用运行速度的同时,保证了终端的正常运行。
在第一方面的第一种可能实现方式中,所述获取内存状态信息包括:获取单位时间内终端内存的平均剩余数、平均回收数以及平均被清除数中至少一项数值;对获取到的至少一项数值进行归一化,得到至少一项归一化参数;基于所述至少一项归一化参数,计算所述内存状态信息。通过对上述至少一项数值的统计,使得能够更准确的衡量终端内存的实际使用情况,从而达到在加快应用运行速度的同时,保证了终端的正常运行的目的。
在第一方面的第二种可能实现方式中,基于所述至少一项归一化参数,计算所述内存状态信息包括:所述至少一项归一化参数均为百分比数值,则应用以下公式计算内存状态信息:
S=(100/(a*W1+b*W2+c*W3))/3;
其中,S为内存状态信息的取值,a为终端内存的平均剩余数的归一化参数,W1为终端内存的平均剩余数的权重,b为终端内存的平均回收数的归一化参数,W2为终端内存的平均回收数的权重,c为终端内存的平均被清除数的归一化参数,W3为终端内存的平均被清除数的权重。
在第一方面的第三种可能实现方式中,按照所述目标数据大小,进行预读操作之后,所述方法还包括:检测终端的运行性能;当按照所述内存状态信息与预读数据大小的对应关系进行预读操作导致所述运行性能下降时,对所述内存状态信息与预读数据大小的对应关系进行调整。
在第一方面的第四种可能实现方式中,所述获取内存状态信息包括:每隔预设时间段,获取所述预设时间段内的内存状态信息。
根据本公开实施例的第二方面,提供一种预读装置,所述装置包括:
获取模块,用于获取内存状态信息,所述内存状态信息用于指示终端内存的使用情况;
确定模块,用于根据所述内存状态信息,从内存状态信息与预读数据大小的对应关系中,确定目标数据大小;
预读模块,用于按照所述目标数据大小,进行预读操作。
在第二方面的第一种可能实现方式中,所述获取模块用于获取单位时间内终端内存的平均剩余数、平均回收数以及平均被清除数中至少一项数值;对获取到的至少一项数值进行归一化,得到至少一项归一化参数;基于所述至少一项归一化参数,计算所述内存状态信息。
在第二方面的第二种可能实现方式中,所述获取模块用于当所述至少一项归一化参数均为百分比数值,则应用以下公式计算内存状态信息:
S=(100/(a*W1+b*W2+c*W3))/3;
其中,S为内存状态信息的取值,a为终端内存的平均剩余数的归一化参数,W1为终端内存的平均剩余数的权重,b为终端内存的平均回收数的归一化参数,W2为终端内存的平均回收数的权重,c为终端内存的平均被清除数的归一化参数,W3为终端内存的平均被清除数的权重。
在第二方面的第三种可能实现方式中,所述装置还包括:
检测模块,用于检测终端的运行性能;
调整模块,用于当按照所述内存状态信息与预读数据大小的对应关系进行预读操作导致所述运行性能下降时,对所述内存状态信息与预读数据大小的对应关系进行调整。
在第二方面的第四种可能实现方式中,所述获取模块用于每隔预设时间段,获取所述预设时间段内的内存状态信息。
根据本公开实施例的第三方面,提供一种预读装置,其特征在于,包括:
处理器;
用于存储处理器可执行的指令的存储器;
其中,所述处理器被配置为:
获取内存状态信息,所述内存状态信息用于指示终端内存的使用情况;
根据所述内存状态信息,从内存状态信息与预读数据大小的对应关系中,确定目标数据大小;
按照所述目标数据大小,进行预读操作。
本公开所提供的技术方案,通过对内存状态进行实时获取,以获知终端内存的实际使用情况,由于该实际使用情况可以反映更精确的系统状态,因此,根据这种实际使用状态所确定的预读数据大小,可以有利的指导后续预读操作,使得预读操作能够不对系统内存造成负担,能够更适应于终端的实际运行,在加快应用运行速度的同时,保证了终端的正常运行。
应当理解的是,以上的一般描述和后文的细节描述仅是示例性和解释性的,并不能限制本公开。
附图说明
此处的附图被并入说明书中并构成本说明书的一部分,示出了符合本公开的实施例,并与说明书一起用于解释本公开的原理。
图1是根据一示例性实施例示出的一种预读方法的流程图。
图2是根据一示例性实施例示出的一种预读方法的流程图。
图3是根据一示例性实施例示出的不同周期中预读数据大小变化的示意图。
图4是根据一示例性实施例示出的一种预读装置框图。
图5是根据一示例性实施例示出的另一种预读装置框图。
图6是根据一示例性实施例示出的一种预读装置的框图。
具体实施方式
为使本公开的目的、技术方案和优点更加清楚,下面将结合附图对本公开实施方式作进一步地详细描述。
这里将详细地对示例性实施例进行说明,其示例表示在附图中。下面的描述涉及附图时,除非另有表示,不同附图中的相同数字表示相同或相似的要素。以下示例性实施例中所描述的实施方式并不代表与本公开相一致的所有实施方式。相反,它们仅是与如所附权利要求书中所详述的、本公开的一些方面相一致的装置和方法的例子。
图1是根据一示例性实施例示出的一种预读方法的流程图,如图1所示,该预读方法用于终端中,包括以下步骤。
在步骤101中,获取内存状态信息,所述内存状态信息用于指示终端内存的使用情况。
在步骤102中,根据所述内存状态信息,从内存状态信息与预读数据大小的对应关系中,确定目标数据大小。
在步骤103中,按照所述目标数据大小,进行预读操作。
本公开所提供的技术方案,通过对内存状态进行实时获取,以获知终端内存的实际使用情况,由于该实际使用情况可以反映更精确的系统状态,因此,根据这种实际使用状态所确定的预读数据大小,可以有利的指导后续预读操作,使得预读操作能够不对系统内存造成负担,能够更适应于终端的实际运行,在加快应用运行速度的同时,保证了终端的正常运行。
上述所有可选技术方案,可以采用任意结合形成本公开的可选实施例,在此不再一一赘述。
图2是根据一示例性实施例示出的一种预读方法的流程图,如图2所示,该预读方法用于终端中,包括以下步骤。
在步骤201中,获取单位时间内终端内存的平均剩余数、平均回收数以及平均被清除数。
对于终端来说,在终端运行过程中,会在发生读写操作时,对剩余数、回收数以及被清除数进行统计,如,回收一个物理页面,则对回收数中加1,清除一个物理页面,则对被清除数加1。
其中,该单位时间可以由系统默认设置,例如,设置为1个小时或者半个小时等,本公开实施例对此不作限定。
在步骤202中,对获取到的至少一项数值进行归一化,得到至少一项归一化参数。
该归一化过程可以包括:将单位时间内终端内存的平均剩余数除以终端内存总容量,将得到的百分比数值作为归一化参数。例如,平均剩余数为1000个物理页面,内存总容量为5000个物理页面,则该得到的百分比为20%,将其中的百分比数值20作为该平均剩余数的归一化参数。
对于平均回收数和平均被清除数来说,该归一化过程可以有以下内容:将单位时间内终端内存的平均回收数除以终端内存总容量,将得到的百分比数值作为该平均回收数的归一化参数。将单位时间内终端内存的平均被清除数除以终端内存总容量,将得到的百分比数值作为该平均被清除数的归一化参数。
在步骤203中,基于该至少一项归一化参数,计算该内存状态信息。
在该步骤203中,如果该至少一项归一化参数均为百分比数值,则应用公式:S=(100/(a*W1+b*W2+c*W3))/3;
其中,S为内存状态信息的取值,a为终端内存的平均剩余数的归一化参数,W1为终端内存的平均剩余数的权重,b为终端内存的平均回收数的归一化参数,W2为终端内存的平均回收数的权重,c为终端内存的平均被清除数的归一化参数,W3为终端内存的平均被清除数的权重。其中,“*”可以用于表示乘法运算。
其中,不同参数的权重可以由终端系统默认设置,还可以由终端根据自身运行情况进行调整,本公开不做具体限定。
上述步骤201至203位获取内存状态信息的过程,该内存状态信息用于指示终端内存的使用情况,该过程可以每隔预设时间段进行,也即是周期性进行,由于内存的使用情况可能随着用户对终端的使用发生变化,在每个周期内,获取该周期内的内存状态信息,以便后续根据该周期内的内存状态信息,获知本周期内的终端内存使用情况,从而对下一周期内预读操作的预读大小进行调整。
需要说明的是,上述实施例仅以基于上述三个参数均获取内存状态信息为例进行说明,而事实上,在其他实施例中,还可以基于上述三个参数中的一个参数或多个参数的组合进行内存状态信息的获取,而在应用公式进行计算的过程中,如果仅基于某一个或某两个参数进行计算时,可以将未参与计算的其他参数置为0,不会影响到对内存状态信息的计算。
在步骤204中,根据该内存状态信息,从内存状态信息与预读数据大小的对应关系中,确定目标数据大小。
该内存状态信息与预读数据大小的对应关系可以由技术人员预先设置于终端系统中,或是设置于服务器中,由终端从服务器获取,该具体获取时机可以是在终端进行系统更新时获取,或是由终端在任一时刻获取,当然,还可以由服务器主动向终端推送该对应关系,以使得终端能够及时修改设置,以采用更好的预读方式。
如图3所示,在终端实际运行过程中,不同周期内可能会对应于不同的预读数据大小,正是应用这样预读数据大小随着终端的内存使用情况的变化而变化的机制,使得终端的预读不会干扰到终端的实际运行,不仅能够实现预读对应用运行速度的提升,还能够避免对终端其他应用正常运行的影响。
需要说明的是,内存状态信息与预读数据大小的对应关系,可以是分段对应的关系,也即是,当内存状态信息处于某一数值范围内,则对应于某一预读数据大小,而内存状态信息处于另一数值范围内,则对应于另一预读数值大小。例如,当内存状态信息处于(10,20]内,则预读数据大小为A1,而当内存状态信息处于(20,30]内,则预读数据大小为A2,以此类推,其具体数值对应关系可以由技术人员进行设置,本公开具体不做限定。
例如,以常用的预读数据大小为512KB为例,对于不同内存状态信息取值所对应的预读数据大小可以如下表1所示:
表1
通过上述表1可以获知,在不同内存使用情况下,可以应用不同预读数据大小进行预读操作,以减轻内存负担。上述表1中所举例的数据,仅为示例性举例,该内存状态信息与预读数据大小的对应关系可以不受上表数据的限制,而是由技术人员通过对不同机型终端在不同内存使用情况下的实验过程,得出该对应关系,本公开对此不作具体限定。
需要说明的是,不同机型终端可以具有不同的内存状态信息与预读数据大小的对应关系,终端可以根据自身机型从服务器获取,或是由技术人员提前根据该终端机型配置于终端系统中。
在步骤205中,按照该目标数据大小,进行预读操作。
在根据内存状态信息确定了目标数据大小后,当再次检测到读操作时,可以按照该目标数据大小进行预读操作,例如,在预读时读出与目标数据大小相同数量的文件数据。
在另一实施例中,还可以根据终端的实际性能,对内存状态信息与预读数据大小的对应关系进行调整。该运行性能可以是指基于终端的运行参数如下载速度、应用加载速度等等综合考虑的性能。该方法可以包括:检测终端的运行性能;当按照该内存状态信息与预读数据大小的对应关系进行预读操作导致该运行性能下降,对该内存状态信息与预读数据大小的对应关系进行调整。
如果运行性能有所下降,则可能是内存状态信息与预读数据大小的对应关系的设置不合理,因此,可以通过将内存状态信息所对应的预读数据大小减小的方式,调整该对应关系,该减小可以是以递减的方式进行,如先从各个预读数据大小中减小预设大小,再进行运行性能的检测,如果性能仍然不能够达到预设标准,则再减小预设大小,以此类推,直到性能能够维持在预设标准上停止减小。其中,该预设大小可以由系统默认设置,本公开实施例对此不作限定。
本公开所提供的技术方案,通过对内存状态进行实时获取,以获知终端内存的实际使用情况,由于该实际使用情况可以反映更精确的系统状态,因此,根据这种实际使用状态所确定的预读数据大小,可以有利的指导后续预读操作,使得预读操作能够不对系统内存造成负担,能够更适应于终端的实际运行,在加快应用运行速度的同时,保证了终端的正常运行。
图4是根据一示例性实施例示出的一种预读装置框图。参照图4,该装置包括获取模块401,确定模块402和预读模块403。
获取模块401,用于获取内存状态信息,所述内存状态信息用于指示终端内存的使用情况;
确定模块402,用于根据所述内存状态信息,从内存状态信息与预读数据大小的对应关系中,确定目标数据大小;
预读模块403,用于按照所述目标数据大小,进行预读操作。
在另一实施例中,所述获取模块401用于获取单位时间内终端内存的平均剩余数、平均回收数以及平均被清除数中至少一项数值;对获取到的至少一项数值进行归一化,得到至少一项归一化参数;基于所述至少一项归一化参数,计算所述内存状态信息。
在另一实施例中,所述获取模块401用于当所述至少一项归一化参数均为百分比数值,则应用公式:
S=(100/(a*W1+b*W2+c*W3))/3;
其中,S为内存状态信息的取值,a为终端内存的平均剩余数的归一化参数,W1为终端内存的平均剩余数的权重,b为终端内存的平均回收数的归一化参数,W2为终端内存的平均回收数的权重,c为终端内存的平均被清除数的归一化参数,W3为终端内存的平均被清除数的权重。
在另一实施例中,参见图5,基于图4已有的架构,所述装置还包括:
检测模块404,用于检测终端的运行性能;
调整模块405,用于当按照所述内存状态信息与预读数据大小的对应关系进行预读操作导致所述运行性能下降时,对所述内存状态信息与预读数据大小的对应关系进行调整。
在另一实施例中,所述获取模块401用于每隔预设时间段,获取所述预设时间段内的内存状态信息。
关于上述实施例中的装置,其中各个模块执行操作的具体方式已经在有关该方法的实施例中进行了详细描述,此处将不做详细阐述说明。
图6是根据一示例性实施例示出的一种预读装置600的框图。例如,装置600可以是移动电话,计算机,数字广播终端,消息收发设备,游戏控制台,平板设备,医疗设备,健身设备,个人数字助理等。
参照图6,装置600可以包括以下一个或多个组件:处理组件602,存储器604,电源组件606,多媒体组件608,音频组件610,输入/输出(I/O)的接口612,传感器组件614,以及通信组件616。
处理组件602通常控制装置600的整体操作,诸如与显示,电话呼叫,数据通信,相机操作和记录操作相关联的操作。处理组件602可以包括一个或多个处理器620来执行指令,以完成上述的方法的全部或部分步骤。此外,处理组件602可以包括一个或多个模块,便于处理组件602和其他组件之间的交互。例如,处理组件602可以包括多媒体模块,以方便多媒体组件608和处理组件602之间的交互。
存储器604被配置为存储各种类型的数据以支持在装置600的操作。这些数据的示例包括用于在装置600上操作的任何应用程序或方法的指令,联系人数据,电话簿数据,消息,图片,视频等。存储器604可以由任何类型的易失性或非易失性存储设备或者它们的组合实现,如静态随机存取存储器(SRAM),电可擦除可编程只读存储器(EEPROM),可擦除可编程只读存储器(EPROM),可编程只读存储器(PROM),只读存储器(ROM),磁存储器,快闪存储器,磁盘或光盘。
电源组件606为装置600的各种组件提供电力。电源组件606可以包括电源管理系统,一个或多个电源,及其他与为装置600生成、管理和分配电力相关联的组件。
多媒体组件608包括在所述装置600和用户之间的提供一个输出接口的屏幕。在一些实施例中,屏幕可以包括液晶显示器(LCD)和触摸面板(TP)。如果屏幕包括触摸面板,屏幕可以被实现为触摸屏,以接收来自用户的输入信号。触摸面板包括一个或多个触摸传感器以感测触摸、滑动和触摸面板上的手势。所述触摸传感器可以不仅感测触摸或滑动动作的边界,而且还检测与所述触摸或滑动操作相关的持续时间和压力。在一些实施例中,多媒体组件608包括一个前置摄像头和/或后置摄像头。当装置600处于操作模式,如拍摄模式或视频模式时,前置摄像头和/或后置摄像头可以接收外部的多媒体数据。每个前置摄像头和后置摄像头可以是一个固定的光学透镜系统或具有焦距和光学变焦能力。
音频组件610被配置为输出和/或输入音频信号。例如,音频组件610包括一个麦克风(MIC),当装置600处于操作模式,如呼叫模式、记录模式和语音识别模式时,麦克风被配置为接收外部音频信号。所接收的音频信号可以被进一步存储在存储器604或经由通信组件616发送。在一些实施例中,音频组件610还包括一个扬声器,用于输出音频信号。
I/O接口612为处理组件602和外围接口模块之间提供接口,上述外围接口模块可以是键盘,点击轮,按钮等。这些按钮可包括但不限于:主页按钮、音量按钮、启动按钮和锁定按钮。
传感器组件614包括一个或多个传感器,用于为装置600提供各个方面的状态评估。例如,传感器组件614可以检测到设备600的打开/关闭状态,组件的相对定位,例如所述组件为装置600的显示器和小键盘,传感器组件614还可以检测装置600或装置600一个组件的位置改变,用户与装置600接触的存在或不存在,装置600方位或加速/减速和装置600的温度变化。传感器组件614可以包括接近传感器,被配置用来在没有任何的物理接触时检测附近物体的存在。传感器组件614还可以包括光传感器,如CMOS或CCD图像传感器,用于在成像应用中使用。在一些实施例中,该传感器组件614还可以包括加速度传感器,陀螺仪传感器,磁传感器,压力传感器或温度传感器。
通信组件616被配置为便于装置600和其他设备之间有线或无线方式的通信。装置600可以接入基于通信标准的无线网络,如WiFi,2G或3G,或它们的组合。在一个示例性实施例中,通信部件616经由广播信道接收来自外部广播管理系统的广播信号或广播相关信息。在一个示例性实施例中,所述通信部件616还包括近场通信(NFC)模块,以促进短程通信。例如,在NFC模块可基于射频识别(RFID)技术,红外数据协会(IrDA)技术,超宽带(UWB)技术,蓝牙(BT)技术和其他技术来实现。
在示例性实施例中,装置600可以被一个或多个应用专用集成电路(ASIC)、数字信号处理器(DSP)、数字信号处理设备(DSPD)、可编程逻辑器件(PLD)、现场可编程门阵列(FPGA)、控制器、微控制器、微处理器或其他电子元件实现,用于执行上述预读方法。
在示例性实施例中,还提供了一种包括指令的非临时性计算机可读存储介质,例如包括指令的存储器604,上述指令可由装置600的处理器620执行以完成上述方法。例如,所述非临时性计算机可读存储介质可以是ROM、随机存取存储器(RAM)、CD-ROM、磁带、软盘和光数据存储设备等。
在示例性实施例中,还提供了一种非临时性计算机可读存储介质,当所述存储介质中的指令由移动终端的处理器执行时,使得移动终端能够执行上述预读方法。
本领域技术人员在考虑说明书及实践这里公开的发明后,将容易想到本公开的其它实施方案。本申请旨在涵盖本公开的任何变型、用途或者适应性变化,这些变型、用途或者适应性变化遵循本公开的一般性原理并包括本公开未公开的本技术领域中的公知常识或惯用技术手段。说明书和实施例仅被视为示例性的,本公开的真正范围和精神由下面的权利要求指出。
应当理解的是,本公开并不局限于上面已经描述并在附图中示出的精确结构,并且可以在不脱离其范围进行各种修改和改变。本公开的范围仅由所附的权利要求来限制。

Claims (11)

1.一种预读方法,其特征在于,所述方法包括:
获取内存状态信息,所述内存状态信息用于指示终端内存的使用情况;
根据所述内存状态信息,从内存状态信息与预读数据大小的对应关系中,确定目标数据大小;
按照所述目标数据大小,进行预读操作。
2.根据权利要求1所述的方法,其特征在于,所述获取内存状态信息包括:
获取单位时间内终端内存的平均剩余数、平均回收数以及平均被清除数中至少一项数值;
对获取到的至少一项数值进行归一化,得到至少一项归一化参数;
基于所述至少一项归一化参数,计算所述内存状态信息。
3.根据权利要求2所述的方法,其特征在于,基于所述至少一项归一化参数,计算所述内存状态信息包括:
所述至少一项归一化参数均为百分比数值,则应用以下公式计算内存状态信息:
S=(100/(a*W1+b*W2+c*W3))/3;
其中,S为内存状态信息的取值,a为终端内存的平均剩余数的归一化参数,W1为终端内存的平均剩余数的权重,b为终端内存的平均回收数的归一化参数,W2为终端内存的平均回收数的权重,c为终端内存的平均被清除数的归一化参数,W3为终端内存的平均被清除数的权重。
4.根据权利要求3所述的方法,其特征在于,按照所述目标数据大小,进行预读操作之后,所述方法还包括:
检测终端的运行性能;
当按照所述内存状态信息与预读数据大小的对应关系进行预读操作导致所述运行性能下降时,对所述内存状态信息与预读数据大小的对应关系进行调整。
5.根据权利要求1所述的方法,其特征在于,所述获取内存状态信息包括:
每隔预设时间段,获取所述预设时间段内的内存状态信息。
6.一种预读装置,其特征在于,所述装置包括:
获取模块,用于获取内存状态信息,所述内存状态信息用于指示终端内存的使用情况;
确定模块,用于根据所述内存状态信息,从内存状态信息与预读数据大小的对应关系中,确定目标数据大小;
预读模块,用于按照所述目标数据大小,进行预读操作。
7.根据权利要求6所述的装置,其特征在于,所述获取模块用于获取单位时间内终端内存的平均剩余数、平均回收数以及平均被清除数中至少一项数值;对获取到的至少一项数值进行归一化,得到至少一项归一化参数;基于所述至少一项归一化参数,计算所述内存状态信息。
8.根据权利要求7所述的装置,其特征在于,所述获取模块用于当所述至少一项归一化参数均为百分比数值,则应用以下公式计算内存状态信息:
S=(100/(a*W1+b*W2+c*W3))/3;
其中,S为内存状态信息的取值,a为终端内存的平均剩余数的归一化参数,W1为终端内存的平均剩余数的权重,b为终端内存的平均回收数的归一化参数,W2为终端内存的平均回收数的权重,c为终端内存的平均被清除数的归一化参数,W3为终端内存的平均被清除数的权重。
9.根据权利要求8所述的装置,其特征在于,所述装置还包括:
检测模块,用于检测终端的运行性能;
调整模块,用于当按照所述内存状态信息与预读数据大小的对应关系进行预读操作导致所述运行性能下降时,对所述内存状态信息与预读数据大小的对应关系进行调整。
10.根据权利要求6所述的装置,其特征在于,所述获取模块用于每隔预设时间段,获取所述预设时间段内的内存状态信息。
11.一种预读装置,其特征在于,包括:
处理器;
用于存储处理器可执行的指令的存储器;
其中,所述处理器被配置为:
获取内存状态信息,所述内存状态信息用于指示终端内存的使用情况;
根据所述内存状态信息,从内存状态信息与预读数据大小的对应关系中,确定目标数据大小;
按照所述目标数据大小,进行预读操作。
CN201610252019.4A 2016-04-21 2016-04-21 预读方法及装置 Active CN105955821B (zh)

Priority Applications (1)

Application Number Priority Date Filing Date Title
CN201610252019.4A CN105955821B (zh) 2016-04-21 2016-04-21 预读方法及装置

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
CN201610252019.4A CN105955821B (zh) 2016-04-21 2016-04-21 预读方法及装置

Publications (2)

Publication Number Publication Date
CN105955821A true CN105955821A (zh) 2016-09-21
CN105955821B CN105955821B (zh) 2020-01-10

Family

ID=56915010

Family Applications (1)

Application Number Title Priority Date Filing Date
CN201610252019.4A Active CN105955821B (zh) 2016-04-21 2016-04-21 预读方法及装置

Country Status (1)

Country Link
CN (1) CN105955821B (zh)

Cited By (4)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN111309257A (zh) * 2020-02-10 2020-06-19 西安奥卡云数据科技有限公司 恒定速率读文件的预读方法、装置及计算机可读存储介质
CN111930513A (zh) * 2020-08-31 2020-11-13 Oppo(重庆)智能科技有限公司 文件预读的调整方法、装置、电子设备及存储介质
CN112558866A (zh) * 2020-12-03 2021-03-26 Oppo(重庆)智能科技有限公司 数据的预读方法、移动终端及计算机可读存储介质
CN114390072A (zh) * 2021-12-17 2022-04-22 武汉慧联无限科技有限公司 一种信息处理方法、装置及存储介质

Citations (5)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN101814038A (zh) * 2010-03-23 2010-08-25 杭州顺网科技股份有限公司 一种加快计算机启动速度的方法
CN102479155A (zh) * 2010-11-30 2012-05-30 国际商业机器公司 用于网络应用服务器系统的内存过载管理的方法和系统
CN102521349A (zh) * 2011-12-12 2012-06-27 深圳市创新科信息技术有限公司 一种文件预读方法
US8359438B2 (en) * 2010-05-18 2013-01-22 Avago Technologies Enterprise IP (Singapore) Pte. Ltd. Memory banking system and method to increase memory bandwidth via parallel read and write operations
CN103795781A (zh) * 2013-12-10 2014-05-14 西安邮电大学 一种基于文件预测的分布式缓存模型

Patent Citations (5)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN101814038A (zh) * 2010-03-23 2010-08-25 杭州顺网科技股份有限公司 一种加快计算机启动速度的方法
US8359438B2 (en) * 2010-05-18 2013-01-22 Avago Technologies Enterprise IP (Singapore) Pte. Ltd. Memory banking system and method to increase memory bandwidth via parallel read and write operations
CN102479155A (zh) * 2010-11-30 2012-05-30 国际商业机器公司 用于网络应用服务器系统的内存过载管理的方法和系统
CN102521349A (zh) * 2011-12-12 2012-06-27 深圳市创新科信息技术有限公司 一种文件预读方法
CN103795781A (zh) * 2013-12-10 2014-05-14 西安邮电大学 一种基于文件预测的分布式缓存模型

Cited By (7)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN111309257A (zh) * 2020-02-10 2020-06-19 西安奥卡云数据科技有限公司 恒定速率读文件的预读方法、装置及计算机可读存储介质
CN111930513A (zh) * 2020-08-31 2020-11-13 Oppo(重庆)智能科技有限公司 文件预读的调整方法、装置、电子设备及存储介质
CN111930513B (zh) * 2020-08-31 2023-02-28 Oppo(重庆)智能科技有限公司 文件预读的调整方法、装置、电子设备及存储介质
CN112558866A (zh) * 2020-12-03 2021-03-26 Oppo(重庆)智能科技有限公司 数据的预读方法、移动终端及计算机可读存储介质
CN112558866B (zh) * 2020-12-03 2022-12-09 Oppo(重庆)智能科技有限公司 数据的预读方法、移动终端及计算机可读存储介质
CN114390072A (zh) * 2021-12-17 2022-04-22 武汉慧联无限科技有限公司 一种信息处理方法、装置及存储介质
CN114390072B (zh) * 2021-12-17 2023-09-29 武汉慧联无限科技有限公司 一种信息处理方法、装置及存储介质

Also Published As

Publication number Publication date
CN105955821B (zh) 2020-01-10

Similar Documents

Publication Publication Date Title
CN107786743A (zh) 防止终端误触的方法及装置
CN104267877B (zh) 表情图片的显示方法及装置、电子设备
CN105955821A (zh) 预读方法及装置
CN105991930A (zh) 双摄像头的变焦处理方法、装置和移动终端
CN107155060A (zh) 图像处理方法及装置
CN106033397A (zh) 内存缓冲区调整方法、装置及终端
CN105956837A (zh) 红包发放方法及装置
CN107766820A (zh) 图像分类方法及装置
CN105912450A (zh) 应用的状态信息显示方法及装置
CN108898591A (zh) 图像质量的评分方法及装置、电子设备、可读存储介质
CN106557755A (zh) 指纹模板获取方法及装置
CN107493421A (zh) 摄像头模组、电子设备、摄像头模组控制方法及装置
CN109255128A (zh) 多层级标签的生成方法、装置和存储介质
CN107678934A (zh) 卡顿指标获取方法及装置
CN105913569A (zh) 电量管理方法和装置
CN105487758A (zh) 应用软件弹窗控制方法、装置和终端设备
CN106875106A (zh) 送货方法及装置
CN104539846B (zh) 拍摄图片的方法、装置及终端
CN105551047A (zh) 图片内容的检测方法和装置
CN105931187A (zh) 图像处理方法及装置
CN106295468A (zh) 人脸识别方法及装置
CN104408130B (zh) 图片整理的方法及装置
CN107357643A (zh) 应用调用方法、装置及计算机可读存储介质
CN106201709A (zh) 资源显示方法及装置
CN107463833A (zh) Web应用的校验方法及装置

Legal Events

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