资源访问方法及装置与流程

文档序号:12469689阅读:213来源:国知局
资源访问方法及装置与流程

本发明涉及系统资源访问技术领域,尤其涉及一种资源访问方法及装置。



背景技术:

目前,在终端系统中,数据一致性访问是一个非常重要的部分,通常可以采用锁机制实现数据的一致性访问。在移动终端访问共享数据时,比如在进行垃圾文件扫描时,首先访问锁资源,在获取锁资源的前提下才能实现数据的访问。比如操作同一个文件,首先访问一个全局的变量(锁),通过全局变量的状态来控制线程对资源的访问。但是,随着移动终端的存储控件越来越大,CPU的核数量增多,数据量急剧增加,采用锁机制实现数据访问的一致性存在效率低的问题。



技术实现要素:

本发明的主要目的在于提出一种资源访问方法及装置,旨在提高对系统共享资源的访问速度,使得共享资源的控制更加灵活。

为实现上述目的,本发明提供的一种资源访问装置,包括:

接收模块,用于接收对系统共享资源的访问操作申请,所述访问操作申请的类型包括读操作和写操作;

判断模块,用于若当前访问操作申请的类型为读操作类型,则判断申请访问的系统共享资源是否处于约束期;

读操作模块,用于若申请访问的系统共享资源处于约束期,则对所述系统共享资源的副本进行读操作,否则,对所述系统共享资源的原版本进行读操作。

可选地,所述装置还包括:

写操作模块,用于若当前访问操作申请的类型为写操作类型,则为所述系统共享资源建立副本,对所述副本进行修改,并为所述副本设立约束期。

可选地,所述写操作模块,还用于判断对所述系统共享资源的所有读操作是否结束;若对所述系统共享资源的所有读操作结束,则为所述系统共享 资源建立副本,对所述副本进行修改。

可选地,所述装置还包括:

解除回收模块,用于在所述读操作模块对所述系统共享资源的副本进行读操作结束后,解除所述系统共享资源的约束期,并回收所述系统共享资源的原版本。

可选地,所述装置还包括:

解除回收模块,用于在对所述系统共享资源的副本进行读操作结束前,判断所述系统共享资源的约束期是否达到阈值;若所述系统共享资源的约束期达到阈值,则强制解除所述系统共享资源的约束期,并回收所述系统共享资源的原版本。

本发明实施例还提出一种资源访问方法,包括:

接收对系统共享资源的访问操作申请,所述访问操作申请的类型包括读操作和写操作;

若当前访问操作申请的类型为读操作类型,则判断申请访问的系统共享资源是否处于约束期;

若申请访问的系统共享资源处于约束期,则对所述系统共享资源的副本进行读操作,否则,对所述系统共享资源的原版本进行读操作。

可选地,所述接收对系统共享资源的访问操作申请的步骤之后,还包括:

若当前访问操作申请的类型为写操作类型,则为所述系统共享资源建立副本,对所述副本进行修改,并为所述副本设立约束期。

可选地,若当前访问操作申请的类型为写操作类型,则在为所述系统共享资源建立副本,对所述副本进行修改的步骤之前还包括:

判断对所述系统共享资源的所有读操作是否结束;

若对所述系统共享资源的所有读操作结束,则执行步骤:为所述系统共享资源建立副本,对所述副本进行修改。

可选地,所述若申请访问的系统共享资源处于约束期,则对所述系统共享资源的副本进行读操作的步骤之后,还包括:

在对所述系统共享资源的副本进行读操作结束后,解除所述系统共享资源的约束期,并回收所述系统共享资源的原版本。

可选地,所述若申请访问的系统共享资源处于约束期,则对所述系统共享资源的副本进行读操作的步骤之后,还包括:

在对所述系统共享资源的副本进行读操作结束前,判断所述系统共享资源的约束期是否达到阈值;

若所述系统共享资源的约束期达到阈值,则强制解除所述系统共享资源的约束期,并回收所述系统共享资源的原版本。

本发明提出的一种资源访问方法及装置,在接收到对系统共享资源的访问操作申请时,若当前访问操作申请的类型为读操作类型,则判断申请访问的系统共享资源是否处于约束期;若申请访问的系统共享资源处于约束期,则对所述系统共享资源的副本进行读操作,否则,对所述系统共享资源的原版本进行读操作;此外,对于写操作,其需要将原来的老数据作一次备份,然后对备份数据进行修改,修改完毕之后,且老数据约束期解除后再实现老数据资源的回收。由此,通过采用副本机制替代现有的锁机制,保证在读写操作共享资源时,基本不需要取锁操作,在一定程度上提升共享资源的访问速度,从而节省数据扫描时间,对共享资源的控制也更加灵活。

附图说明

图1是实现本发明各个实施例的一个可选的移动终端的硬件结构示意图;

图2是如图1所示的移动终端的无线通信系统示意图;

图3是本发明资源访问装置第一实施例的模块示意图;

图4是本发明资源访问装置第二实施例的模块示意图;

图5是本发明资源访问装置第三实施例的模块示意图;

图6是本发明资源访问方法第一实施例的流程示意图;

图7是本发明资源访问方法第二实施例的流程示意图;

图8是本发明资源访问方法第三实施例的流程示意图;

图9是本发明实施例中一种具体的资源访问流程示意图。

本发明目的的实现、功能特点及优点将结合实施例,参照附图做进一步说明。

具体实施方式

应当理解,此处所描述的具体实施例仅仅用以解释本发明,并不用于限定本发明。

本发明实施例方案涉及终端系统资源的共享,其中涉及的终端可以是PC等固定终端,也可以指移动终端,本发明实施例以移动终端进行举例,但并不构成对终端的限制。

现在将参考附图描述实现本发明各个实施例的移动终端。在后续的描述中,使用用于表示元件的诸如“模块”、“部件”或“单元”的后缀仅为了有利于本发明的说明,其本身并没有特定的意义。因此,"模块"与"部件"可以混合地使用。

移动终端可以以各种形式来实施。例如,本发明中描述的终端可以包括诸如移动电话、智能电话、笔记本电脑、数字广播接收器、PDA(个人数字助理)、PAD(平板电脑)、PMP(便携式多媒体播放器)、导航装置等等的移动终端以及诸如数字TV、台式计算机等等的固定终端。下面,假设终端是移动终端。然而,本领域技术人员将理解的是,除了特别用于移动目的的元件之外,根据本发明的实施方式的构造也能够应用于固定类型的终端。

图1为实现本发明各个实施例的一个可选的移动终端的硬件结构示意图。

移动终端100可以包括无线通信单元110、用户输入单元130、输出单元150、存储器160、接口单元170、控制器180和电源单元190等等。图1示出了具有各种组件的移动终端,但是应理解的是,并不要求实施所有示出的组件。可以替代地实施更多或更少的组件。将在下面详细描述移动终端的元件。

无线通信单元110通常包括一个或多个组件,其允许移动终端100与无线通信系统或网络之间的无线电通信。例如,无线通信单元可以包括广播接收模块111、无线互联网模块113中的至少一个。

广播接收模块111经由广播信道从外部广播管理服务器接收广播信号和/或广播相关信息。广播信道可以包括卫星信道和/或地面信道。广播管理服务器可以是生成并发送广播信号和/或广播相关信息的服务器或者接收之前生成的广播信号和/或广播相关信息并且将其发送给终端的服务器。广播信号可以包括TV广播信号、无线电广播信号、数据广播信号等等。而且,广播信号可以进一步包括与TV或无线电广播信号组合的广播信号。广播相关信息也可以 经由移动通信网络提供,并且在该情况下,广播相关信息可以由移动通信模块112来接收。广播信号可以以各种形式存在,例如,其可以以数字多媒体广播(DMB)的电子节目指南(EPG)、数字视频广播手持(DVB-H)的电子服务指南(ESG)等等的形式而存在。广播接收模块111可以通过使用各种类型的广播系统接收信号广播。特别地,广播接收模块111可以通过使用诸如多媒体广播-地面(DMB-T)、数字多媒体广播-卫星(DMB-S)、数字视频广播-手持(DVB-H),前向链路媒体(MediaFLO@)的数据广播系统、地面数字广播综合服务(ISDB-T)等等的数字广播系统接收数字广播。广播接收模块111可以被构造为适合提供广播信号的各种广播系统以及上述数字广播系统。经由广播接收模块111接收的广播信号和/或广播相关信息可以存储在存储器160(或者其它类型的存储介质)中。

无线互联网模块113支持移动终端的无线互联网接入。该模块可以内部或外部地耦接到终端。该模块所涉及的无线互联网接入技术可以包括WLAN(无线LAN)(Wi-Fi)、Wibro(无线宽带)、Wimax(全球微波互联接入)、HSDPA(高速下行链路分组接入)等等。

用户输入单元130可以根据用户输入的命令生成键输入数据以控制移动终端的各种操作。用户输入单元130允许用户输入各种类型的信息,并且可以包括键盘、锅仔片、触摸板(例如,检测由于被接触而导致的电阻、压力、电容等等的变化的触敏组件)、滚轮、摇杆等等。特别地,当触摸板以层的形式叠加在显示单元151上时,可以形成触摸屏。

接口单元170用作至少一个外部装置与移动终端100连接可以通过的接口。例如,外部装置可以包括有线或无线头戴式耳机端口、外部电源(或电池充电器)端口、有线或无线数据端口、存储卡端口、用于连接具有识别模块的装置的端口、音频输入/输出(I/O)端口、视频I/O端口、耳机端口等等。识别模块可以是存储用于验证用户使用移动终端100的各种信息并且可以包括用户识别模块(UIM)、客户识别模块(SIM)、通用客户识别模块(USIM)等等。另外,具有识别模块的装置(下面称为"识别装置")可以采取智能卡的形式,因此,识别装置可以经由端口或其它连接装置与移动终端100连接。接口单元170可以用于接收来自外部装置的输入(例如,数据信息、电力等等)并且将接收到的输入传输到移动终端100内的一个或多个元件或者可以用于在移动终端和外部 装置之间传输数据。

另外,当移动终端100与外部底座连接时,接口单元170可以用作允许通过其将电力从底座提供到移动终端100的路径或者可以用作允许从底座输入的各种命令信号通过其传输到移动终端的路径。从底座输入的各种命令信号或电力可以用作用于识别移动终端是否准确地安装在底座上的信号。

输出单元150被构造为以视觉、音频和/或触觉方式提供输出信号(例如,音频信号、视频信号、警报信号、振动信号等等)。输出单元150可以包括显示单元151、音频输出模块152等。

显示单元151可以显示在移动终端100中处理的信息。例如,当移动终端100处于电话通话模式时,显示单元151可以显示与通话或其它通信(例如,文本消息收发、多媒体文件下载等等)相关的用户界面(UI)或图形用户界面(GUI)。当移动终端100处于视频通话模式或者图像捕获模式时,显示单元151可以显示捕获的图像和/或接收的图像、示出视频或图像以及相关功能的UI或GUI等等。

同时,当显示单元151和触摸板以层的形式彼此叠加以形成触摸屏时,显示单元151可以用作输入装置和输出装置。显示单元151可以包括液晶显示器(LCD)、薄膜晶体管LCD(TFT-LCD)、有机发光二极管(OLED)显示器、柔性显示器、三维(3D)显示器等等中的至少一种。这些显示器中的一些可以被构造为透明状以允许用户从外部观看,这可以称为透明显示器,典型的透明显示器可以例如为TOLED(透明有机发光二极管)显示器等等。根据特定想要的实施方式,移动终端100可以包括两个或更多显示单元(或其它显示装置),例如,移动终端可以包括外部显示单元(未示出)和内部显示单元(未示出)。触摸屏可用于检测触摸输入压力以及触摸输入位置和触摸输入面积。

音频输出模块152可以在移动终端处于呼叫信号接收模式、通话模式、记录模式、语音识别模式、广播接收模式等等模式下时,将无线通信单元110接收的或者在存储器160中存储的音频数据转换音频信号并且输出为声音。而且,音频输出模块152可以提供与移动终端100执行的特定功能相关的音频输出(例如,呼叫信号接收声音、消息接收声音等等)。音频输出模块152可以包括扬声器、蜂鸣器等等。

存储器160可以存储由控制器180执行的处理和控制操作的软件程序等 等,或者可以暂时地存储己经输出或将要输出的数据(例如,电话簿、消息、静态图像、视频等等)。而且,存储器160可以存储关于当触摸施加到触摸屏时输出的各种方式的振动和音频信号的数据。

存储器160可以包括至少一种类型的存储介质,所述存储介质包括闪存、硬盘、多媒体卡、卡型存储器(例如,SD或DX存储器等等)、随机访问存储器(RAM)、静态随机访问存储器(SRAM)、只读存储器(ROM)、电可擦除可编程只读存储器(EEPROM)、可编程只读存储器(PROM)、磁性存储器、磁盘、光盘等等。而且,移动终端100可以与通过网络连接执行存储器160的存储功能的网络存储装置协作。

控制器180通常控制移动终端的总体操作。例如,控制器180执行与语音通话、数据通信、视频通话等等相关的控制和处理。另外,控制器180可以包括用于再现(或回放)多媒体数据的多媒体模块1810,多媒体模块1810可以构造在控制器180内,或者可以构造为与控制器180分离。控制器180可以执行模式识别处理,以将在触摸屏上执行的手写输入或者图片绘制输入识别为字符或图像。

具体地,控制器180还可以包括:接收模块182,用于接收对系统共享资源的访问操作申请,所述访问操作申请的类型包括读操作和写操作;

判断模块183,用于若当前访问操作申请的类型为读操作类型,则判断申请访问的系统共享资源是否处于约束期;

读操作模块184,用于若申请访问的系统共享资源处于约束期,则对所述系统共享资源的副本进行读操作,否则,对所述系统共享资源的原版本进行读操作。

写操作模块185,用于若当前访问操作申请的类型为写操作类型,则为所述系统共享资源建立副本,对所述副本进行修改,并为所述副本设立约束期。

进一步地,所述写操作模块185,还用于判断对所述系统共享资源的所有读操作是否结束;若对所述系统共享资源的所有读操作结束,则为所述系统共享资源建立副本,对所述副本进行修改。

解除回收模块186,用于在所述读操作模块对所述系统共享资源的副本进行读操作结束后,解除所述系统共享资源的约束期,并回收所述系统共享资源的原版本。或者解除回收模块186,用于在对所述系统共享资源的副本进行 读操作结束前,判断所述系统共享资源的约束期是否达到阈值;若所述系统共享资源的约束期达到阈值,则强制解除所述系统共享资源的约束期,并回收所述系统共享资源的原版本。

电源单元190在控制器180的控制下接收外部电力或内部电力并且提供操作各元件和组件所需的适当的电力。

这里描述的各种实施方式可以以使用例如计算机软件、硬件或其任何组合的计算机可读介质来实施。对于硬件实施,这里描述的实施方式可以通过使用特定用途集成电路(ASIC)、数字信号处理器(DSP)、数字信号处理装置(DSPD)、可编程逻辑装置(PLD)、现场可编程门阵列(FPGA)、处理器、控制器、微控制器、微处理器、被设计为执行这里描述的功能的电子单元中的至少一种来实施,在一些情况下,这样的实施方式可以在控制器180中实施。对于软件实施,诸如过程或功能的实施方式可以与允许执行至少一种功能或操作的单独的软件模块来实施。软件代码可以由以任何适当的编程语言编写的软件应用程序(或程序)来实施,软件代码可以存储在存储器160中并且由控制器180执行。

如图1中所示的移动终端100可以被构造为利用经由帧或分组发送数据的诸如有线和无线通信系统以及基于卫星的通信系统来操作。

现在将参考图2描述其中根据本发明的移动终端能够操作的通信系统。

这样的通信系统可以使用不同的空中接口和/或物理层。例如,由通信系统使用的空中接口包括例如频分多址(FDMA)、时分多址(TDMA)、码分多址(CDMA)和通用移动通信系统(UMTS)(特别地,长期演进(LTE))、全球移动通信系统(GSM)等等。作为非限制性示例,下面的描述涉及CDMA通信系统,但是这样的教导同样适用于其它类型的系统。

参考图2,CDMA无线通信系统可以包括多个移动终端100、多个基站(BS)270、基站控制器(BSC)275和移动交换中心(MSC)280。MSC280被构造为与公共电话交换网络(PSTN)290形成接口。MSC280还被构造为与可以经由回程线路耦接到基站270的BSC275形成接口。回程线路可以根据若干己知的接口中的任一种来构造,所述接口包括例如E1/T1、ATM,IP、PPP、帧中继、HDSL、ADSL或xDSL。将理解的是,如图2中所示的系统可以包括多个BSC2750。

每个BS270可以服务一个或多个分区(或区域),由多向天线或指向特定方向的天线覆盖的每个分区放射状地远离BS270。或者,每个分区可以由用于分集接收的两个或更多天线覆盖。每个BS270可以被构造为支持多个频率分配,并且每个频率分配具有特定频谱(例如,1.25MHz,5MHz等等)。

分区与频率分配的交叉可以被称为CDMA信道。BS270也可以被称为基站收发器子系统(BTS)或者其它等效术语。在这样的情况下,术语"基站"可以用于笼统地表示单个BSC275和至少一个BS270。基站也可以被称为"蜂窝站"。或者,特定BS270的各分区可以被称为多个蜂窝站。

如图2中所示,广播发射器(BT)295将广播信号发送给在系统内操作的移动终端100。如图1中所示的广播接收模块111被设置在移动终端100处以接收由BT295发送的广播信号。在图2中,示出了几个全球定位系统(GPS)卫星300。卫星300帮助定位多个移动终端100中的至少一个。

在图2中,描绘了多个卫星300,但是理解的是,可以利用任何数目的卫星获得有用的定位信息。作为无线通信系统的一个典型操作,BS270接收来自各种移动终端100的反向链路信号。移动终端100通常参与通话、消息收发和其它类型的通信。特定基站270接收的每个反向链路信号被在特定BS270内进行处理。获得的数据被转发给相关的BSC275。BSC提供通话资源分配和包括BS270之间的软切换过程的协调的移动管理功能。BSC275还将接收到的数据路由到MSC280,其提供用于与PSTN290形成接口的额外的路由服务。类似地,PSTN290与MSC280形成接口,MSC与BSC275形成接口,并且BSC275相应地控制BS270以将正向链路信号发送到移动终端100。

基于上述移动终端硬件结构以及通信系统,提出本发明各个实施例。

由于现有技术中,在访问终端系统共享数据时,比如在进行垃圾文件扫描时,首先访问锁资源,在获取锁资源的前提下才能实现数据的访问,而采用锁机制实现数据访问的一致性存在效率低的问题。

为此,本发明提出一种解决方案,采用副本机制替代现有的锁机制,保证在读写操作共享资源时,基本不需要取锁操作,在一定程度上提升共享资源的访问速度,节省数据扫描时间,对共享资源的控制更加灵活。

首先介绍一下数据的一致性,所谓数据一致性,就是当多个用户试图同时访问一个数据库,他们的事务同时使用相同的数据时,可能会发生丢失更新、未确定的相关性、不一致的分析和幻想读等问题。

比如,在数据有多份副本的情况下,如果网络、服务器或者软件出现故障,会导致部分副本写入成功,部分副本写入失败。这就造成各个副本之间的数据不一致,数据内容冲突。在实践中,导致数据不一致的情况有很多种,表现样式也多种多样,比如数据更新返回操作失败,事实上数据在存储服务器已经更新成功。

数据一致性通常指关联数据之间的逻辑关系是否正确和完整。而数据存储的一致性模型则可以认为是存储系统和数据使用者之间的一种约定。

具体地,如图3所示,本发明提出一种资源访问装置的第一实施例,包括:接收模块201、判断模块202及读操作模块203,其中:

接收模块201,用于接收对系统共享资源的访问操作申请,所述访问操作申请的类型包括读操作和写操作;

判断模块202,用于若当前访问操作申请的类型为读操作类型,则判断申请访问的系统共享资源是否处于约束期;

读操作模块203,用于若申请访问的系统共享资源处于约束期,则对所述系统共享资源的副本进行读操作,否则,对所述系统共享资源的原版本进行读操作。

本实施例中,对系统共享资源的访问包括对系统共享资源的读操作和写操作,其中,可能同时存在多个读操作,以及同时存在多个写操作,或者一个或多个读操作和一个或多个写操作并存。

在接收到对系统共享资源的访问操作申请时,解析该访问操作申请,得到访问操作申请的类型是读操作还是写操作。通常,读操作则是读取系统共享资源数据,写操作则是对系统共享资源数据进行修改。

若当前访问操作申请的类型为读操作类型,则判断申请访问的系统共享资源是否处于约束期。

其中,约束期是在对系统共享资源的写操作过程中设立的,本实施例中, 在访问操作申请的类型为写操作类型时,为系统共享资源建立副本,然后对副本进行修改,并为所述副本设立约束期。

也就是说,在访问操作申请的类型为写操作类型时,其需要将原来的老数据作一次备份,然后对备份数据进行修改,修改完毕之后,且老数据约束期解除后再实现老数据资源的回收。

本实施例采用副本机制替代现有的锁机制,并增加了一个约束期,使得在同时存在读写操作时,减少读操作和写操作的等待时间,在一定程度上提升对系统资源的访问速度。

由于可能同时存在读操作和写操作,因此,在当前访问操作申请的类型为读操作类型时,首先需要判断申请访问的系统共享资源是否处于约束期,即是否有写操作申请访问过,建立有副本,并为修改后的副本设立有约束期。

若申请访问的系统共享资源处于约束期,则表明当前申请访问的系统共享资源进行过写操作并建立有副本,此时,对系统共享资源的副本进行读操作,若申请访问的系统共享资源不处于约束期,则表明当前申请访问的系统共享资源没有同时存在写操作,此时,直接对系统共享资源的原版本进行读操作。

本实施例由于采用了副本机制,使得对共享资源的控制更加灵活。其中,对于读操作,可以直接对共享资源(原版本或副本)进行访问;对于写操作,则需要将原来的老数据作一次备份,然后对备份数据进行修改,并设立约束期。本机制能够保证在读写操作共享系统资源时,保证数据的一致性,并且基本不需要取锁操作,能够在一定程度上提升资源的访问速度,从而节省数据扫描时间。

上述实施方案中,需要说明的是,在一个写操作发生后,必须等待所有在约束期开始前已经开始的读线程结束,才可以进行更新操作,以保证数据的一致性访问。

具体地,在当前访问操作申请的类型为写操作类型时,判断对所述系统共享资源的所有读操作是否结束;若对所述系统共享资源的所有读操作结束,则为所述系统共享资源建立副本,对所述副本进行修改,以保证访问数据的一致性。

如图4所示,本发明提出一种资源访问装置的第二实施例,该实施例与上述第一实施例的区别在于,所述装置还包括:

写操作模块204,用于若当前访问操作申请的类型为写操作类型,则为所述系统共享资源建立副本,对所述副本进行修改,并为所述副本设立约束期。

如前所述,若当前访问操作申请的类型为写操作类型,则为所述系统共享资源建立副本,对所述副本进行修改,并为所述修改后的副本设立约束期。

如图5所示,本发明提出一种资源访问装置的第三实施例,该实施例与上述第二实施例的区别在于,所述装置还包括:解除回收模块205;

作为一种实施方式,解除回收模块205用于在所述读操作模块对所述系统共享资源的副本进行读操作结束后,解除所述系统共享资源的约束期,并回收所述系统共享资源的原版本。

具体地,在对系统共享资源的访问结束后,即在同时存在的读操作和写操作均结束后,可以解除系统共享资源的约束期,并回收所述系统共享资源的原版本,以保证后续数据访问的准确性。

进一步地,作为另一种实施方式,解除回收模块205用于在对所述系统共享资源的副本进行读操作结束前,判断所述系统共享资源的约束期是否达到阈值;若所述系统共享资源的约束期达到阈值,则强制解除所述系统共享资源的约束期,并回收所述系统共享资源的原版本。

具体地,对于处于约束期的系统共享资源,为了避免某个读操作线程不停的进行,导致数据访问无法正常进行,本实施例对约束期设置有一定的阈值,当资源的约束期达到阈值时,强制申请解除资源约束期。

本实施例由于采用了副本机制,使得对共享资源的控制更加灵活。其中,对于读操作,可以直接对共享资源(原版本或副本)进行访问;对于写操作,则需要将原来的老数据作一次备份,然后对备份数据进行修改,修改完毕之后,且老数据约束期解除后再实现老数据资源的回收。本机制能够保证在读写操作共享资源时,保证数据的一致性,并且基本不需要取锁操作,能够在一定程度上提升资源的访问速度,从而节省数据扫描时间;而通过约束期的 解除,保证后续数据访问的准确性。

如图6所示,本发明提出一种资源访问方法第一实施例,包括:

步骤S101,接收对系统共享资源的访问操作申请,所述访问操作申请的类型包括读操作和写操作;

本实施例中,对系统共享资源的访问包括对系统共享资源的读操作和写操作,其中,可能同时存在多个读操作,以及同时存在多个写操作,或者一个或多个读操作和一个或多个写操作并存。

步骤S102,判断访问操作申请的类型;

在接收到对系统共享资源的访问操作申请时,解析该访问操作申请,得到访问操作申请的类型是读操作还是写操作。通常,读操作则是读取系统共享资源数据,写操作则是对系统共享资源数据进行修改。

步骤S103,若当前访问操作申请的类型为读操作类型,则判断申请访问的系统共享资源是否处于约束期;

其中,约束期是在对系统共享资源的写操作过程中设立的,本实施例中,在访问操作申请的类型为写操作类型时,为系统共享资源建立副本,然后对副本进行修改,并为所述副本设立约束期。

也就是说,在访问操作申请的类型为写操作类型时,其需要将原来的老数据作一次备份,然后对备份数据进行修改,修改完毕之后,且老数据约束期解除后再实现老数据资源的回收。

本实施例采用副本机制替代现有的锁机制,并增加了一个约束期,使得在同时存在读写操作时,减少读操作和写操作的等待时间,在一定程度上提升对系统资源的访问速度。

由于可能同时存在读操作和写操作,因此,在当前访问操作申请的类型为读操作类型时,首先需要判断申请访问的系统共享资源是否处于约束期,即是否有写操作申请访问过,建立有副本,并为修改后的副本设立有约束期。

步骤S104,若申请访问的系统共享资源处于约束期,则对所述系统共享资源的副本进行读操作;

步骤S105,若申请访问的系统共享资源不处于约束期,则对所述系统共享资源的原版本进行读操作。

若申请访问的系统共享资源处于约束期,则表明当前申请访问的系统共享资源进行过写操作并建立有副本,此时,对系统共享资源的副本进行读操作,若申请访问的系统共享资源不处于约束期,则表明当前申请访问的系统共享资源没有同时存在写操作,此时,直接对系统共享资源的原版本进行读操作。

步骤S106,若当前访问操作申请的类型为写操作类型,则为所述系统共享资源建立副本,对所述副本进行修改,并为所述副本设立约束期。

如前所述,若当前访问操作申请的类型为写操作类型,则为所述系统共享资源建立副本,对所述副本进行修改,并为所述修改后的副本设立约束期。

本实施例由于采用了副本机制,使得对共享资源的控制更加灵活。其中,对于读操作,可以直接对共享资源(原版本或副本)进行访问;对于写操作,则需要将原来的老数据作一次备份,然后对备份数据进行修改,并设立约束期。本机制能够保证在读写操作共享系统资源时,保证数据的一致性,并且基本不需要取锁操作,能够在一定程度上提升资源的访问速度,从而节省数据扫描时间。

上述实施方案中,需要说明的是,在一个写操作发生后,必须等待所有在约束期开始前已经开始的读线程结束,才可以进行更新操作,以保证数据的一致性访问。

具体地,在当前访问操作申请的类型为写操作类型时,判断对所述系统共享资源的所有读操作是否结束;若对所述系统共享资源的所有读操作结束,则为所述系统共享资源建立副本,对所述副本进行修改,以保证访问数据的一致性。

如图7所示,本发明提出一种资源访问方法第二实施例,该实施例与上述第一实施例的区别在于,本实施例在对所述系统共享资源的副本进行读操作结束后,解除所述系统共享资源的约束期,并回收所述系统共享资源的原版本。

因此,在本实施例中,在上述步骤S104:若申请访问的系统共享资源处 于约束期,则对所述系统共享资源的副本进行读操作之后,该方法还可以包括:

步骤S107,在对所述系统共享资源的副本进行读操作结束后,解除所述系统共享资源的约束期,并回收所述系统共享资源的原版本。

具体地,在对系统共享资源的访问结束后,即在同时存在的读操作和写操作均结束后,可以解除系统共享资源的约束期,并回收所述系统共享资源的原版本,以保证后续数据访问的准确性。

本实施例由于采用了副本机制,使得对共享资源的控制更加灵活。其中,对于读操作,可以直接对共享资源(原版本或副本)进行访问;对于写操作,则需要将原来的老数据作一次备份,然后对备份数据进行修改,修改完毕之后,且老数据约束期解除后再实现老数据资源的回收。本机制能够保证在读写操作共享资源时,保证数据的一致性,并且基本不需要取锁操作,能够在一定程度上提升资源的访问速度,从而节省数据扫描时间;而通过约束期的解除,保证后续数据访问的准确性。

如图8所示,本发明提出一种资源访问方法第三实施例,该实施例与上述第一实施例的区别在于,本实施例为约束期设立有阈值,在对所述系统共享资源的副本进行读操作结束前,若所述系统共享资源的约束期达到阈值,则强制解除所述系统共享资源的约束期,并回收所述系统共享资源的原版本。

因此,在本实施例中,在上述步骤S104:若申请访问的系统共享资源处于约束期,则对所述系统共享资源的副本进行读操作之后,还包括:

步骤S108,在对所述系统共享资源的副本进行读操作结束前,判断所述系统共享资源的约束期是否达到阈值;

步骤S109,若所述系统共享资源的约束期达到阈值,则强制解除所述系统共享资源的约束期,并回收所述系统共享资源的原版本。

具体地,对于处于约束期的系统共享资源,为了避免某个读操作线程不停的进行,导致数据访问无法正常进行,本实施例对约束期设置有一定的阈值,当资源的约束期达到阈值时,强制申请解除资源约束期。

下面以扫描垃圾文件为例,对本发明实施例方案进行详细阐述:

由于现在的移动终端的操作系统通常都是多任务和多线程的,在进行垃圾扫描的同时,也会出现其他进程或线程对扫描的资源进行访问,这样,就会造成资源共享操作。

现有技术在系统中采用锁机制实现数据的一致性访问存在效率问题和扩展问题,其中,效率问题体现在:锁机制的实现需要对内存的原子化访问,这种访问操作会破坏流水线操作,降低了流水线效率。另外,在采用读写锁机制的情况下,写锁是排他锁,无法实现写锁与读锁的并发操作,在某些应用下回降低性能;扩展性问题体现在:当系统中CPU数量增多的时候,采用锁机制实现数据的同步访问效率偏低。并且随着CPU数量的增多,效率降低,由此可见锁机制实现的数据一致性访问扩展性差。

本发明实施例方案,通过采用副本机制,使得对共享资源的控制更加灵活。对于读操作,可以直接对共享资源进行访问;对于写操作,其需要将原来的老数据作一次备份,然后对备份数据进行修改,修改完毕之后,且老数据约束期解除后再实现老数据资源的回收。这里增加了一个约束期,在一个写操作发生后,它必须等待所有在约束期开始前已经开始的读线程结束,才可以进行更新操作。本机制能够保证在读写操作共享资源时,基本不需要取锁操作,能够在一定程度上提升资源的访问速度,从而节省垃圾扫描时间。

更为具体地,如图9所示,为实施本发明方案,可以在系统框架中设置相应的功能模块,比如可以包括:资源申请管理模块、资源约束期管理模块和副本管理模块。其中,各功能模块的功能如下:

资源申请管理模块:当需要访问系统资源时,需要向本模块提交操作申请。资源申请管理模块会根据申请的操作类型执行相应的逻辑。

a、写操作类型。本模块会调用副本管理模块,申请新建副本。

b、读操作类型。本模块会首先在资源约束期管理模块中查询申请访问的资源是否处于约束期。如果处于约束期,此时的线程会被引导至新资源进行访问。否则,直接访问资源。

资源约束期管理模块:本模块接收到资源约束期查询请求后,会搜索在本地注册的资源信息,如果搜索到请求的资源信息,则意味着已经有线程对 本资源发起过写操作,此时返回资源处于约束期。如果未搜索到,意味着资源可以直接访问,此时返回资源不处于约束期。本模块也对处在约束期的旧资源不断的进行监测,当旧资源的访问结束时,调用副本管理模块,申请解除资源约束期。约束期有一定的阈值,当资源的约束期达到阈值时,仍然没有被解除,其也会调用副本管理模块,强制申请解除资源约束期。同时,从本模块中移除对应的资源信息。

副本管理模块:本模块收到新建副本的指令后,会拷贝一份资源,并同时将资源信息注册至约束期资源管理魔窟。当收到解除资源约束期的指令后,其会回收旧资源,使用副本资源替代。

通过上述方案就能够保证在读写操作共享资源时,基本不需要取锁操作,能够在一定程度上提升资源的访问速度,从而节省垃圾扫描时间。

本实施例由于采用了副本机制,使得对共享资源的控制更加灵活。其中,对于读操作,可以直接对共享资源(原版本或副本)进行访问;对于写操作,则需要将原来的老数据作一次备份,然后对备份数据进行修改,修改完毕之后,且老数据约束期解除后再实现老数据资源的回收。本机制能够保证在读写操作共享资源时,保证数据的一致性,并且基本不需要取锁操作,能够在一定程度上提升资源的访问速度,从而节省垃圾数据的扫描时间;而通过约束期的解除,保证后续数据访问的准确性。

需要说明的是,在本文中,术语“包括”、“包含”或者其任何其他变体意在涵盖非排他性的包含,从而使得包括一系列要素的过程、方法、物品或者装置不仅包括那些要素,而且还包括没有明确列出的其他要素,或者是还包括为这种过程、方法、物品或者装置所固有的要素。在没有更多限制的情况下,由语句“包括一个……”限定的要素,并不排除在包括该要素的过程、方法、物品或者装置中还存在另外的相同要素。

上述本发明实施例序号仅仅为了描述,不代表实施例的优劣。

通过以上的实施方式的描述,本领域的技术人员可以清楚地了解到上述实施例方法可借助软件加必需的通用硬件平台的方式来实现,当然也可以通 过硬件,但很多情况下前者是更佳的实施方式。基于这样的理解,本发明的技术方案本质上或者说对现有技术做出贡献的部分可以以软件产品的形式体现出来,该计算机软件产品存储在一个存储介质(如ROM/RAM、磁碟、光盘)中,包括若干指令用以使得一台终端设备(可以是手机,计算机,服务器,空调器,或者网络设备等)执行本发明各个实施例所述的方法。

以上仅为本发明的优选实施例,并非因此限制本发明的专利范围,凡是利用本发明说明书及附图内容所作的等效结构或等效流程变换,或直接或间接运用在其他相关的技术领域,均同理包括在本发明的专利保护范围内。

当前第1页1 2 3 
网友询问留言 已有0条留言
  • 还没有人留言评论。精彩留言会获得点赞!
1