一种业务交互方法、终端和计算机可读存储介质与流程

文档序号:12887041阅读:238来源:国知局
本发明涉及终端存储领域,更具体地说,涉及一种业务交互方法、终端和计算机可读存储介质。
背景技术
::智能终端的快速发展已然改变了每个人的生活和工作习惯,已经逐步完成替代pc的角色,大家习惯性的将生活照片、工作资料等文档存储在移动终端,方便和朋友分享和协同工作等等。而由于终端上安装的越来越多的应用,势必会增大应用和底层存储的交互密度,请参考图1,图1示出了一种现有的终端存储访问的结构示意图,其采用的是套接字阻塞式的通信方式。在底层的存储框架层,虽然有多个线程协同工作,但是每个线程各司其职,真正处理上层发送过来的命令的,仍然是单通道的模式。也就是说,上层有多个线程访问存储架构,然而底层的存储架构只有一个阻塞式套接字和底层进行交互,前端的多个业务线程需要抢占式使用和等待,这样等待线程就很可能由于等待时间过长而造成前端应用anr(applicationnotresponding,应用程序无响应)的发生,给用户的体验带来极大的困扰。技术实现要素:本发明要解决的技术问题在于如何避免现有终端前端业务和底层存储交互机制迟滞,导致容易发生anr,用户体验差的问题;针对该技术问题,提供一种业务交互方法,包括:异步接收前端业务线程发起的存储访问消息;根据所述存储访问消息,在套接字池中申请套接字;根据所述套接字,在线程池中为所述存储访问消息分配处理线程,通过所述处理线程独立处理所述存储访问消息。可选的,所述异步接收前端业务线程发起的存储访问消息包括:所述前端业务处理线程以非阻塞式发起所述存储访问消息。可选的,在所述根据所述存储访问消息,在套接字池中申请套接字之前,还包括:按照各所述前端业务线程发起的存储访问消息的时间顺序,依次对所述存储访问消息进行缓存。可选的,在所述通过所述处理线程独立处理所述存储访问消息之后,还包括:当所述处理线程处理所述存储访问消息完成后,将处理结果通过广播通知对应的所述前端业务线程。可选的,在所述异步接收业务线程发起的存储访问消息之后,还包括:监听所述处理线程处理所述存储访问消息的处理结果。本发明还提供一种终端,包括处理器、存储器以及通信总线;所述通信总线用于实现处理器和存储器之间的连接通信;所述处理器用于执行存储器中存储的业务交互程序,以实现:异步接收前端业务线程发起的存储访问消息;根据所述存储访问消息,在套接字池中申请套接字;根据所述套接字,在线程池中为所述存储访问消息分配处理线程,通过所述处理线程独立处理所述存储访问消息。可选的,所述异步接收前端业务线程发起的存储访问消息包括:所述前端业务处理线程以非阻塞式发起所述存储访问消息。可选的,在所述根据所述存储访问消息,在套接字池中申请套接字之前,所述处理器还用于执行存储器中存储的业务交互程序,以实现:按照各所述前端业务线程发起的存储访问消息的时间顺序,依次对所述存储访问消息进行缓存。可选的,在所述通过所述处理线程独立处理所述存储访问消息之后,所述处理器还用于执行存储器中存储的业务交互程序,以实现:当所述处理线程处理所述存储访问消息完成后,将处理结果通过广播通知对应的所述前端业务线程。本发明还提供一种计算机可读存储介质,所述计算机可读存储介质存储有一个或者多个程序,所述一个程序或者多个程序可被一个或者多个处理器执行,以实现以下步骤:异步接收前端业务线程发起的存储访问消息;根据所述存储访问消息,在套接字池中申请套接字;根据所述套接字,在线程池中为所述存储访问消息分配处理线程,通过所述处理线程独立处理所述存储访问消息。有益效果本发明提供了一种业务交互方法、终端和计算机可读存储介质,异步接收前端业务线程发起的存储访问消息;然后,根据存储访问消息,在套接字池中申请套接字;根据套接字,在线程池中为存储访问消息分配处理线程,通过处理线程独立处理所述存储访问消息。通过本发明的实施,增设的套接字池和线程池为多任务同时执行提供了可能,且通过异步的形式进行交互,业务线程发起之后无需等待,显著降低了anr的几率,改善了用户体验。附图说明下面将结合附图及实施例对本发明作进一步说明,附图中:图1为现有的终端存储访问结构示意图;图2为实现本发明各个实施例一个可选的移动终端的硬件结构示意图;图3为本发明第一实施例提供的业务交互方法流程图;图4为本发明第二实施例提供的业务交互方法流程图;图5为本发明第三实施例提供的终端组成示意图;图6为本发明第四实施例提供的业务交互装置组成示意图。具体实施方式应当理解,此处所描述的具体实施例仅仅用以解释本发明,并不用于限定本发明。在后续的描述中,使用用于表示元件的诸如“模块”、“部件”或“单元”的后缀仅为了有利于本发明的说明,其本身没有特定的意义。因此,“模块”、“部件”或“单元”可以混合地使用。终端可以以各种形式来实施。例如,本发明中描述的终端可以包括诸如手机、平板电脑、笔记本电脑、掌上电脑、个人数字助理(personaldigitalassistant,pda)、便捷式媒体播放器(portablemediaplayer,pmp)、导航装置、可穿戴设备、智能手环、计步器等移动终端,以及诸如数字tv、台式计算机等固定终端。后续描述中将以移动终端为例进行说明,本领域技术人员将理解的是,除了特别用于移动目的的元件之外,根据本发明的实施方式的构造也能够应用于固定类型的终端。请参阅图2,其为实现本发明各个实施例的一种移动终端的硬件结构示意图,该移动终端100可以包括:rf(radiofrequency,射频)单元101、wifi模块102、音频输出单元103、a/v(音频/视频)输入单元104、传感器105、显示单元106、用户输入单元107、接口单元108、存储器109、处理器110、以及电源111等部件。本领域技术人员可以理解,图2中示出的移动终端结构并不构成对移动终端的限定,移动终端可以包括比图示更多或更少的部件,或者组合某些部件,或者不同的部件布置。下面结合图2对移动终端的各个部件进行具体的介绍:射频单元101可用于收发信息或通话过程中,信号的接收和发送,具体的,将基站的下行信息接收后,给处理器110处理;另外,将上行的数据发送给基站。通常,射频单元101包括但不限于天线、至少一个放大器、收发信机、耦合器、低噪声放大器、双工器等。此外,射频单元101还可以通过无线通信与网络和其他设备通信。上述无线通信可以使用任一通信标准或协议,包括但不限于gsm(globalsystemofmobilecommunication,全球移动通讯系统)、gprs(generalpacketradioservice,通用分组无线服务)、cdma2000(codedivisionmultipleaccess2000,码分多址2000)、wcdma(widebandcodedivisionmultipleaccess,宽带码分多址)、td-scdma(timedivision-synchronouscodedivisionmultipleaccess,时分同步码分多址)、fdd-lte(frequencydivisionduplexing-longtermevolution,频分双工长期演进)和tdd-lte(timedivisionduplexing-longtermevolution,分时双工长期演进)等。wifi属于短距离无线传输技术,移动终端通过wifi模块102可以帮助用户收发电子邮件、浏览网页和访问流式媒体等,它为用户提供了无线的宽带互联网访问。虽然图2示出了wifi模块102,但是可以理解的是,其并不属于移动终端的必须构成,完全可以根据需要在不改变发明的本质的范围内而省略。音频输出单元103可以在移动终端100处于呼叫信号接收模式、通话模式、记录模式、语音识别模式、广播接收模式等等模式下时,将射频单元101或wifi模块102接收的或者在存储器109中存储的音频数据转换成音频信号并且输出为声音。而且,音频输出单元103还可以提供与移动终端100执行的特定功能相关的音频输出(例如,呼叫信号接收声音、消息接收声音等等)。音频输出单元103可以包括扬声器、蜂鸣器等等。a/v输入单元104用于接收音频或视频信号。a/v输入单元104可以包括图形处理器(graphicsprocessingunit,gpu)1041和麦克风1042,图形处理器1041对在视频捕获模式或图像捕获模式中由图像捕获装置(如摄像头)获得的静态图片或视频的图像数据进行处理。处理后的图像帧可以显示在显示单元106上。经图形处理器1041处理后的图像帧可以存储在存储器109(或其它存储介质)中或者经由射频单元101或wifi模块102进行发送。麦克风1042可以在电话通话模式、记录模式、语音识别模式等等运行模式中经由麦克风1042接收声音(音频数据),并且能够将这样的声音处理为音频数据。处理后的音频(语音)数据可以在电话通话模式的情况下转换为可经由射频单元101发送到移动通信基站的格式输出。麦克风1042可以实施各种类型的噪声消除(或抑制)算法以消除(或抑制)在接收和发送音频信号的过程中产生的噪声或者干扰。移动终端100还包括至少一种传感器105,比如光传感器、运动传感器以及其他传感器。具体地,光传感器包括环境光传感器及接近传感器,其中,环境光传感器可根据环境光线的明暗来调节显示面板1061的亮度,接近传感器可在移动终端100移动到耳边时,关闭显示面板1061和/或背光。作为运动传感器的一种,加速计传感器可检测各个方向上(一般为三轴)加速度的大小,静止时可检测出重力的大小及方向,可用于识别手机姿态的应用(比如横竖屏切换、相关游戏、磁力计姿态校准)、振动识别相关功能(比如计步器、敲击)等;至于手机还可配置的指纹传感器、压力传感器、虹膜传感器、分子传感器、陀螺仪、气压计、湿度计、温度计、红外线传感器等其他传感器,在此不再赘述。显示单元106用于显示由用户输入的信息或提供给用户的信息。显示单元106可包括显示面板1061,可以采用液晶显示器(liquidcrystaldisplay,lcd)、有机发光二极管(organiclight-emittingdiode,oled)等形式来配置显示面板1061。用户输入单元107可用于接收输入的数字或字符信息,以及产生与移动终端的用户设置以及功能控制有关的键信号输入。具体地,用户输入单元107可包括触控面板1071以及其他输入设备1072。触控面板1071,也称为触摸屏,可收集用户在其上或附近的触摸操作(比如用户使用手指、触笔等任何适合的物体或附件在触控面板1071上或在触控面板1071附近的操作),并根据预先设定的程式驱动相应的连接装置。触控面板1071可包括触摸检测装置和触摸控制器两个部分。其中,触摸检测装置检测用户的触摸方位,并检测触摸操作带来的信号,将信号传送给触摸控制器;触摸控制器从触摸检测装置上接收触摸信息,并将它转换成触点坐标,再送给处理器110,并能接收处理器110发来的命令并加以执行。此外,可以采用电阻式、电容式、红外线以及表面声波等多种类型实现触控面板1071。除了触控面板1071,用户输入单元107还可以包括其他输入设备1072。具体地,其他输入设备1072可以包括但不限于物理键盘、功能键(比如音量控制按键、开关按键等)、轨迹球、鼠标、操作杆等中的一种或多种,具体此处不做限定。进一步的,触控面板1071可覆盖显示面板1061,当触控面板1071检测到在其上或附近的触摸操作后,传送给处理器110以确定触摸事件的类型,随后处理器110根据触摸事件的类型在显示面板1061上提供相应的视觉输出。虽然在图2中,触控面板1071与显示面板1061是作为两个独立的部件来实现移动终端的输入和输出功能,但是在某些实施例中,可以将触控面板1071与显示面板1061集成而实现移动终端的输入和输出功能,具体此处不做限定。接口单元108用作至少一个外部装置与移动终端100连接可以通过的接口。例如,外部装置可以包括有线或无线头戴式耳机端口、外部电源(或电池充电器)端口、有线或无线数据端口、存储卡端口、用于连接具有识别模块的装置的端口、音频输入/输出(i/o)端口、视频i/o端口、耳机端口等等。接口单元108可以用于接收来自外部装置的输入(例如,数据信息、电力等等)并且将接收到的输入传输到移动终端100内的一个或多个元件或者可以用于在移动终端100和外部装置之间传输数据。存储器109可用于存储软件程序以及各种数据。存储器109可主要包括存储程序区和存储数据区,其中,存储程序区可存储操作系统、至少一个功能所需的应用程序(比如声音播放功能、图像播放功能等)等;存储数据区可存储根据手机的使用所创建的数据(比如音频数据、电话本等)等。此外,存储器109可以包括高速随机存取存储器,还可以包括非易失性存储器,例如至少一个磁盘存储器件、闪存器件、或其他易失性固态存储器件。处理器110是移动终端的控制中心,利用各种接口和线路连接整个移动终端的各个部分,通过运行或执行存储在存储器109内的软件程序和/或模块,以及调用存储在存储器109内的数据,执行移动终端的各种功能和处理数据,从而对移动终端进行整体监控。处理器110可包括一个或多个处理单元;优选的,处理器110可集成应用处理器和调制解调处理器,其中,应用处理器主要处理操作系统、用户界面和应用程序等,调制解调处理器主要处理无线通信。可以理解的是,上述调制解调处理器也可以不集成到处理器110中。移动终端100还可以包括给各个部件供电的电源111(比如电池),优选的,电源111可以通过电源管理系统与处理器110逻辑相连,从而通过电源管理系统实现管理充电、放电、以及功耗管理等功能。尽管图2未示出,移动终端100还可以包括蓝牙模块等,在此不再赘述。以下通过具体实施例进行详细说明。第一实施例参照图3,图3为本发明第一实施例提供的业务交互方法流程图。本实施例中的业务交互方法,包括:s301、异步接收前端业务线程发起的存储访问消息;s302、根据存储访问消息,在套接字池中申请套接字;s303、根据套接字,在线程池中为存储访问消息分配处理线程,通过处理线程独立处理存储访问消息。在终端的存储交互流程中,一般是,根据用户的指令,或者是终端自发的,从前端的业务线程发起存储访问消息,其中存储访问消息是针对终端的内存而言,而内存可以包括终端的运行内存或者机身内存,访问消息则是一种可通过终端的处理器识别而执行的一种指令信息。s301中,异步接收前端业务线程发起的存储访问消息。异步,与同步相对应,其中,同步所指的是,在发出一个“调用”时,在没有得到结果之前,该“调用”就不会返回,但是一旦调用返回,就意味着得到返回值了。而异步则不同,“调用”在发出后,这个“调用”就直接返回了,所以并没有返回结果。也就是说,当一个异步“调用”发出后,发起者不会立刻得到结果,而是在“调用”发出后,处理的一端通过状态、通知来通知调用者,或者通过回调函数处理这个调用。异步机制无需发起者持续的等待,前端业务在发起存储访问消息后,可以自行进行其他任务,不用等待这个存储访问消息的处理结果回传。在本实施例中,异步接收的存储访问消息,就意味着这个存储访问消息的处理方式是异步的,非同步的,可以提高前端业务处理的灵活度。其中,异步接收前端业务线程发起的存储访问消息,可以包括:前端业务线程以非阻塞式发起存储访问消息。其中,非阻塞和阻塞相对应,阻塞是指处理结果返回之前,当前线程会被挂起,而该线程只有在得到结果之后才会返回。非阻塞则是指在不能立刻得到结果之前,该调用不会阻塞当前线程。非阻塞指的是,在发起存储访问消息之后,前端业务线程的状态是自如的,不等待对存储访问消息的处理结果,而可以去做其他的事情。s302中,根据存储访问消息,在套接字池中申请套接字。套接字,其定义为,源ip地址和目的ip地址以及源端口号和目的端口号的组合成为套接字。它是网络通信过程中,端点的抽象表示,包含进行网络通信必须的信息,比如:连接使用的协议、本地主机的ip地址、本地进程的协议端口、远程主机的ip地址、远程进程的协议端口等等。套接字,是支持tcp/ip的网络通信的基本操作单元,可以看做是双方进程之间进行双向通信的端点,简单地说就是通信双方的一种约定,用套接字中的相关函数来完成通信过程。多通道的维护依赖于多套接字。套接字就相当于在前端业务线程和底层存储架构之间建立了交互通道。本实施例中的终端设有套接字池,该套接字池中包括多个套接字,在实际应用中,每一个套接字对应于一个前端业务线程和底层存储架构之间的交互通道,每有一个前端业务线程发起了存储访问消息,就可以根据该存储访问消息,在套接字池中申请一个套接字,以便进行后续的处理。在本实施例中,在根据存储访问消息,在套接字池中申请套接字之前,还可以包括:按照各前端业务线程发起的存储访问消息的时间顺序,依次对存储访问消息进行缓存。也就是说,业务线程发起的存储访问消息有两个或者以上时,可以对这些存储访问消息进行缓存,按照其发起的时间顺序,便于后续套接字的分配以及处理线程处理的流程是科学连续的,避免当存储访问消息过多,超过了底层存储架构处理的上限,而可能导致的处理次序紊乱的问题。对这些存储访问消息按照时间顺序进行缓存后,就可以进一步有序的进行后续的处理,保证系统的流畅度,降低anr的几率。s303中,根据套接字,在线程池中为存储访问消息分配处理线程,通过处理线程独立处理存储访问消息。不同于前端业务线程,线程池是底层存储架构中的后台线程。线程池是一种多线程处理形式,处理过程中将任务添加到队列,然后在创建线程后自动启动这些任务。线程池线程都是后台线程。各线程可以使用默认的堆栈大小,以默认的优先级运行,并处于多线程单元中。线程池可以通过多个线程来执行一个任务,但线程池中的线程总数不会超过线程池允许的最大数目。如果在线程池中的当前处理线程的数量已达到的最大线程数,那后续的线程将会被挂起,等待线程池中有线程结束,再执行后续的处理线程。其中,独立处理,所指的是,各不同的存储访问消息对应的处理线程之间是各自独立的,不会互相干扰,处理的结果也是独立的。在本实施例中,通过套接字,确认了前端业务线程,与底层存储架构之间的交互通道,而一个由前端业务线程发起的存储访问消息,对应于一个套接字,以及一个或者多个处理线程。由于套接字池中包括多个套接字,线程池中也包括多个线程,那么,本实施例允许多个前端业务线程发起的存储访问消息同时与底层存储架构进行交互,或者更具体的说,各前端业务线程发起的存储访问消息可同时的在底层存储架构中被处理,无需一个一个的排队等待,明显提升了处理的效率,降低了anr的几率。在本实施例中,在通过处理线程独立处理存储访问消息之后,还可以包括:当处理线程处理存储访问消息完成后,将处理结果通过广播通知对应的前端业务线程。由于存储访问消息是异步形式处理的,前端业务线程无需挂起等待处理结果,那么,在处理完成后,可以以广播的形式,将处理结果通过对应的前端业务线程。在本实施例中,这一过程除了广播的通知形式,还可以通过状态、通知,或者回调函数来通知前端业务线程。在本实施例中,在异步接收业务线程发起的存储访问消息之后,还可以包括:监听处理线程处理存储访问消息的处理结果。由于前端业务线程在发起存储访问消息之后,就可以进行其他的活动,为了及时的得知本次存储访问消息的处理结果,那么,还可以通过监听的方式,监听处理线程处理存储访问消息的处理结果。与广播通知对应的前端业务线程不同,本实施例中的监听过程是设置在前端业务线程侧的,监听可以是监听广播通知的处理结果,也可以直接监听处理线程对存储访问消息的处理结果。广播过程可以直接通知前端业务线程,或者通知对应前端业务线程中,用于监听的部分。本实施例提供了一种业务交互方法,异步接收前端业务线程发起的存储访问消息;然后,根据存储访问消息,在套接字池中申请套接字;根据套接字,在线程池中为存储访问消息分配处理线程,通过处理线程独立处理所述存储访问消息。通过本实施例的实施,增设的套接字池和线程池为多任务同时执行提供了可能,且通过异步的形式进行交互,业务线程发起之后无需等待,显著降低了anr的几率,改善了用户体验。第二实施例请参考图4,图4为本发明第二实施例提供的业务交互方法流程图。本实施例中的业务交互方法,包括:s401、前端业务线程以异步非阻塞的形式,向底层存储架构发起存储访问消息;s402、底部存储架构接收存储访问消息;s403、根据接收到的存储访问消息的生成的时间顺序进行顺序缓存;s404、依次根据缓存顺序,在套接字池中申请套接字;s405、根据套接字,在线程池中为存储访问消息分配处理线程,通过处理线程独立处理存储访问消息;s406、当处理线程处理存储访问消息完成后,将处理结果通过广播通知对应的前端业务线程。在终端的存储交互流程中,一般是,根据用户的指令,或者是终端自发的,从前端的业务线程发起存储访问消息,其中存储访问消息是针对终端的内存而言,而内存可以包括终端的运行内存或者机身内存,访问消息则是一种可通过终端的处理器识别而执行的一种指令信息。s401中,前端业务线程以异步非阻塞式发起存储访问消息。其中,异步与同步相对应,其中,同步所指的是,在发出一个“调用”时,在没有得到结果之前,该“调用”就不会返回,但是一旦调用返回,就意味着得到返回值了。而异步则不同,“调用”在发出后,这个“调用”就直接返回了,所以并没有返回结果。也就是说,当一个异步“调用”发出后,发起者不会立刻得到结果,而是在“调用”发出后,处理的一端通过状态、通知来通知调用者,或者通过回调函数处理这个调用。异步机制无需发起者持续的等待,前端业务在发起存储访问消息后,可以自行进行其他任务,不用等待这个存储访问消息的处理结果回传。在本实施例中,异步接收的存储访问消息,就意味着这个存储访问消息的处理方式是异步的,非同步的,可以提高前端业务处理的灵活度。而非阻塞则与阻塞对应,阻塞是指处理结果返回之前,当前线程会被挂起,而该线程只有在得到结果之后才会返回。非阻塞则是指在不能立刻得到结果之前,该调用不会阻塞当前线程。非阻塞指的是,在发起存储访问消息之后,前端业务线程的状态是自如的,不等待对存储访问消息的处理结果,而可以去做其他的事情。s403中,业务线程发起的存储访问消息有两个或者以上时,可以对这些存储访问消息进行缓存,按照其发起的时间顺序,便于后续套接字的分配以及处理线程处理的流程是科学连续的,避免当存储访问消息过多,超过了底层存储架构处理的上限,而可能导致的处理次序紊乱的问题。对这些存储访问消息按照时间顺序进行缓存后,就可以进一步有序的进行后续的处理,保证系统的流畅度,降低anr的几率。s404中,套接字是网络通信过程中,端点的抽象表示,包含进行网络通信必须的信息,比如连接使用的协议、本地主机的ip地址、本地进程的协议端口、远程主机的ip地址、远程进程的协议端口等等。套接字,是支持tcp/ip的网络通信的基本操作单元,可以看做是双方进程之间进行双向通信的端点,简单地说就是通信双方的一种约定,用套接字中的相关函数来完成通信过程。多通道的维护依赖于多套接字。套接字就相当于在前端业务线程和底层存储架构之间建立了交互通道。s405中,不同于前端业务线程,线程池是底层存储架构中的后台线程。线程池是一种多线程处理形式,处理过程中将任务添加到队列,然后在创建线程后自动启动这些任务。线程池线程都是后台线程。各线程可以使用默认的堆栈大小,以默认的优先级运行,并处于多线程单元中。线程池可以通过多个线程来执行一个任务,但线程池中的线程总数不会超过线程池允许的最大数目。如果在线程池中的当前处理线程的数量已达到的最大线程数,那后续的线程将会被挂起,等待线程池中有线程结束,再执行后续的处理线程。其中,独立处理,所指的是,各不同的存储访问消息对应的处理线程之间是各自独立的,不会互相干扰,处理的结果也是独立的。s406中,由于存储访问消息是异步形式处理的,前端业务线程无需挂起等待处理结果,那么,在处理完成后,可以以广播的形式,将处理结果通过对应的前端业务线程。在本实施例中,这一过程除了广播的通知形式,还可以通过状态、通知,或者回调函数来通知前端业务线程。在本实施例中,在前端业务线程以异步非阻塞对底层存储架构发起存储访问消息之后,还可以包括:监听处理线程处理存储访问消息的处理结果。由于前端业务线程在发起存储访问消息之后,就可以进行其他的活动,为了及时的得知本次存储访问消息的处理结果,那么,还可以通过监听的方式,监听处理线程处理存储访问消息的处理结果。与广播通知对应的前端业务线程不同,本实施例中的监听过程是设置在前端业务线程侧的,监听可以是监听广播通知的处理结果,也可以直接监听处理线程对存储访问消息的处理结果。广播过程可以直接通知前端业务线程,或者通知对应前端业务线程中,用于监听的部分。本实施例提供了一种业务交互方法,前端业务线程以异步非阻塞的形式,向底层存储架构发起存储访问消息;底部存储架构接收存储访问消息,并按照时间顺序进行缓存;然后,根据存储访问消息,在套接字池中申请套接字;根据套接字,在线程池中为存储访问消息分配处理线程,通过处理线程独立处理所述存储访问消息;在处理完成后,将处理结果通过广播通知对应的前端业务线程。通过本实施例的实施,增设的套接字池和线程池为多任务同时执行提供了可能,且通过异步的形式进行交互,业务线程发起之后无需等待,显著降低了anr的几率,改善了用户体验。第三实施例请参考图5,图5为本发明第三实施例提供的终端组成示意图。本实施例中的终端,包括处理器110,存储器109以及通信总线501;其中:通信总线501用于实现处理器110和存储器109之间的连接通信;处理器110用于执行存储器109中存储的业务交互程序,以实现:异步接收前端业务线程发起的存储访问消息;根据存储访问消息,在套接字池中申请套接字;根据套接字,在线程池中为存储访问消息分配处理线程,通过处理线程独立处理存储访问消息。在终端的存储交互流程中,一般是,根据用户的指令,或者是终端自发的,从前端的业务线程发起存储访问消息,其中存储访问消息是针对终端的内存而言,而内存可以包括终端的运行内存或者机身内存,访问消息则是一种可通过终端的处理器110识别而执行的一种指令信息。本实施例中,处理器110执行业务交互程序,首先实现:异步接收前端业务线程发起的存储访问消息。异步,与同步相对应,其中,同步所指的是,在发出一个“调用”时,在没有得到结果之前,该“调用”就不会返回,但是一旦调用返回,就意味着得到返回值了。而异步则不同,“调用”在发出后,这个“调用”就直接返回了,所以并没有返回结果。也就是说,当一个异步“调用”发出后,发起者不会立刻得到结果,而是在“调用”发出后,处理的一端通过状态、通知来通知调用者,或者通过回调函数处理这个调用。异步机制无需发起者持续的等待,前端业务在发起存储访问消息后,可以自行进行其他任务,不用等待这个存储访问消息的处理结果回传。在本实施例中,异步接收的存储访问消息,就意味着这个存储访问消息的处理方式是异步的,非同步的,可以提高前端业务处理的灵活度。其中,异步接收前端业务线程发起的存储访问消息,可以包括:前端业务线程以非阻塞式发起存储访问消息。其中,非阻塞和阻塞相对应,阻塞是指处理结果返回之前,当前线程会被挂起,而该线程只有在得到结果之后才会返回。非阻塞则是指在不能立刻得到结果之前,该调用不会阻塞当前线程。非阻塞指的是,在发起存储访问消息之后,前端业务线程的状态是自如的,不等待对存储访问消息的处理结果,而可以去做其他的事情。本实施例中,处理器110执行业务交互程序,然后实现:根据存储访问消息,在套接字池中申请套接字。套接字,其定义为,源ip地址和目的ip地址以及源端口号和目的端口号的组合成为套接字。它是网络通信过程中,端点的抽象表示,包含进行网络通信必须的信息,比如:连接使用的协议、本地主机的ip地址、本地进程的协议端口、远程主机的ip地址、远程进程的协议端口等等。套接字,是支持tcp/ip的网络通信的基本操作单元,可以看做是双方进程之间进行双向通信的端点,简单地说就是通信双方的一种约定,用套接字中的相关函数来完成通信过程。多通道的维护依赖于多套接字。套接字就相当于在前端业务线程和底层存储架构之间建立了交互通道。本实施例中的终端设有套接字池,该套接字池中包括多个套接字,在实际应用中,每一个套接字对应于一个前端业务线程和底层存储架构之间的交互通道,每有一个前端业务线程发起了存储访问消息,就可以根据该存储访问消息,在套接字池中申请一个套接字,以便进行后续的处理。在本实施例中,在根据存储访问消息,在套接字池中申请套接字之前,处理器110还可以执行存储器109中存储的业务交互程序,以实现:按照各前端业务线程发起的存储访问消息的时间顺序,依次对存储访问消息进行缓存。也就是说,业务线程发起的存储访问消息有两个或者以上时,可以对这些存储访问消息进行缓存,按照其发起的时间顺序,便于后续套接字的分配以及处理线程处理的流程是科学连续的,避免当存储访问消息过多,超过了底层存储架构处理的上限,而可能导致的处理次序紊乱的问题。对这些存储访问消息按照时间顺序进行缓存后,就可以进一步有序的进行后续的处理,保证系统的流畅度,降低anr的几率。本实施例中,处理器110执行业务交互程序,然后实现:根据套接字,在线程池中为存储访问消息分配处理线程,通过处理线程独立处理存储访问消息。不同于前端业务线程,线程池是底层存储架构中的后台线程。线程池是一种多线程处理形式,处理过程中将任务添加到队列,然后在创建线程后自动启动这些任务。线程池线程都是后台线程。各线程可以使用默认的堆栈大小,以默认的优先级运行,并处于多线程单元中。线程池可以通过多个线程来执行一个任务,但线程池中的线程总数不会超过线程池允许的最大数目。如果在线程池中的当前处理线程的数量已达到的最大线程数,那后续的线程将会被挂起,等待线程池中有线程结束,再执行后续的处理线程。其中,独立处理,所指的是,各不同的存储访问消息对应的处理线程之间是各自独立的,不会互相干扰,处理的结果也是独立的。在本实施例中,通过套接字,确认了前端业务线程,与底层存储架构之间的交互通道,而一个由前端业务线程发起的存储访问消息,对应于一个套接字,以及一个或者多个处理线程。由于套接字池中包括多个套接字,线程池中也包括多个线程,那么,本实施例允许多个前端业务线程发起的存储访问消息同时与底层存储架构进行交互,或者更具体的说,各前端业务线程发起的存储访问消息可同时的在底层存储架构中被处理,无需一个一个的排队等待,明显提升了处理的效率,降低了anr的几率。在本实施例中,在通过处理线程独立处理存储访问消息之后,处理器110还可以执行存储器109中存储的业务交互程序,以实现:当处理线程处理存储访问消息完成后,将处理结果通过广播通知对应的前端业务线程。由于存储访问消息是异步形式处理的,前端业务线程无需挂起等待处理结果,那么,在处理完成后,可以以广播的形式,将处理结果通过对应的前端业务线程。在本实施例中,这一过程除了广播的通知形式,还可以通过状态、通知,或者回调函数来通知前端业务线程。在本实施例中,在异步接收业务线程发起的存储访问消息之后,处理器110还可以执行存储器109中存储的业务交互程序,以实现:监听处理线程处理存储访问消息的处理结果。由于前端业务线程在发起存储访问消息之后,就可以进行其他的活动,为了及时的得知本次存储访问消息的处理结果,那么,还可以通过监听的方式,监听处理线程处理存储访问消息的处理结果。与广播通知对应的前端业务线程不同,本实施例中的监听过程是设置在前端业务线程侧的,监听可以是监听广播通知的处理结果,也可以直接监听处理线程对存储访问消息的处理结果。广播过程可以直接通知前端业务线程,或者通知对应前端业务线程中,用于监听的部分。本实施例提供了一种终端,异步接收前端业务线程发起的存储访问消息;然后,根据存储访问消息,在套接字池中申请套接字;根据套接字,在线程池中为存储访问消息分配处理线程,通过处理线程独立处理所述存储访问消息。通过本实施例的实施,增设的套接字池和线程池为多任务同时执行提供了可能,且通过异步的形式进行交互,业务线程发起之后无需等待,显著降低了anr的几率,改善了用户体验。第四实施例请参考图6,图6为本发明第四实施例提供的一种业务交互装置组成示意图。本实施例中的业务交互装置,包括:访问接收模块601,接收前端业务线程以异步非阻塞方式发起的存储访问消息;访问队列模块602,用于根据接收到的存储访问消息的生成的时间顺序进行顺序缓存;调度模块603,用于依次根据缓存顺序,在套接字池中申请套接字;线程池模块604,用于根据套接字,在线程池中为存储访问消息分配处理线程,通过处理线程独立处理存储访问消息;广播模块605,用于当处理线程处理存储访问消息完成后,将处理结果通过广播通知对应的前端业务线程。在终端的存储交互流程中,一般是,根据用户的指令,或者是终端自发的,从前端的业务线程发起存储访问消息,其中存储访问消息是针对终端的内存而言,而内存可以包括终端的运行内存或者机身内存,访问消息则是一种可通过终端的处理器识别而执行的一种指令信息。在本实施例中,访问接收模块601接收前端业务线程以异步非阻塞方式发起的存储访问消息。其中,异步与同步相对应,其中,同步所指的是,在发出一个“调用”时,在没有得到结果之前,该“调用”就不会返回,但是一旦调用返回,就意味着得到返回值了。而异步则不同,“调用”在发出后,这个“调用”就直接返回了,所以并没有返回结果。也就是说,当一个异步“调用”发出后,发起者不会立刻得到结果,而是在“调用”发出后,处理的一端通过状态、通知来通知调用者,或者通过回调函数处理这个调用。异步机制无需发起者持续的等待,前端业务在发起存储访问消息后,可以自行进行其他任务,不用等待这个存储访问消息的处理结果回传。在本实施例中,异步接收的存储访问消息,就意味着这个存储访问消息的处理方式是异步的,非同步的,可以提高前端业务处理的灵活度。而非阻塞则与阻塞对应,阻塞是指处理结果返回之前,当前线程会被挂起,而该线程只有在得到结果之后才会返回。非阻塞则是指在不能立刻得到结果之前,该调用不会阻塞当前线程。非阻塞指的是,在发起存储访问消息之后,前端业务线程的状态是自如的,不等待对存储访问消息的处理结果,而可以去做其他的事情。业务线程发起的存储访问消息有两个或者以上时,可以对这些存储访问消息进行缓存,按照其发起的时间顺序,便于后续套接字的分配以及处理线程处理的流程是科学连续的,避免当存储访问消息过多,超过了底层存储架构处理的上限,而可能导致的处理次序紊乱的问题。对这些存储访问消息按照时间顺序进行缓存后,就可以进一步有序的进行后续的处理,保证系统的流畅度,降低anr的几率。套接字是网络通信过程中,端点的抽象表示,包含进行网络通信必须的信息,比如连接使用的协议、本地主机的ip地址、本地进程的协议端口、远程主机的ip地址、远程进程的协议端口等等。套接字,是支持tcp/ip的网络通信的基本操作单元,可以看做是双方进程之间进行双向通信的端点,简单地说就是通信双方的一种约定,用套接字中的相关函数来完成通信过程。多通道的维护依赖于多套接字。套接字就相当于在前端业务线程和底层存储架构之间建立了交互通道。不同于前端业务线程,线程池是底层存储架构中的后台线程。线程池是一种多线程处理形式,处理过程中将任务添加到队列,然后在创建线程后自动启动这些任务。线程池线程都是后台线程。各线程可以使用默认的堆栈大小,以默认的优先级运行,并处于多线程单元中。线程池可以通过多个线程来执行一个任务,但线程池中的线程总数不会超过线程池允许的最大数目。如果在线程池中的当前处理线程的数量已达到的最大线程数,那后续的线程将会被挂起,等待线程池中有线程结束,再执行后续的处理线程。其中,独立处理,所指的是,各不同的存储访问消息对应的处理线程之间是各自独立的,不会互相干扰,处理的结果也是独立的。由于存储访问消息是异步形式处理的,前端业务线程无需挂起等待处理结果,那么,在处理完成后,可以以广播的形式,将处理结果通过对应的前端业务线程。在本实施例中,这一过程除了广播的通知形式,还可以通过状态、通知,或者回调函数来通知前端业务线程。在本实施例中,还可以包括监听模块606,用于在前端业务线程以异步非阻塞对底层存储架构发起存储访问消息之后,监听处理线程处理存储访问消息的处理结果。由于前端业务线程在发起存储访问消息之后,就可以进行其他的活动,为了及时的得知本次存储访问消息的处理结果,那么,还可以通过监听的方式,监听处理线程处理存储访问消息的处理结果。与广播通知对应的前端业务线程不同,本实施例中的监听过程是设置在前端业务线程侧的,监听可以是监听广播通知的处理结果,也可以直接监听处理线程对存储访问消息的处理结果。广播过程可以直接通知前端业务线程,或者通知对应前端业务线程中,用于监听的部分。本实施例提供了一种业务交互装置,接收前端业务线程以异步非阻塞的形式发起的存储访问消息,并按照时间顺序进行缓存;然后,根据存储访问消息,在套接字池中申请套接字;根据套接字,在线程池中为存储访问消息分配处理线程,通过处理线程独立处理所述存储访问消息;在处理完成后,将处理结果通过广播通知对应的前端业务线程。通过本实施例的实施,增设的套接字池和线程池为多任务同时执行提供了可能,且通过异步的形式进行交互,业务线程发起之后无需等待,显著降低了anr的几率,改善了用户体验。第五实施例本实施例提供了一种计算机可读存储介质,该计算机可读存储介质中存储有一个或者多个程序,一个或者多个程序可被一个或者多个处理器执行,以实现:异步接收前端业务线程发起的存储访问消息;根据存储访问消息,在套接字池中申请套接字;根据套接字,在线程池中为存储访问消息分配处理线程,通过处理线程独立处理存储访问消息。异步,与同步相对应,其中,同步所指的是,在发出一个“调用”时,在没有得到结果之前,该“调用”就不会返回,但是一旦调用返回,就意味着得到返回值了。而异步则不同,“调用”在发出后,这个“调用”就直接返回了,所以并没有返回结果。也就是说,当一个异步“调用”发出后,发起者不会立刻得到结果,而是在“调用”发出后,处理的一端通过状态、通知来通知调用者,或者通过回调函数处理这个调用。异步机制无需发起者持续的等待,前端业务在发起存储访问消息后,可以自行进行其他任务,不用等待这个存储访问消息的处理结果回传。在本实施例中,异步接收的存储访问消息,就意味着这个存储访问消息的处理方式是异步的,非同步的,可以提高前端业务处理的灵活度。其中,异步接收前端业务线程发起的存储访问消息,可以包括:前端业务线程以非阻塞式发起存储访问消息。其中,非阻塞和阻塞相对应,阻塞是指处理结果返回之前,当前线程会被挂起,而该线程只有在得到结果之后才会返回。非阻塞则是指在不能立刻得到结果之前,该调用不会阻塞当前线程。非阻塞指的是,在发起存储访问消息之后,前端业务线程的状态是自如的,不等待对存储访问消息的处理结果,而可以去做其他的事情。套接字,其定义为,源ip地址和目的ip地址以及源端口号和目的端口号的组合成为套接字。它是网络通信过程中,端点的抽象表示,包含进行网络通信必须的信息,比如:连接使用的协议、本地主机的ip地址、本地进程的协议端口、远程主机的ip地址、远程进程的协议端口等等。套接字,是支持tcp/ip的网络通信的基本操作单元,可以看做是双方进程之间进行双向通信的端点,简单地说就是通信双方的一种约定,用套接字中的相关函数来完成通信过程。多通道的维护依赖于多套接字。套接字就相当于在前端业务线程和底层存储架构之间建立了交互通道。本实施例中的终端设有套接字池,该套接字池中包括多个套接字,在实际应用中,每一个套接字对应于一个前端业务线程和底层存储架构之间的交互通道,每有一个前端业务线程发起了存储访问消息,就可以根据该存储访问消息,在套接字池中申请一个套接字,以便进行后续的处理。在本实施例中,在根据存储访问消息,在套接字池中申请套接字之前,还可以包括:按照各前端业务线程发起的存储访问消息的时间顺序,依次对存储访问消息进行缓存。也就是说,业务线程发起的存储访问消息有两个或者以上时,可以对这些存储访问消息进行缓存,按照其发起的时间顺序,便于后续套接字的分配以及处理线程处理的流程是科学连续的,避免当存储访问消息过多,超过了底层存储架构处理的上限,而可能导致的处理次序紊乱的问题。对这些存储访问消息按照时间顺序进行缓存后,就可以进一步有序的进行后续的处理,保证系统的流畅度,降低anr的几率。不同于前端业务线程,线程池是底层存储架构中的后台线程。线程池是一种多线程处理形式,处理过程中将任务添加到队列,然后在创建线程后自动启动这些任务。线程池线程都是后台线程。各线程可以使用默认的堆栈大小,以默认的优先级运行,并处于多线程单元中。线程池可以通过多个线程来执行一个任务,但线程池中的线程总数不会超过线程池允许的最大数目。如果在线程池中的当前处理线程的数量已达到的最大线程数,那后续的线程将会被挂起,等待线程池中有线程结束,再执行后续的处理线程。其中,独立处理,所指的是,各不同的存储访问消息对应的处理线程之间是各自独立的,不会互相干扰,处理的结果也是独立的。在本实施例中,通过套接字,确认了前端业务线程,与底层存储架构之间的交互通道,而一个由前端业务线程发起的存储访问消息,对应于一个套接字,以及一个或者多个处理线程。由于套接字池中包括多个套接字,线程池中也包括多个线程,那么,本实施例允许多个前端业务线程发起的存储访问消息同时与底层存储架构进行交互,或者更具体的说,各前端业务线程发起的存储访问消息可同时的在底层存储架构中被处理,无需一个一个的排队等待,明显提升了处理的效率,降低了anr的几率。在本实施例中,在通过处理线程独立处理存储访问消息之后,还可以包括:当处理线程处理存储访问消息完成后,将处理结果通过广播通知对应的前端业务线程。由于存储访问消息是异步形式处理的,前端业务线程无需挂起等待处理结果,那么,在处理完成后,可以以广播的形式,将处理结果通过对应的前端业务线程。在本实施例中,这一过程除了广播的通知形式,还可以通过状态、通知,或者回调函数来通知前端业务线程。在本实施例中,在异步接收业务线程发起的存储访问消息之后,还可以包括:监听处理线程处理存储访问消息的处理结果。由于前端业务线程在发起存储访问消息之后,就可以进行其他的活动,为了及时的得知本次存储访问消息的处理结果,那么,还可以通过监听的方式,监听处理线程处理存储访问消息的处理结果。与广播通知对应的前端业务线程不同,本实施例中的监听过程是设置在前端业务线程侧的,监听可以是监听广播通知的处理结果,也可以直接监听处理线程对存储访问消息的处理结果。广播过程可以直接通知前端业务线程,或者通知对应前端业务线程中,用于监听的部分。上面结合附图对本发明的实施例进行了描述,但是本发明并不局限于上述的具体实施方式,上述的具体实施方式仅仅是示意性的,而不是限制性的,本领域的普通技术人员在本发明的启示下,在不脱离本发明宗旨和权利要求所保护的范围情况下,还可做出很多形式,这些均属于本发明的保护之内。当前第1页12当前第1页12
当前第1页1 2 
网友询问留言 已有0条留言
  • 还没有人留言评论。精彩留言会获得点赞!
1