基于文件句柄的数据读写方法、装置及计算设备与流程

文档序号:14478802阅读:503来源:国知局

本发明涉及数据处理技术领域,具体涉及一种基于文件句柄的数据读写方法、装置、计算设备及计算机存储介质。



背景技术:

文件句柄是操作系统中非常宝贵的系统资源,用来唯一标识文件,根据文件句柄可以打开相应的文件,现有技术中,对于一个文件句柄,会先监听这个文件句柄是否具有可读事件,如果具有可读事件,则读取文件句柄对应的内容,在读取完对应的内容以后,就设置去监听这个文件句柄的可写事件,等待下一次循环,判断这个文件句柄是否可写,如果可写就把内容写入缓冲区,然后重新监听可读事件,而一般情况下,文件句柄关联的缓冲区不可写的概率非常低,每次写入之前均监听文件句柄是否具有可写事件,不仅增加了不必要的循环和监听操作,还影响了网络编程框架的性能。



技术实现要素:

鉴于上述问题,提出了本发明以便提供一种克服上述问题或者至少部分地解决上述问题的基于文件句柄的数据读写方法、装置、计算设备及计算机存储介质。

根据本发明的一个方面,提供了一种基于文件句柄的数据读写方法,包括:

监听文件句柄关联的缓冲区,以确定所述文件句柄是否具有可读事件;

若所述文件句柄具有可读事件,则读取所述文件句柄对应的数据并进行相应的处理,并对所述文件句柄执行写操作;

根据写操作执行结果进行相应的监听处理。

根据本发明的另一方面,提供了一种基于文件句柄的数据读写装置,包括:

监听模块,适于监听文件句柄关联的缓冲区,以确定所述文件句柄是否具有可读事件;

处理模块,适于若所述文件句柄具有可读事件,则读取所述文件句柄对应的数据并进行相应的处理,并对所述文件句柄执行写操作;

监听模块进一步适于:根据写操作执行结果进行相应的监听处理。

根据本发明的又一方面,提供了一种计算设备,包括:处理器、存储器、通信接口和通信总线,所述处理器、所述存储器和所述通信接口通过所述通信总线完成相互间的通信;

所述存储器用于存放至少一可执行指令,所述可执行指令使所述处理器执行上述基于文件句柄的数据读写方法对应的操作。

根据本发明的再一方面,提供了一种计算机存储介质,所述存储介质中存储有至少一可执行指令,所述可执行指令使处理器执行如上述基于文件句柄的数据读写方法对应的操作。

根据本发明提供的方案,监听文件句柄关联的缓冲区,以确定所述文件句柄是否具有可读事件;若所述文件句柄具有可读事件,则读取所述文件句柄对应的数据并进行相应的处理,并对所述文件句柄执行写操作;根据写操作执行结果进行相应的监听处理,无需退出监听文件句柄是否可写,从而减少了一次循环以及一次监听是否可写的操作,对网络编程框架的性能进行了优化。

上述说明仅是本发明技术方案的概述,为了能够更清楚了解本发明的技术手段,而可依照说明书的内容予以实施,并且为了让本发明的上述和其它目的、特征和优点能够更明显易懂,以下特举本发明的具体实施方式。

附图说明

通过阅读下文优选实施方式的详细描述,各种其他的优点和益处对于本领域普通技术人员将变得清楚明了。附图仅用于示出优选实施方式的目的,而并不认为是对本发明的限制。而且在整个附图中,用相同的参考符号表示相同的部件。在附图中:

图1示出了根据本发明一个实施例的基于文件句柄的数据读写方法的流程示意图;

图2示出了根据本发明另一个实施例的基于文件句柄的数据读写方法的流程示意图;

图3示出了根据本发明一个实施例的基于文件句柄的数据读写装置的结构示意图;

图4示出了根据本发明一个实施例的一种计算设备的结构示意图。

具体实施方式

下面将参照附图更详细地描述本公开的示例性实施例。虽然附图中显示了本公开的示例性实施例,然而应当理解,可以以各种形式实现本公开而不应被这里阐述的实施例所限制。相反,提供这些实施例是为了能够更透彻地理解本公开,并且能够将本公开的范围完整的传达给本领域的技术人员。

图1示出了根据本发明一个实施例的基于文件句柄的数据读写方法的流程示意图。如图1所示,该方法包括以下步骤:

步骤s100,监听文件句柄关联的缓冲区,以确定所述文件句柄是否具有可读事件。

大众所熟知的网络服务架构为c/s架构(client/server架构,即客户端/服务器架构),一般情况下,是由客户端主动向服务器发起请求,请求服务器返回数据给客户端,而服务器在未接收到请求的情况下,是不会主动向客户端推送数据的。

若一个客户端连接到服务器,客户端向服务器发送的请求中会携带有文件句柄,服务器通过调用接纳客户端请求的函数(accept函数)可以得到这个客户端对应的文件句柄,其中,文件句柄用于标记文件,根据文件句柄可以访问到对应的文件,因此,这里需要监听是否有可读事件,以确定客户端是否向服务器发送请求,具体地,通过监听文件句柄关联的缓冲区来确定文件句柄是否具有可读事件。

步骤s101,若所述文件句柄具有可读事件,则读取所述文件句柄对应的数据并进行相应的处理,并对所述文件句柄执行写操作。

若文件句柄具有可读事件,则可以读取该文件句柄对应的文件中的数据,在读取到数据之后,需要对数据进行相应的处理,例如,解析数据以确定客户端所请求的内容是什么,在执行相应的处理之后,直接对文件句柄执行写操作,该写操作是服务器对请求所做的应答,即向客户端返回数据。

步骤s102,根据写操作执行结果进行相应的监听处理。

虽然在步骤s101中,对文件句柄执行了写操作,但是写操作执行结果可能是写入成功或写入失败,不同的写操作执行结果决定了写操作执行结束后的监听处理方案。

根据本发明上述实施例提供的方法,监听文件句柄关联的缓冲区,以确定所述文件句柄是否具有可读事件;若所述文件句柄具有可读事件,则读取所述文件句柄对应的数据并进行相应的处理,并对所述文件句柄执行写操作;根据写操作执行结果进行相应的监听处理,无需退出监听文件句柄是否可写,从而减少了一次循环以及一次监听是否可写的操作,对网络编程框架的性能进行了优化。

图2示出了根据本发明另一个实施例的基于文件句柄的数据读写方法的流程示意图。如图2所示,该方法包括以下步骤:

步骤s200,监测文件句柄关联的缓冲区是否存储有数据,若是,则执行步骤s201。

在本发明实施例中,每个文件句柄对应一缓冲区,文件句柄关联的缓冲区非空即有数据时,说明缓冲区有数据可以读取,此时就会触发可读事件,即epollin事件,因此,通过监听文件句柄关联的缓冲区是否存储有数据,即可确定文件句柄是否具有可读事件,若文件句柄关联的缓冲区存储有数据,则说明文件句柄具有可读事件;若文件句柄关联的缓冲区未存储有数据,则说明不具有可读事件。

步骤s201,确定文件句柄具有可读事件,读取所述文件句柄对应的数据并进行相应的处理,并对所述文件句柄执行写操作。

若监听到文件句柄关联的缓冲区存储有数据,则表明有数据可以读取,可以采用水平触发方式,发出可读信号,由此可以确定文件句柄具有可读事件,如此,可以从缓冲区读取该文件句柄对应的文件中的数据,在读取到数据之后,需要对数据进行相应的处理,例如,解析数据以确定客户端所请求的内容是什么。

在读取所述文件句柄对应的数据并进行相应的处理之后,现有方法是继续监听文件句柄是否具有可写事件,等待下一次循环到来时,判断文件句柄是否具有可写事件,若具有可写事件,则将数据写入至缓冲区,然后重新监听文件句柄是否具有可读事件,具体地,可以通过如下代码实现:

一般情况下,文件句柄关联的缓冲区不可写的概率非常低,每次写入之前均监听文件句柄是否具有可写事件,不仅增加了不必要的循环和监听操作,还影响了网络编程框架的性能。

基于上述问题,本发明实施例在读取所述文件句柄对应的数据并进行相应的处理之后,直接对文件句柄执行写操作,该写操作是服务器对请求所做的应答,虽然直接对文件句柄执行写操作,但是执行结果可能为写入失败或写入成功,根据不同的写操作执行结果,将执行不同的监听处理方法。

步骤s202,若写操作执行结果表明写入失败,则监听文件句柄关联的缓冲区,以确定文件句柄是否具有可写事件。

若写操作执行结果表明写入失败,则说明缓冲区当前是被写满状态,没有空闲空间可供写入,此时就需要等待下一次循环,可以通过监听文件句柄关联的缓冲区来确定文件句柄是否具有可写事件,具体地,可以监测文件句柄关联的缓冲区的状态是否为写满状态,若缓冲区的状态不是写满状态,说明缓冲区不满,有空闲空间可以写入,则会触发可写事件:epollout事件。

步骤s203,若文件句柄具有可写事件,则执行写操作,并在写操作完成后继续监听所述文件句柄是否具有可读事件,执行下一次循环。

在确定文件句柄具有可写事件的情况下,则执行写操作,将数据写入至缓冲区,这里的写操作是对请求所作出的响应,写操作完成后,说明一次循环结束,可以继续监听文件句柄是否具有可读事件,执行下一次循环。

步骤s204,若写操作执行结果表明写入成功,则继续监听所述文件句柄是否具有可读事件,执行下一次循环。

若写操作执行结果表明写入成功,说明数据已写入至缓冲区,服务器对客户端的请求已作出响应,此时可以执行下一次循环,即继续监听文件句柄是否具有可读事件,以确定客户端是否发送了新的请求需要进行处理。

根据本发明上述实施例提供的方法,监测文件句柄关联的缓冲区是否存储有数据,若是,定文件句柄具有可读事件,读取所述文件句柄对应的数据并进行相应的处理,并对所述文件句柄执行写操作,若写操作执行结果表明写入失败,则监听文件句柄关联的缓冲区,以确定文件句柄是否具有可写事件,若文件句柄具有可写事件,则执行写操作,并在写操作完成后继续监听所述文件句柄是否具有可读事件,执行下一次循环;若写操作执行结果表明写入成功,则继续监听所述文件句柄是否具有可读事件,执行下一次循环。基于本发明实施例的方案,无需退出监听文件句柄是否可写,从而减少了一次循环以及一次监听是否可写的操作,对网络编程框架的性能进行了优化。

图3示出了根据本发明一个实施例的基于文件句柄的数据读写装置的结构示意图。如图3所示,该装置包括:监听模块300、处理模块310。

监听模块300,适于监听文件句柄关联的缓冲区,以确定所述文件句柄是否具有可读事件。

大众所熟知的网络服务架构为c/s架构(client/server架构,即客户端/服务器架构),一般情况下,是由客户端主动向服务器发起请求,请求服务器返回数据给客户端,而服务器在未接收到请求的情况下,是不会主动向客户端推送数据的。

若一个客户端连接到服务器,客户端向服务器发送的请求中会携带有文件句柄,服务器通过调用接纳客户端请求的函数(accept函数)可以得到这个客户端对应的文件句柄,其中,文件句柄用于标记文件,根据文件句柄可以访问到对应的文件,因此,这里需要监听是否有可读事件,以确定客户端是否向服务器发送请求,具体地,通过监听文件句柄关联的缓冲区来确定文件句柄是否具有可读事件。

处理模块310,适于若所述文件句柄具有可读事件,则读取所述文件句柄对应的数据并进行相应的处理,并对所述文件句柄执行写操作。

若文件句柄具有可读事件,则可以读取该文件句柄对应的文件中的数据,在读取到数据之后,需要对数据进行相应的处理,例如,解析数据以确定客户端所请求的内容是什么,在执行相应的处理之后,直接对文件句柄执行写操作,该写操作是服务器对请求所做的应答,即向客户端返回数据。

监听模块300进一步适于:根据写操作执行结果进行相应的监听处理。

虽然对文件句柄执行了写操作,但是写操作执行结果可能是写入成功或写入失败,不同的写操作执行结果决定了写操作执行结束后的监听处理方案。

现有方法在读取所述文件句柄对应的数据并进行相应的处理之后,继续监听文件句柄是否具有可写事件,等待下一次循环到来时,判断文件句柄是否具有可写事件,若具有可写事件,则将数据写入至缓冲区,然后重新监听文件句柄是否具有可读事件,具体地,可以通过如下代码实现:

一般情况下,文件句柄关联的缓冲区不可写的概率非常低,每次写入之前均监听文件句柄是否具有可写事件,不仅增加了不必要的循环和监听操作,还影响了网络编程框架的性能。

基于上述问题,本发明实施例在读取所述文件句柄对应的数据并进行相应的处理之后,直接对文件句柄执行写操作,该写操作是服务器对请求所做的应答,虽然直接对文件句柄执行写操作,但是执行结果可能为写入失败或写入成功,根据不同的写操作执行结果,将执行不同的监听处理方法。

可选地,所述监听模块300进一步适于:若写操作执行结果表明写入失败,则监听文件句柄关联的缓冲区,以确定文件句柄是否具有可写事件。

所述处理模块310进一步适于:若文件句柄具有可写事件,则执行写操作;并在写操作完成后继续监听所述文件句柄是否具有可读事件,执行下一次循环。

所述监听模块300进一步适于:若写操作执行结果表明写入成功,则继续监听所述文件句柄是否具有可读事件,执行下一次循环。

可选地,所述监听模块300进一步适于:监测文件句柄关联的缓冲区的状态是否为写满状态,若否,则确定文件句柄具有可写事件。

可选地,所述监听模块300进一步适于:监测文件句柄关联的缓冲区是否存储有数据,若是,则确定文件句柄具有可读事件。

在本发明实施例中,每个文件句柄对应一缓冲区,文件句柄关联的缓冲区非空即有数据时,说明缓冲区有数据可以读取,此时就会触发可读事件,即epollin事件,因此,通过监听文件句柄关联的缓冲区是否存储有数据,即可确定文件句柄是否具有可读事件,若文件句柄关联的缓冲区存储有数据,则说明文件句柄具有可读事件;若文件句柄关联的缓冲区未存储有数据,则说明不具有可读事件。

可选地,每个文件句柄对应一缓冲区。

根据本发明上述实施例提供的装置,监测文件句柄关联的缓冲区是否存储有数据,若是,定文件句柄具有可读事件,读取所述文件句柄对应的数据并进行相应的处理,并对所述文件句柄执行写操作,若写操作执行结果表明写入失败,则监听文件句柄关联的缓冲区,以确定文件句柄是否具有可写事件,若文件句柄具有可写事件,则执行写操作,并在写操作完成后继续监听所述文件句柄是否具有可读事件,执行下一次循环;若写操作执行结果表明写入成功,则继续监听所述文件句柄是否具有可读事件,执行下一次循环。基于本发明实施例的方案,无需退出监听文件句柄是否可写,从而减少了一次循环以及一次监听是否可写的操作,对网络编程框架的性能进行了优化。

本申请还提供了一种非易失性计算机存储介质,所述计算机存储介质存储有至少一可执行指令,该计算机可执行指令可执行上述任意方法实施例中的基于文件句柄的数据读写方法。

图4示出了根据本发明一个实施例的一种计算设备的结构示意图,本发明具体实施例并不对计算设备的具体实现做限定。

如图4所示,该计算设备可以包括:处理器(processor)402、通信接口(communicationsinterface)404、存储器(memory)406、以及通信总线408。

其中:

处理器402、通信接口404、以及存储器406通过通信总线408完成相互间的通信。

通信接口404,用于与其它设备比如客户端或其它服务器等的网元通信。

处理器402,用于执行程序410,具体可以执行上述基于文件句柄的数据读写方法实施例中的相关步骤。

具体地,程序410可以包括程序代码,该程序代码包括计算机操作指令。

处理器402可能是中央处理器cpu,或者是特定集成电路asic(applicationspecificintegratedcircuit),或者是被配置成实施本发明实施例的一个或多个集成电路。计算设备包括的一个或多个处理器,可以是同一类型的处理器,如一个或多个cpu;也可以是不同类型的处理器,如一个或多个cpu以及一个或多个asic。

存储器406,用于存放程序410。存储器406可能包含高速ram存储器,也可能还包括非易失性存储器(non-volatilememory),例如至少一个磁盘存储器。

程序410具体可以用于使得处理器402执行上述任意方法实施例中的基于文件句柄的数据读写方法。程序410中各步骤的具体实现可以参见上述基于文件句柄的数据读写实施例中的相应步骤和单元中对应的描述,在此不赘述。所属领域的技术人员可以清楚地了解到,为描述的方便和简洁,上述描述的设备和模块的具体工作过程,可以参考前述方法实施例中的对应过程描述,在此不再赘述。

在此提供的算法和显示不与任何特定计算机、虚拟系统或者其它设备固有相关。各种通用系统也可以与基于在此的示教一起使用。根据上面的描述,构造这类系统所要求的结构是显而易见的。此外,本发明也不针对任何特定编程语言。应当明白,可以利用各种编程语言实现在此描述的本发明的内容,并且上面对特定语言所做的描述是为了披露本发明的最佳实施方式。

在此处所提供的说明书中,说明了大量具体细节。然而,能够理解,本发明的实施例可以在没有这些具体细节的情况下实践。在一些实例中,并未详细示出公知的方法、结构和技术,以便不模糊对本说明书的理解。

类似地,应当理解,为了精简本公开并帮助理解各个发明方面中的一个或多个,在上面对本发明的示例性实施例的描述中,本发明的各个特征有时被一起分组到单个实施例、图、或者对其的描述中。然而,并不应将该公开的方法解释成反映如下意图:即所要求保护的本发明要求比在每个权利要求中所明确记载的特征更多的特征。更确切地说,如下面的权利要求书所反映的那样,发明方面在于少于前面公开的单个实施例的所有特征。因此,遵循具体实施方式的权利要求书由此明确地并入该具体实施方式,其中每个权利要求本身都作为本发明的单独实施例。

本领域那些技术人员可以理解,可以对实施例中的设备中的模块进行自适应性地改变并且把它们设置在与该实施例不同的一个或多个设备中。可以把实施例中的模块或单元或组件组合成一个模块或单元或组件,以及此外可以把它们分成多个子模块或子单元或子组件。除了这样的特征和/或过程或者单元中的至少一些是相互排斥之外,可以采用任何组合对本说明书(包括伴随的权利要求、摘要和附图)中公开的所有特征以及如此公开的任何方法或者设备的所有过程或单元进行组合。除非另外明确陈述,本说明书(包括伴随的权利要求、摘要和附图)中公开的每个特征可以由提供相同、等同或相似目的的替代特征来代替。

此外,本领域的技术人员能够理解,尽管在此所述的一些实施例包括其它实施例中所包括的某些特征而不是其它特征,但是不同实施例的特征的组合意味着处于本发明的范围之内并且形成不同的实施例。例如,在下面的权利要求书中,所要求保护的实施例的任意之一都可以以任意的组合方式来使用。

本发明的各个部件实施例可以以硬件实现,或者以在一个或者多个处理器上运行的软件模块实现,或者以它们的组合实现。本领域的技术人员应当理解,可以在实践中使用微处理器或者数字信号处理器(dsp)来实现根据本发明实施例的基于文件句柄的数据读写设备中的一些或者全部部件的一些或者全部功能。本发明还可以实现为用于执行这里所描述的方法的一部分或者全部的设备或者装置程序(例如,计算机程序和计算机程序产品)。这样的实现本发明的程序可以存储在计算机可读介质上,或者可以具有一个或者多个信号的形式。这样的信号可以从因特网网站上下载得到,或者在载体信号上提供,或者以任何其他形式提供。

应该注意的是上述实施例对本发明进行说明而不是对本发明进行限制,并且本领域技术人员在不脱离所附权利要求的范围的情况下可设计出替换实施例。在权利要求中,不应将位于括号之间的任何参考符号构造成对权利要求的限制。单词“包含”不排除存在未列在权利要求中的元件或步骤。位于元件之前的单词“一”或“一个”不排除存在多个这样的元件。本发明可以借助于包括有若干不同元件的硬件以及借助于适当编程的计算机来实现。在列举了若干装置的单元权利要求中,这些装置中的若干个可以是通过同一个硬件项来具体体现。单词第一、第二、以及第三等的使用不表示任何顺序。可将这些单词解释为名称。

本发明公开了:

a1.一种基于文件句柄的数据读写方法,包括:

监听文件句柄关联的缓冲区,以确定所述文件句柄是否具有可读事件;

若所述文件句柄具有可读事件,则读取所述文件句柄对应的数据并进行相应的处理,并对所述文件句柄执行写操作;

根据写操作执行结果进行相应的监听处理。

a2.根据a1所述的方法,其中,所述根据写操作执行结果进行相应的监听处理进一步包括:

若写操作执行结果表明写入失败,则监听文件句柄关联的缓冲区,以确定文件句柄是否具有可写事件,若文件句柄具有可写事件,则执行写操作,并在写操作完成后继续监听所述文件句柄是否具有可读事件,执行下一次循环;

若写操作执行结果表明写入成功,则继续监听所述文件句柄是否具有可读事件,执行下一次循环。

a3.根据a2所述的方法,其中,所述监听文件句柄关联的缓冲区,以确定文件句柄是否具有可写事件进一步包括:

监测文件句柄关联的缓冲区的状态是否为写满状态,若否,则确定文件句柄具有可写事件。

a4.根据a1-a3任一项所述的方法,其中,所述监听文件句柄关联的缓冲区,以确定文件句柄是否具有可读事件进一步包括:

监测文件句柄关联的缓冲区是否存储有数据,若是,则确定文件句柄具有可读事件。

a5.根据a1-a4任一项所述的方法,其中,每个文件句柄对应一缓冲区。

b6.一种基于文件句柄的数据读写装置,包括:

监听模块,适于监听文件句柄关联的缓冲区,以确定所述文件句柄是否具有可读事件;

处理模块,适于若所述文件句柄具有可读事件,则读取所述文件句柄对应的数据并进行相应的处理,并对所述文件句柄执行写操作;

监听模块进一步适于:根据写操作执行结果进行相应的监听处理。

b7.根据b6所述的装置,其中,所述监听模块进一步适于:若写操作执行结果表明写入失败,则监听文件句柄关联的缓冲区,以确定文件句柄是否具有可写事件;

所述处理模块进一步适于:若文件句柄具有可写事件,则执行写操作;并在写操作完成后继续监听所述文件句柄是否具有可读事件,执行下一次循环;

所述监听模块进一步适于:若写操作执行结果表明写入成功,则继续监听所述文件句柄是否具有可读事件,执行下一次循环。

b8.根据b7所述的装置,其中,所述监听模块进一步适于:监测文件句柄关联的缓冲区的状态是否为写满状态,若否,则确定文件句柄具有可写事件。

b9.根据b6-b8任一项所述的装置,其中,所述监听模块进一步适于:监测文件句柄关联的缓冲区是否存储有数据,若是,则确定文件句柄具有可读事件。

b10.根据b6-b9任一项所述的装置,其中,每个文件句柄对应一缓冲区。

c11.一种计算设备,包括:处理器、存储器、通信接口和通信总线,所述处理器、所述存储器和所述通信接口通过所述通信总线完成相互间的通信;

所述存储器用于存放至少一可执行指令,所述可执行指令使所述处理器执行如a1-a5中任一项所述的基于文件句柄的数据读写方法对应的操作。

d12.一种计算机存储介质,所述存储介质中存储有至少一可执行指令,所述可执行指令使处理器执行如a1-a5中任一项所述的基于文件句柄的数据读写方法对应的操作。

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