CN108363629B - 用于即时通信的方法、介质、装置和计算设备 - Google Patents

用于即时通信的方法、介质、装置和计算设备 Download PDF

Info

Publication number
CN108363629B
CN108363629B CN201810169665.3A CN201810169665A CN108363629B CN 108363629 B CN108363629 B CN 108363629B CN 201810169665 A CN201810169665 A CN 201810169665A CN 108363629 B CN108363629 B CN 108363629B
Authority
CN
China
Prior art keywords
user interaction
push
push process
interaction process
communication link
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.)
Active
Application number
CN201810169665.3A
Other languages
English (en)
Other versions
CN108363629A (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.)
Hangzhou Netease Zhiqi Technology Co Ltd
Original Assignee
Hangzhou Langhe 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 Hangzhou Langhe Technology Co Ltd filed Critical Hangzhou Langhe Technology Co Ltd
Priority to CN201810169665.3A priority Critical patent/CN108363629B/zh
Publication of CN108363629A publication Critical patent/CN108363629A/zh
Application granted granted Critical
Publication of CN108363629B publication Critical patent/CN108363629B/zh
Active legal-status Critical Current
Anticipated expiration legal-status Critical

Links

Images

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/54Interprogram communication
    • G06F9/544Buffers; Shared memory; Pipes
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L51/00User-to-user messaging in packet-switching networks, transmitted according to store-and-forward or real-time protocols, e.g. e-mail
    • H04L51/04Real-time or near real-time messaging, e.g. instant messaging [IM]

Abstract

本发明的实施方式提供了一种用于即时通信的方法,所述即时通信包括通过用户交互进程和推送进程进行信息传输,包括:建立所述用户交互进程与所述推送进程之间的通信链接通道,用于所述用户交互进程和所述推送进程之间的信息传输;从所述连接记录中移除所述通信链接通道的信息;以及建立所述用户交互进程与所述推送进程之间的辅助连接通道,其中,所述辅助连接通道的信息被记录在所述连接记录中,用于保持所述推送进程的优先级。本发明的方法避免了通信链接通道意外情况断开链接后无法在重新建立的问题,并同时保证了推送进程的优先级。此外,本发明的实施方式提供了一种用于即时通信的计算机可读介质、装置、和计算设备。

Description

用于即时通信的方法、介质、装置和计算设备
技术领域
本发明的实施方式涉及互联网领域,更具体地,本发明的实施方式涉及一种用于即时通信的方法、介质、装置和计算设备。
背景技术
本部分旨在为权利要求书中陈述的本发明的实施方式提供背景或上下文。此处的描述不因为包括在本部分中就承认是现有技术。
在整个即时通信技术领域中,信息传输的稳定性、准确性和及时性是非常关键的。根据即时通信的进程和业务拆分,可以将即时通信系统架构分为单进程结构和多进程结构。在多进程结构中,一种常见的结构为双进程结构。在双进程结构中,可以通过用户交互进程与推送进程协同工作实现即时通信的功能。
在双进程结构中,用户交互进程和推送进程之间往往仅有一个通信链接通道,并且用户交互进程和推送进程通过该通信链接通道实现彼此绑定、以及传输信息。然而,现有技术中,在一些极端情况下,推送进程中建立的通信链接通道的服务模块被意外杀死后,在即时通信系统可能就无法重新建立起用户交互进程与所述推送进程之间的通信链接通道。在这种情况下,用户交互进程和推送进程就无法继续传输信息,从而导致即时通信系统失效,无法再正常使用。
发明内容
在本上下文中,本发明的实施方式期望提供一种更加稳定的用于即时通信的方法、介质、装置和计算设备。
在本发明实施方式的第一方面中,提供了一种用于即时通信的方法。所述即时通信包括通过用户交互进程和推送进程进行信息传输,其中,所述用户交互进程用于接收和处理用户交互信息,所述推送进程用于维护与外部服务器的长连接。所述方法包括:建立所述用户交互进程与所述推送进程之间的通信链接通道,其中,所述通信链接通道用于所述用户交互进程和所述推送进程之间的信息传输,所述通信链接通道的信息被记录在连接记录中;从所述连接记录中移除所述通信链接通道的信息;以及建立所述用户交互进程与所述推送进程之间的辅助连接通道,其中,所述辅助连接通道的信息被记录在所述连接记录中,用于保持所述推送进程的优先级。
在本发明的一个实施例中,所述通信链接通道的信息包括表征所述用户交互进程绑定了所述推送进程的信息。
在本发明的另一个实施例中,从所述连接记录中移除所述通信链接通道的信息,包括在监测到将所述用户交互进程和所述推送进程解除绑定的情况下,从所述连接记录中移除所述通信链接通道的信息。
在本发明的又一个实施例中,所述辅助连接通道的信息包括表征所述用户交互进程绑定了所述推送进程的信息。
在本发明的又一个实施例中,所述方法还包括所述用户交互进程与所述推送进程通过所述通信链接通道传输信息。在本发明的又一个实施例中,当所述用户交互进程与所述推送进程之间传输的数据包的数据量大于阈值数据量时,所述用户交互进程与所述推送进程通过所述通信链接通道传输信息,包括将所述数据包拆分成多个子数据包,其中所述多个子数据包中的每个数据包的数据量小于所述阈值数据量,通过所述通信链接通道依次传输所述多个子数据包,以及将传输完成的所述多个子数据包进行组装,得到所述数据包。在本发明的又一个实施例中,所述用户交互进程与所述推送进程通过所述通信链接通道传输信息,包括所述用户交互进程接收到所述推送进程发送的数据包后向所述推送进程发送确认回执,以及所述推送进程在接收到所述确认回执后再向所述用户交互进程发送下一个数据包。在本发明的又一个实施例中,所述推送进程在接收到所述确认回执后再向所述用户交互进程发送下一个数据包,包括当所述推送进程在预设确收时间内未收到所述确认回执时,所述推送进程重复以下操作,直到接收到所述确认回执:向所述外部服务器发送所述数据包补充请求,以及在接收到所述外部服务器发送的所述数据包后将所述数据包发送至所述用户交互进程。
在本发明的又一个实施例中,所述方法还包括所述推送进程监听所述用户交互进程的生命周期是否结束,以及响应于所述用户交互进程的生命周期的结束,所述推送进程执行自杀机制以退出服务且不被自动唤醒。在本发明的又一个实施例中,所述推送进程执行自杀机制以退出服务且不被自动唤醒,包括所述推送进程切断所述推送进程的唤醒路径,以及所述推送进程退出服务。
在本发明的又一个实施例中,所述方法还包括所述推送进程创建与所述通信链接通道对应的第一前台服务,所述推送进程创建与所述辅助连接通道对应的第二前台服务,其中第二前台服务与所述第一前台服务的标识相同,以及所述推送进程取消所述第一前台服务和所述第二前台服务其中之一。在本发明的又一个实施例中,当所述推送进程接收到所述外部服务器发送的消息时,且在所述用户交互进程处于未运行的状态下,所述方法还包括所述推送进程唤醒所述用户交互进程。在本发明的又一个实施例中,所述推送进程唤醒所述用户交互进程,包括在所述用户交互进程未被唤醒之前每隔预设唤醒时长唤醒一次,直到所述用户交互进程被唤醒为止,或者直到当唤醒的持续时长大于阈值持续时长为止。在本发明的又一个实施例中,在当唤醒的持续时长大于阈值持续时长时所述用户交互进程仍未被唤醒的情况下,所述方法还包括所述推送进程启动自杀机制以退出服务且不被自动唤醒。
在本发明的又一个实施例中,所述方法还包括所述用户交互进程与所述推送进程通过内容提供器Content Provider共享数据。在本发明的又一个实施例中,所述用户交互进程与所述推送进程通过内容提供器Content Provider共享数据,包括所述用户交互进程获取所述推送进程的最新数据,和/或所述用户交互进程更新所述推送进程的数据,以及决定是否通知所述内容提供器Content Provider提供的数据源观察者,和/或所述用户交互进程监听所述推送进程的数据变更,和/或所述用户交互进程发送数据包给所述推送进程进行处理,和/或所述用户交互进程移除所述推送进程的数据。在本发明的又一个实施例中,所述用户交互进程与所述推送进程通过内容提供器Content Provider共享数据,还包括所述推送进程更新所述用户交互进程的数据,以及通知所述用户交互进程。
在本发明的又一个实施例中,所述方法还包括所述推送进程通过安卓系统的精准闹钟Alarm执行心跳机制,以确定所述推送进程与外部服务器的长连接的有效性。在本发明的又一个实施例中,所述方法还包括从执行心跳机制中首次未收到外部服务器的回应信息超过阈值回应时长时,以第二时间间隔补充发送心跳包,所述第二时间间隔与精准闹钟Alarm中的定时时间间隔相同或不同。在本发明的又一个实施例中,在以第二时间间隔补充发送心跳包的次数达到第二阈值次数时,所述方法还包括所述推送进程断开所述推送进程与外部服务器的连接,以及所述推送进程启动重新建立所述推送进程与外部服务器的长连接。
在本发明的又一个实施例中,所述方法还包括在监测到所述用户交互进程回到前台时或者所述推送进程与外部服务器的长连接连接超时的情况下,所述推送进程向所述外部服务器发送心跳包,以检测所述推送进程与外部服务器的长连接的有效性。
在本发明实施方式的第二方面中,提供了一种计算机可读介质,其上存储有可执行指令,所述指令在被处理器执行时使处理器执行如上所述的用于即时通信的方法。
在本发明实施方式的第三方面中,提供了一种用于即时通信的装置。所述即时通信包括通过用户交互进程和推送进程进行信息传输,其中,所述用户交互进程用于接收和处理用户交互信息,所述推送进程用于维护与外部服务器的长连接,所述装置包括通信链接通道建立模块、通信链接通道的记录信息移除模块、和辅助连接通道建立模块。通信链接通道建立模块用于建立所述用户交互进程与所述推送进程之间的通信链接通道,其中,所述通信链接通道用于所述用户交互进程和所述推送进程之间的信息传输,所述通信链接通道的信息被记录在连接记录中。通信链接通道的记录信息移除模块用于从所述连接记录中移除所述通信链接通道的信息。辅助连接通道建立模块用于建立所述用户交互进程与所述推送进程之间的辅助连接通道,其中,所述辅助连接通道的信息被记录在所述连接记录中,用于保持所述推送进程的优先级。
在本发明的一个实施例中,所述通信链接通道的信息包括表征所述用户交互进程绑定了所述推送进程的信息。
在本发明的另一个实施例中,所述通信链接通道的记录信息移除模块从所述连接记录中移除所述通信链接通道的信息,包括在监测到将所述用户交互进程和所述推送进程解除绑定的情况下,从所述连接记录中移除所述通信链接通道的信息。
在本发明的又一个实施例中,所述辅助连接通道的信息包括表征所述用户交互进程绑定了所述推送进程的信息。
在本发明的又一个实施例中,所述装置还包括进程间信息传输模块。进程间信息传输模块用于所述用户交互进程与所述推送进程通过所述通信链接通道传输信息。在本发明的又一个实施例中,当所述用户交互进程与所述推送进程之间传输的数据包的数据量大于阈值数据量时,所述用户交互进程与所述推送进程通过所述通信链接通道传输信息,包括将所述数据包拆分成多个子数据包,其中所述多个子数据包中的每个数据包的数据量小于所述阈值数据量,通过所述通信链接通道依次传输所述多个子数据包,以及将传输完成的所述多个子数据包进行组装,得到所述数据包。在本发明的又一个实施例中,所述用户交互进程与所述推送进程通过所述通信链接通道传输信息,包括所述用户交互进程接收到所述推送进程发送的数据包后向所述推送进程发送确认回执,以及所述推送进程在接收到所述确认回执后再向所述用户交互进程发送下一个数据包。在本发明的又一个实施例中,所述推送进程在接收到所述确认回执后再向所述用户交互进程发送下一个数据包,包括当所述推送进程在预设确收时间内未收到所述确认回执时,所述推送进程重复以下操作,直到接收到所述确认回执:向所述外部服务器发送所述数据包补充请求;以及在接收到所述外部服务器发送的所述数据包后将所述数据包发送至所述用户交互进程。
在本发明的又一个实施例中,所述装置还包括监听模块、以及推送进程自杀模块。监听模块用于所述推送进程监听所述用户交互进程的生命周期是否结束。推送进程自杀模块用于响应于所述用户交互进程的生命周期的结束,所述推送进程执行自杀机制以退出服务且不被自动唤醒。在本发明的又一个实施例中,所述推送进程执行自杀机制以退出服务且不被自动唤醒,包括所述推送进程切断所述推送进程的唤醒路径,以及所述推送进程退出服务。
在本发明的又一个实施例中,所述装置还包括第一前台服务创建模块、第二前台服务创建模块以及前台服务取消模块。第一前台服务创建模块用于所述推送进程创建与所述通信链接通道对应的第一前台服务。第二前台服务创建模块用于所述推送进程创建与所述辅助连接通道对应的第二前台服务,其中第二前台服务与所述第一前台服务的标识相同。前台服务取消模块用于所述推送进程取消所述第一前台服务和所述第二前台服务其中之一。在本发明的一个实施例中,当所述推送进程接收到所述外部服务器发送的消息时,且在所述用户交互进程处于未运行的状态下,所述装置还包括用户交互进程唤醒模块。用户交互进程唤醒模块用于所述推送进程唤醒所述用户交互进程。在本发明的又一个实施例中,所述推送进程唤醒所述用户交互进程,包括在所述用户交互进程未被唤醒之前每隔预设唤醒时长唤醒一次,直到所述用户交互进程被唤醒为止,或者直到当唤醒的持续时长大于阈值持续时长为止。在本发明的又一个实施例中,在当唤醒的持续时长大于阈值持续时长时所述用户交互进程仍未被唤醒的情况下,所述装置还包括推送进程自杀模块。推送进程自杀模块用于所述推送进程启动自杀机制以退出服务且不被自动唤醒。
在本发明的又一个实施例中,所述装置还包括共享数据模块。共享数据模块用于所述用户交互进程与所述推送进程通过内容提供器Content Provider共享数据。在本发明的一个实施例中,所述用户交互进程与所述推送进程通过内容提供器Content Provider共享数据包括:所述用户交互进程获取所述推送进程的最新数据;和/或所述用户交互进程更新所述推送进程的数据,以及决定是否通知所述内容提供器Content Provider提供的数据源观察者;和/或所述用户交互进程监听所述推送进程的数据变更;和/或所述用户交互进程发送数据包给所述推送进程进行处理;和/或所述用户交互进程移除所述推送进程的数据。在本发明的又一个实施例中,所述用户交互进程与所述推送进程通过内容提供器Content Provider共享数据,还包括所述推送进程更新所述用户交互进程的数据,以及通知所述用户交互进程。
在本发明的又一实施例中,所述装置还包括心跳模块。心跳模块用于所述推送进程通过安卓系统的精准闹钟Alarm执行心跳机制,以确定所述推送进程与外部服务器的长连接的有效性。在本发明的又一实施例中,所述装置还包括后补心跳模块。后补心跳模块用于从执行心跳机制中首次未收到外部服务器的回应信息超过阈值回应时长时,以第二时间间隔补充发送心跳包,所述第二时间间隔与精准闹钟Alarm中的定时时间间隔相同或不同。在本发明的又一个实施例中,在以第二时间间隔补充发送心跳包的次数达到第二阈值次数时,所述装置还包括长连接断开模块和长连接重连模块。长连接断开模块用于所述推送进程断开所述推送进程与外部服务器的长连接。长连接重连模块用于所述推送进程启动重新建立所述推送进程与外部服务器的长连接。
在本发明的一个实施例中,所述装置还包括心跳检测模块。心跳检测模块用于在监测到所述用户交互进程回到前台时或者所述推送进程与外部服务器的长连接连接超时的情况下,所述推送进程向所述外部服务器发送心跳包,以检测所述推送进程与外部服务器的长连接的有效性。
在本发明实施方式的第四方面中,提供了一种用于即时通信的计算设备,包括一个或多个存储器,存储有可执行指令,以及一个或多个处理器。所述处理器执行所述可执行指令,用以实现如上所述的用于即时通信的方法。
根据本发明实施方式的用于即时通信的方法、介质、装置和计算设备,在用户交互进程和推送进程之间创建了通信链接通道和辅助连接通道两个通道,将相应在合适时机将该通信链接通道的信息所述连接记录移除。这样,一方面可以避免发生在一些极端情况下该通信链接通道虽然被意外切断但连接记录中尚存在该通信链接通道的信息,而导致的该通信链接通道无法重新创建的问题;另一方面该辅助连接通道的信息会被记录所述连接记录中,从而在连接记录中始终记录有该用户交互进程绑定了该推送进程的信息,从而可以保持所述推送进程的优先级,保障了用户体验。通过这种方式,根据本发明实施方式的用于即时通信的方法、介质、装置和计算设备,提高了即时通信的稳定性,为用户带来了更好的体验。
附图说明
通过参考附图阅读下文的详细描述,本发明示例性实施方式的上述以及其他目的、特征和优点将变得易于理解。在附图中,以示例性而非限制性的方式示出了本发明的若干实施方式,其中:
图1示意性地示出了根据本发明实施方式的用于即时通信的方法、介质、装置和计算设备的应用场景;
图2示意性地示出了根据本发明实施例的用于即时通信的方法的流程图;
图3示意性地示出了根据本发明实施例的用于即时通信的方法的一个应用实例架构图;
图4示意性地示出了根据本发明另一实施例的用于即时通信的方法的流程图;
图5示意性示出了根据本发明实施例的图4中用户交互进程与推送进程传输信息的方法流程图;
图6示意性示出了根据本发明另一实施例的图4中用户交互进程与推送进程传输信息的方法流程图;
图7示意性示出了根据本发明又一实施例的图4中用户交互进程与推送进程传输信息的方法流程图;
图8示意性地示出了根据本发明又一实施例的用于即时通信的方法的流程图;
图9示意性示出了根据本发明实施例的图8中推送进程执行自杀机制的方法流程图;
图10示意性地示出了根据本发明再一实施例的用于即时通信的方法的流程图;
图11示意性示出了根据本公开实施例的推送进程创建前台服务的情景示例;
图12示意性示出了根据本发明再一实施例的用于即时通信的方法的流程图;
图13示意性示出了根据本发明再一实施例的用于即时通信的方法的流程图;
图14示意性示出了根据本发明再一实施例的用于即时通信的方法的流程图;
图15示意性示出了根据本发明实施例的用于即时通信的程序产品的示意图;
图16示意性示出了根据本发明实施例的用于即时通信的装置的方框图;以及
图17示意性示出了根据本发明实施例的用于即时通信的计算设备的方框图;
在附图中,相同或对应的标号表示相同或对应的部分。
具体实施方式
下面将参考若干示例性实施方式来描述本发明的原理和精神。应当理解,给出这些实施方式仅仅是为了使本领域技术人员能够更好地理解进而实现本发明,而并非以任何方式限制本发明的范围。相反,提供这些实施方式是为了使本公开更加透彻和完整,并且能够将本公开的范围完整地传达给本领域的技术人员。
本领域技术人员知道,本发明的实施方式可以实现为一种系统、装置、设备、方法或计算机程序产品。因此,本公开可以具体实现为以下形式,即:完全的硬件、完全的软件(包括固件、驻留软件、微代码等),或者硬件和软件结合的形式。
根据本发明的实施方式,提出了一种用于即时通信的方法、介质、装置和计算设备。
在本文中,需要理解的是,所涉及的术语通信链接通道表示所述用户交互进程与所述推送进程之间传输信息的传输路径或传输方式等,辅助连接通道表示所述用户交互进程与所述推送进程之间具有相互连接关系的属性、和/或虚拟关联方式等。此外,附图中的任何元素数量均用于示例而非限制,以及任何命名都仅用于区分,而不具有任何限制含义。
下面参考本发明的若干代表性实施方式,详细阐释本发明的原理和精神。
发明概述
本发明人发现,现有技术中存在的当推送进程中建立的通信链接通道的服务模块被意外杀死后,可能就无法重新建立起用户交互进程与该推送进程之间的通信链接通道的情况,其根本原因是因为该通信链接通道被意外切断时,在该连接记录中该通信链接通道信息并不能够被同步移除。具体而言,在该通信链接通道被建立之初,该通信链接通道的信息会被记录在连接记录中,在一些情况时,该通信链接通道虽然被意外切断,但是连接记录中并未同步移除该通信链接通道的信息,这样导致系统仍默认用户交互进程和推送进程之间处于绑定状态,从而不会再重新建立该通信链接通道。
根据这一发现,本发明人构思可以在该用户交互进程与该推送进程之间建立用于传输信号的通信链接通道以及用于表征该用户交互进程与该推送进程绑定关系的辅助连接通道,并且控制在合适的时机将连接记录中通信链接通道信息及时移除。这样,通过在该用户交互进程与该推送进程之间建立的这种双通道,可以将该用户交互进程与该推送进程之间的信号传输功能和绑定功能分解到两个通道分别承担,从而可以有效提高即时通信稳定性。
在介绍了本发明的基本原理之后,下面具体介绍本发明的各种非限制性实施方式。
应用场景总览
首先参考图1。
图1示意性地示出了根据本发明实施方式的用于即时通信的方法、介质、装置和计算设备的应用场景。
如图1所示,用户终端11中安装有即时通信应用程序,用户通过用户终端11中安装的即时通信应用程序向服务器12发送获取和/或传输数据的请求,服务器12根据用户的获取和/或传输数据的请求,向用户终端11发送相应的数据或将从用户终端11接收到的数据发送给其他用户终端11,从而实现即时通信。
用户终端11和服务器12通过网络连接,该网络可以为局域网、广域网、移动互联网等。用户终端11可以为便携设备(例如:手机、平板、笔记本电脑等),也可以为个人电脑(PC,Personal Computer),服务器12可以为任何能够提供网站服务、和/或数据传输服务的服务器设备。
需要说明的是,本公开实施例所提供的用于即时通信的方法一般可以由服务器12执行。相应地,本公开实施例所提供的用于即时通信的装置一般可以设置于服务器12中。本公开实施例所提供的用于即时通信的方法也可以由不同于服务器12且能够与用户终端11和/或服务器12通信的其他服务器或服务器集群执行。相应地,本公开实施例所提供的用于即时通信的装置也可以设置于不同于服务器12且能够与用户终端11和/或服务器12通信的其他服务器或服务器集群中。
应该理解,图1中的用户终端、网络和服务器的数目仅仅是示意性的。根据实现需要,可以具有任意数目的终端设备、网络和服务器。
示例性方法
下面结合图1的应用场景,参考图2~图14来描述根据本发明示例性实施方式的用于即时通信的方法。需要注意的是,上述应用场景仅是为了便于理解本发明的精神和原理而示出,本发明的实施方式在此方面不受任何限制。相反,本发明的实施方式可以应用于适用的任何场景。
图2示意性地示出了根据本发明实施例的用于即时通信的方法的流程图。
如图2所示,根据本发明实施例的用于即时通信的方法包括操作S201~操作S203。该即时通信包括通过用户交互进程和推送进程进行信息传输,其中,该用户交互进程用于接收和处理用户交互信息,该推送进程用于维护与外部服务器12的长连接。
在操作S201,建立该用户交互进程与该推送进程之间的通信链接通道,其中,该通信链接通道用于该用户交互进程和该推送进程之间的信息传输,该通信链接通道的信息被记录在连接记录中。
根据本发明的实施例,该通信链接通道的信息包括表征该用户交互进程绑定了该推送进程的信息。
在操作S202,从该连接记录中移除该通信链接通道的信息。在一些实施例中,操作S202可以是在通信链接通道建立完成的时候,从该连接记录中移除该通信链接通道的信息。在另一些实施例中,操作S202具体可以是在监测到将该用户交互进程和该推送进程解除绑定的情况下,从该连接记录中移除该通信链接通道的信息。
在操作S203,建立该用户交互进程与该推送进程之间的辅助连接通道,其中,该辅助连接通道的信息被记录在该连接记录中,用于保持该推送进程的优先级。根据本发明的实施例,该辅助连接通道的信息包括表征该用户交互进程绑定了该推送进程的信息。以此方式,该辅助连接通道的信息被记录在该连接记录中,从而在该连接记录中会认为该推送进程与该用户交互进行已经绑定,从而在用户交互进程运行时,可以使得推送进程不会被清理,从而可以保持该推送进程的优先级。
另外,根据本公开的实施例,辅助连接通道可以在实现用户交互进程与该推送进程之间的绑定连接关系功能之外,不再附加其他功能。这样由于辅助连接通道没有其他业务逻辑作用,可以使得该辅助连接通道的维持所占用的内存很小,从而降低用户终端11由于内存禁张而切断该辅助连接通道的可能性。并且,即使该辅助连接通道意外被切断,最差的情况也仅仅是该辅助连接通道无法重新创建,并不会实际影响到用户交互进程和推送进程之间的信息传输,从而并不影响用户终端11上的即时通信应用程序的使用。
图3示意性地示出了根据本发明实施例的用于即时通信的方法的一个应用实例架构图。
如图3所示,该即时通信的架构包括用户交互进程310和推送进程320。推送进程320可以负责处理与外部服务器12的长连接的相关工作,比如安全加密、心跳检测、鉴权、封包解包等业务逻辑。另外的大量业务逻辑可以由用户交互进程320。
推送进程320根据其服务功能可以大致包括通信服务单元(例如,负责与用户交互进程310的通信服务)、辅助服务单元(例如,负责与用户交互进程310的绑定关系服务)、以及网络保持服务单元(例如,负责与外部服务器(集群)12的长连接工作)等。
用户交互进程310根据其服务功能可以大致包括通信链接服务单元(例如,负责与推送进程320的通信服务)、辅助连接服务单元(例如,负责推送进程320的绑定关系服务)、以及用户交互服务单元(例如,负责响应用户交互操作等)等。
在图3中,在用户交互进程310和推送进程320之间建立起了双通道接连结构,包括通信链接通道102和辅助连接通道102F。其中,通信链接通道102可以是通过用户交互进程310中的通信链接服务单元和推送进程320中的通信服务单元建立的。辅助连接通道102F可以是通过用户交互进程310中的辅助连接服务单元和推送进程320中的辅助服务服务单元建立的。
如图3所示,用户交互进程310和推送进程320之间存在双通道接连结构,包括通信链接通道102和辅助连接通道102F。
在用户交互进程310中的通信链接服务单元和推送进程320中的通信服务单元之间建立起通信链接通道102实现跨进程的通信之后,将连接记录中的通信链接通道102的信息移除,通过通信链接通道102的跨进程的通信仍可以继续正常工作的。而且,此时由于连接记录中没有通信链接通道102的信息了,因此,当通信链接通道102被切断时,用户交互进程310中的通信链接服务单元可以重新调度并创建和推送进程320中的通信服务单元之间的链接,即重新创建通信链接通道102。
另外,通过用户交互进程310中的辅助连接服务单元和推送进程320中的辅助服务服务单元建立的辅助连接通道102F使得用户交互进程310和推送进程320始终保持连接。并且,辅助连接通道102F的信息被始终记录在连接记录中。从而保证了在用户交互进程310运行时,推送进程320不会被清理。
通过这种方式,图3示例的用于即时通信的方法的系统架构可以避免在一些极端情况下该通信链接通道102虽然被意外切断但连接记录中尚存在该通信链接通道102的信息,而导致的该通信链接通道102无法重新创建的问题。另一方面该辅助连接通道102F的信息会被记录该连接记录中,从而在连接记录中始终记录有该用户交互进程310绑定了该推送进程320的信息,从而可以保持该推送进程320的优先级,保障了用户体验。而且,辅助连接通道102F可以实现用户交互进程310与该推送进程320之间的轻量级绑定连接关系(即该辅助连接通道102F的维持所占用的内存可以很小,从而降低用户终端11由于内存紧张而切断该辅助连接通道102F的可能性,极大地提升即时通信应用程序的稳定性。
图4示意性地示出了根据本发明另一实施例的用于即时通信的方法的流程图。
如图4所示,根据本发明另一实施例的用于即时通信的方法除操作S201~操作S203之外,还包括操作S404。
在操作S404,该用户交互进程310与该推送进程320通过该通信链接通道102传输信息。
根据本公开的实施例,该用户交互进程310和该推送进程320通过该通信链接通道102进行信息传输,具有更好的稳定性。
图5示意性示出了根据本发明实施例的图4中用户交互进程310与推送进程320传输信息的方法流程图。
如图5所示,根据本发明的实施例,当该用户交互进程310与该推送进程320之间传输的数据包的数据量大于阈值数据量时,操作S404可以进一步包括操作S501~操作S503。
在操作S501,将该数据包拆分成多个子数据包,其中该多个子数据包中的每个数据包的数据量小于该阈值数据量。
在操作S502,通过该通信链接通道102依次传输该多个子数据包。
在操作S503,将传输完成的该多个子数据包进行组装,得到该数据包。
通过这种方式,根据本公开实施例的用于即时通信的方法,能够突破跨进程传输信息的数据大小限制,并可以保障用户传输数据的完整性。
图6示意性示出了根据本发明另一实施例的图4中用户交互进程310与推送进程320传输信息的方法流程图;
如图6所示,根据本发明的另一实施例,操作S404可以包括操作S601和操作S602。
在操作S601,该用户交互进程310接收到该推送进程320发送的数据包后向该推送进程320发送确认回执。
在操作S602,该推送进程320在接收到该确认回执后再向该用户交互进程310发送下一个数据包。
通过这种方式,可以在一定程度上解决现有技术中,即时通信应用程序在接收群消息过程中因为用户交互进程310崩溃使得消息写入和消息确认没有执行,又被后续的群消息覆盖掉外部服务器12上的群消息未读时间戳,导致丢失的消息没有机会再补偿的问题。从而,能够较好地保障即时通信服务中信息不丢失。
图7示意性示出了根据本发明又一实施例的图4中用户交互进程310与推送进程320传输信息的方法流程图。
如图7所示,根据本公开又一实施例,操作S404除操作S601之外,还包括操作S702~操作S704。具体的,通过操作S702~操作S704实现了操作S602中该推送进程320在接收到该确认回执后再向该用户交互进程310发送下一个数据包的具体执行。
在操作S702,判断该推送进程320是否在预设确收时间内收到确认回执。若是,则结束;若否,则循环执行操作S703、操作S704和操作S601,直到操作S702的判断结果为是时结束。
在操作S703,当该推送进程320在预设确收时间内未收到该确认回执时,向该外部服务器12发送该数据包补充请求。
在操作S704,在接收到该外部服务器12发送的该数据包后将该数据包发送至该用户交互进程310。
图8示意性地示出了根据本发明又一实施例的用于即时通信的方法的流程图。
如图8所示,根据本发明的又一实施例,该用于即时通信的方法除操作S201~操作S203之外,还包括操作S804和操作S805。
在操作S804,该推送进程320监听该用户交互进程310的生命周期是否结束。
在操作S805,响应于该用户交互进程310的生命周期的结束,该推送进程320执行自杀机制以退出服务且不被自动唤醒。
根据本公开实施例的用于即时通信的方法,可以在一些对即时通信的实时性、及时性要求较弱(例如,并不需要保证消息通知、和/或数据的实时性)的场景中,模拟单进程结构。根据本公开的实施例,可以使该推送进程320和该用户交互进程310同生命周期,即二者同时运行以及同时推出服务。
图9示意性示出了根据本发明实施例的图8中推送进程执行自杀机制的方法流程图。
如图9所示,根据本发明实施例,操作S805可以包括操作S901和操作S902。
在操作S901,该推送进程320切断该推送进程320的唤醒路径。
在操作S902,该推送进程320退出服务。
根据本公开实施例,在模拟单进程结构时,为使该推送进程320和该用户交互进程310同生命周期,避免推送进程320自杀后被用户终端11自动唤醒,可以在推送进程320退出服务之前切断该推送进程320的唤醒路径。
图10示意性地示出了根据本发明再一实施例的用于即时通信的方法的流程图。
如图10所示,根据本发明的实施例,该用于即时通信的方法除操作S201~操作S203之外,还可以包括操作S1004、操作S1005和操作S1006。
在操作S1004,该推送进程320创建与该通信链接通道102对应的第一前台服务。
在操作S1005,该推送进程320创建与该辅助连接通道102F对应的第二前台服务,其中第二前台服务与该第一前台服务的标识相同。
在操作S1006,该推送进程320取消该第一前台服务和该第二前台服务其中之一。
通过这种方式,可以进一步提高推送进程320的优先级,使推送进程320后台保活时间更长,进一步降低该推送进程320被用户终端11自动清理的概率,从而能够使用户更及时地、和实时地获取来自外部服务器12的通知消息、或者传输数据等。具体原理可以参照图11的相关描述。
图11示意性示出了根据本公开实施例的推送进程320创建前台服务的情景示例。
根据本公开的实施例,在用户终端11的一些系统中,例如在部分安卓系统,可以通过两个具有相同标识(ID)的前台服务配合,创建一个隐形的前台服务,如图11所示。
具体地,例如,可以在图3所示的即时通信架构中,在操作S1004中通过推送进程320中的通信服务单元建立一个对应于通信链接通道102的第一前台服务,从而用户终端11会提供一个与通信链接通道102对应的通知栏NOTIFY_ID,这样对应于通信链接通道102存在一个标识为NOTIFY_ID的常驻通知栏提醒。然后在操作S1005中,可以在同一时间或者短暂的瞬间之后,通过推送进程320中的辅助服务单元建立一个对应于辅助连接通道102F的第二前台服务,并且该第二前台服务的标识与第一前台服务的作用相同,标识也相同,均用来表征推送进程320与用户交互进程310之间传输信息的通知消息。由于第二前台服务的标识与第一前台服务的标识相同,因此,在第二前台建立的通知用户终端11将不再创建新的通知栏提醒了。此时,可以在操作S1006中,取消第一前台服务。此时,推送进程320就只剩下第二前台服务了,推送进程320也变成了前台进程,但这个过程中不会使用户感知到任何不同。并且,第二前台服务的存在对应于该辅助连接通道102F。如前所述,该辅助连接通道102F可以占用较小内存,实现推送进程320与用户交互进程310之间轻量级的连接,使得第二前台服务的运行需要的内存空间小。同时,当有来自服务器12的消息时,能够及时弹出通知栏提示,保障了即时通信的实时性。
继续参考图10,根据本公开的实施例,该用于即时通信的方法在操作S1006之后,还可以包括操作S1007。
在操作S1007,当该推送进程320接收到该外部服务器12发送的消息时,且在该用户交互进程310处于未运行的状态下,该推送进程320唤醒该用户交互进程310。以此方式,保障了即时通信的实时性。
根据本发明的实施例,操作S1007中该推送进程320唤醒该用户交互进程310,具体可以是在该用户交互进程310未被唤醒之前每隔预设唤醒时长唤醒一次,直到该用户交互进程310被唤醒为止,或者直到当唤醒的持续时长大于阈值持续时长为止。
根据本发明的实施例,如图10所示,该用户即时通信的方法在操作S1007之后还可以包括操作S1008。
在操作S1008,在当唤醒的持续时长大于阈值持续时长时该用户交互进程310仍未被唤醒的情况下,该推送进程320启动自杀机制以退出服务且不被自动唤醒。以此方式,当用户交互进程310确定无法被唤醒时,该推送进程320启动自杀机制以退出服务且不被自动唤醒,有效保证系统运行的有效性,节约系统资源。
图12示意性示出了根据本发明再一实施例的用于即时通信的方法的流程图。
如图12所示,根据本发明再一实施例,该用于即时通信的方法除操作S201~操作S203之外,还可以包括操作S1204。
在操作S1204,该用户交互进程310与该推送进程320通过内容提供器ContentProvider共享数据。在安卓系统中,内容提供器Content Provider是安卓系统的四大组件之一。内容提供器Content Provider封装了进程间通信的细节,暴露了丰富的数据源增、删、改、和/或查等接口。
根据本发明的实施例,该用户交互进程310与该推送进程320通过内容提供器Content Provider共享数据包括:该用户交互进程310获取该推送进程320的最新数据;和/或该用户交互进程310更新该推送进程320的数据,以及决定是否通知该内容提供器Content Provider提供的数据源观察者;和/或该用户交互进程310监听该推送进程320的数据变更;和/或该用户交互进程310发送数据包给该推送进程320进行处理;和/或该用户交互进程310移除该推送进程320的数据。
根据本发明的另一实施例,该用户交互进程310与该推送进程320通过内容提供器Content Provider共享数据,还包括该推送进程320更新该用户交互进程310的数据,以及通知该用户交互进程310。
根据本公开的实施例,通过内容提供器Content Provider共享数据,可以实现该用户交互进程310与该推送进程320之间的跨进程数据共享,并可以在一定程度上改善现有技术中通过SharedPreference跨进程共享数据时存在的读写不一致的情况。
图13示意性示出了根据本发明再一实施例的用于即时通信的方法的流程图。
如图13所示,根据本发明再一实施例,该用于即时通信的方法除操作S201~操作S203之外,还可以包括操作S1304。
在操作S1304,该推送进程320通过安卓系统的精准闹钟Alarm执行心跳机制,以确定该推送进程320与外部服务器12的长连接的有效性。例如,通过Alarm精准闹钟,来执行心跳检测、发送心跳包的任务,可以解决在部分用户终端11上的即时通信应用程序的后台进程被挂起导致现有技术中TimeTask无法执行的问题。
继续参考图13,根据本发明的实施例,该用于即时通信的方法在操作S1304之后还可以包括操作S1305。
在操作S1305,从执行心跳机制中首次未收到外部服务器12的回应信息超过阈值回应时长时,以第二时间间隔补充发送心跳包,该第二时间间隔与精准闹钟Alarm中的定时时间间隔相同或不同。
例如,在首次发送心跳包后未收到外部服务器12的回应信息的时间超过阈值回应时长(例如30秒)后,可以每隔第二时间间隔(例如5秒)补发一个心跳包,来维长连接的热性。
继续参考图13,根据本发明的实施例,该用于即时通信的方法在操作S1305之后,还可以包括操作S1306和操作S1307。
在操作S1306,在以第二时间间隔补充发送心跳包的次数达到第二阈值次数时,该推送进程320断开该推送进程320与外部服务器12的长连接。
在操作S1307,该推送进程320启动重新建立该推送进程320与外部服务器12的长连接。
根据本公开的实施例,在以第二时间间隔补充发送心跳包的次数达到第二阈值次数时可以认为当前的长连接已经失效,此时可以直接断开连接,启动重连机制,从而有效保障及时的网络连接,提升用户体验。
图14示意性示出了根据本发明再一实施例的用于即时通信的方法的流程图。
如图14所示,根据本发明的再一实施例,该用于即时通信的方法除操作S201~操作S203之外,还包括操作S1404。
在操作S1404,在监测到该用户交互进程310回到前台时或者该推送进程320与外部服务器的长连接连接超时的情况下,该推送进程320向该外部服务器发送心跳包,以检测该推送进程320与外部服务器的长连接的有效性。当确定长连接失效时,可以断开长连接,启动长连接的重连机制。
示例性介质
在介绍了本发明示例性实施方式的方法之后,接下来,参考图15对本发明示例性实施方式的用于即时通信的计算机可读介质进行说明。
图15示意性示出了根据本发明实施例的用于即时通信的程序产品的示意图。根据本发明实施例,该程序产品可以是存储有可执行指令的计算机可读介质、所述指令在被处理器执行时使处理器执行参考图2~图14中所描述的用于即时通信的方法。其中,所述即时通信包括通过用户交互进程和推送进程进行信息传输,其中,所述用户交互进程用于接收和处理用户交互信息,所述推送进程用于维护与外部服务器的长连接,
在一些可能的实施方式中,本发明的各个方面还可以实现为一种程序产品的形式,其包括程序代码,当该程序产品在计算设备上运行时,该程序代码用于使该计算设备执行本说明书上述“示例性方法”部分中描述的根据本发明各种示例性实施方式的用于即时通信的方法,例如,该计算设备可以执行如图2中所示的操作S201:建立该用户交互进程与该推送进程之间的通信链接通道,其中,该通信链接通道用于该用户交互进程和该推送进程之间的信息传输,该通信链接通道的信息被记录在连接记录中;操作S202:从该连接记录中移除该通信链接通道的信息;以及操作S203:建立该用户交互进程与该推送进程之间的辅助连接通道,其中,该辅助连接通道的信息被记录在该连接记录中,用于保持该推送进程的优先级。
所述程序产品可以采用一个或多个可读介质的任意组合。可读介质可以是可读信号介质或者可读存储介质。可读存储介质例如可以是——但不限于——电、磁、光、电磁、红外线、或半导体的系统、装置或器件,或者任意以上的组合。可读存储介质的更具体的例子(非穷举的列表)包括:具有一个或多个导线的电连接、便携式盘、硬盘、随机存取存储器(RAM)、只读存储器(ROM)、可擦式可编程只读存储器(EPROM或闪存)、光纤、便携式紧凑盘只读存储器(CD-ROM)、光存储器件、磁存储器件、或者上述的任意合适的组合。
如图15所示,描述了根据本发明的实施方式的用于即时通信的程序产品1500,其可以采用便携式紧凑盘只读存储器(CD-ROM)并包括程序代码,并可以在计算设备,例如个人电脑上运行。然而,本发明的程序产品不限于此,在本文件中,可读存储介质可以是任何包含或存储程序的有形介质,该程序可以被指令执行系统、装置或者器件使用或者与其结合使用。
可读信号介质可以包括在基带中或者作为载波一部分传播的数据信号,其中承载了可读程序代码。这种传播的数据信号可以采用多种形式,包括——但不限于——电磁信号、光信号或上述的任意合适的组合。可读信号介质还可以是可读存储介质以外的任何可读介质,该可读介质可以发送、传播或者传输用于由指令执行系统、装置或者器件使用或者与其结合使用的程序。
可读介质上包含的程序代码可以用任何适当的介质传输,包括——但不限于——无线、有线、光缆,RF等等,或者上述的任意合适的组合。
可以以一种或多种程序设计语言的任意组合来编写用于执行本发明操作的程序代码,所述程序设计语言包括面向对象的程序设计语言——诸如Java,C++等,还包括常规的过程式程序设计语言——诸如“C”,语言或类似的程序设计语言。程序代码可以完全地在用户计算设备上执行、部分地在用户设备上执行、作为一个独立的软件包执行、部分在用户计算设备上部分在远程计算设备上执行、或者完全在远程计算设备或服务器上执行。在涉及远程计算设备的情形中,远程计算设备可以通过任意种类的网络——包括局域网(LAN)或广域网(WAN)一连接到用户计算设备,或者,可以连接到外部计算设备(例如利用因特网服务提供商来通过因特网连接)。
示例性装置
在介绍了本发明示例性实施方式的介质之后,接下来,参考图16对本发明示例性实施方式的用于即时通信的装置1600。
图16示意性示出了根据本发明实施例的用于即时通信的装置1600的方框图。该装置1600可以用于参考图2~图14中所描述的用于即时通信的方法。
如图16所示,该装置1600可以用于即时通信,该即时通信包括通过用户交互进程和推送进程进行信息传输,其中,该用户交互进程用于接收和处理用户交互信息,该推送进程用于维护与外部服务器的长连接。改装置1600可以包括通信链接建立模块1610、通信链接通道的记录信息移除模块1620、以及辅助连接通道建立模块1630。
通信链接通道建立模块1610用于建立该用户交互进程与该推送进程之间的通信链接通道,其中,该通信链接通道用于该用户交互进程和该推送进程之间的信息传输,该通信链接通道的信息被记录在连接记录中。
根据本发明的实施例,该通信链接通道的信息包括表征该用户交互进程绑定了该推送进程的信息。
通信链接通道的记录信息移除模块1620用于从该连接记录中移除该通信链接通道的信息。根据本发明的实施例,该通信链接通道的记录信息移除模块1620从该连接记录中移除该通信链接通道的信息,包括在监测到将该用户交互进程和该推送进程解除绑定的情况下,从该连接记录中移除该通信链接通道的信息。
辅助连接通道建立模块1630用于建立该用户交互进程与该推送进程之间的辅助连接通道,其中,该辅助连接通道的信息被记录在该连接记录中,用于保持该推送进程的优先级。根据本发明的实施例,该辅助连接通道的信息包括表征该用户交互进程绑定了该推送进程的信息。
根据本发明的另一实施例,该装置1600除了包括图16所示的通信链接建立模块1610、通信链接通道的记录信息移除模块1620、以及辅助连接通道建立模块1630以外,还可以包括进程间信息传输模块。该进程间信息传输模块用于该用户交互进程与该推送进程通过该通信链接通道传输信息。
根据本发明的实施例,在该进程间通信模块中,当该用户交互进程与该推送进程之间传输的数据包的数据量大于阈值数据量时,该用户交互进程与该推送进程通过该通信链接通道传输信息,包括将该数据包拆分成多个子数据包,其中该多个子数据包中的每个数据包的数据量小于该阈值数据量,通过该通信链接通道依次传输该多个子数据包,以及将传输完成的该多个子数据包进行组装,得到该数据包。具体可以参考图5的相关描述。
根据本发明的实施例,在该进程间通信模块中,该用户交互进程与该推送进程通过该通信链接通道传输信息,包括该用户交互进程接收到该推送进程发送的数据包后向该推送进程发送确认回执,以及该推送进程在接收到该确认回执后再向该用户交互进程发送下一个数据包。
根据本发明的实施例,在该进程间通信模块中,该推送进程在接收到该确认回执后再向该用户交互进程发送下一个数据包,包括当该推送进程在预设确收时间内未收到该确认回执时,该推送进程重复以下操作,直到接收到该确认回执:向该外部服务器发送该数据包补充请求,以及在接收到该外部服务器发送的该数据包后将该数据包发送至该用户交互进程。
根据本发明的另一实施例,该装置1600除了包括图16所示的通信链接建立模块1610、通信链接通道的记录信息移除模块1620、以及辅助连接通道建立模块1630以外,还可以包括监听模块和推送进程自杀模块。监听模块用于该推送进程监听该用户交互进程的生命周期是否结束。推送进程自杀模块用于响应于该用户交互进程的生命周期的结束,该推送进程执行自杀机制以退出服务且不被自动唤醒。
根据本发明的实施例,在该推送进程自杀模块中,述推送进程执行自杀机制以退出服务且不被自动唤醒,包括该推送进程切断该推送进程的唤醒路径,以及该推送进程退出服务。
根据本发明的另一实施例,该装置1600除了包括图16所示的通信链接建立模块1610、通信链接通道的记录信息移除模块1620、以及辅助连接通道建立模块1630以外,还可以包括第一前台服务创建模块、第二前台服务创建模块以及前台服务取消模块。第一前台服务创建模块用于该推送进程创建与该通信链接通道对应的第一前台服务。第二前台服务创建模块用于该推送进程创建与该辅助连接通道对应的第二前台服务,其中第二前台服务与该第一前台服务的标识相同。前台服务取消模块,用于该推送进程取消该第一前台服务和该第二前台服务其中之一。
根据本发明的实施例,该装置600除通信链接建立模块1610、通信链接通道的记录信息移除模块1620、以及辅助连接通道建立模块1630以及第一前台服务创建模块、第二前台服务创建模块和前台服务取消模块以外,还可以包括用户交互进程唤醒模块。用户交互进程唤醒模块用于当该推送进程接收到该外部服务器发送的消息时,且在该用户交互进程处于未运行的状态下,该推送进程唤醒该用户交互进程。根据本发明的一些实施例,在该用户交互进程唤醒模块中,该推送进程唤醒该用户交互进程,包括在该用户交互进程未被唤醒之前每隔预设唤醒时长唤醒一次,直到该用户交互进程被唤醒为止,或者直到当唤醒的持续时长大于阈值持续时长为止。根据本发明的实施例,该装置600还可以进一步包括推送进程自杀模块。该推送进程自杀模块用于在当唤醒的持续时长大于阈值持续时长时该用户交互进程仍未被唤醒的情况下,该推送进程启动自杀机制以退出服务且不被自动唤醒。
根据本发明的另一实施例,该装置1600除了包括图16所示的通信链接建立模块1610、通信链接通道的记录信息移除模块1620、以及辅助连接通道建立模块1630以外,还可以包括共享数据模块。该共享数据模块用于该用户交互进程与该推送进程通过内容提供器Content Provider共享数据。
根据本发明的实施例,在该共享数据模块中,该用户交互进程与该推送进程通过内容提供器Content Provider共享数据包括:该用户交互进程获取该推送进程的最新数据;和/或该用户交互进程更新该推送进程的数据,以及决定是否通知该内容提供器Content Provider提供的数据源观察者;和/或该用户交互进程监听该推送进程的数据变更;和/或该用户交互进程发送数据包给该推送进程进行处理;和/或该用户交互进程移除该推送进程的数据。根据本发明的实施例,该用户交互进程与该推送进程通过内容提供器Content Provider共享数据,还包括该推送进程更新该用户交互进程的数据,以及通知该用户交互进程。
根据本发明的另一实施例,该装置1600除了包括图16所示的通信链接建立模块1610、通信链接通道的记录信息移除模块1620、以及辅助连接通道建立模块1630以外,还可以包括心跳模块。心跳模块用于该推送进程通过安卓系统的精准闹钟Alarm执行心跳机制,以确定该推送进程与外部服务器的长连接的有效性。根据发明另一实施例,该装置600还可以进一步包括后补心跳模块。后补心跳模块用于从执行心跳机制中首次未收到外部服务器的回应信息超过阈值回应时长时,以第二时间间隔补充发送心跳包,该第二时间间隔与精准闹钟Alarm中的定时时间间隔相同或不同。
根据本发明另一实施例,该装置1600除了包括通信链接建立模块1610、通信链接通道的记录信息移除模块1620、辅助连接通道建立模块1630、以及心跳模块和后模心跳模块以外,还可以包括长连接断开模块和长连接重连模块。长连接断开模块用于在以第二时间间隔补充发送心跳包的次数达到第二阈值次数时,该推送进程断开该推送进程与外部服务器的长连接。长连接重连模块用于该推送进程启动重新建立该推送进程与外部服务器的长连接。
根据本发明另一实施例,该装置1600除了包括图16所示的通信链接建立模块1610、通信链接通道的记录信息移除模块1620、以及辅助连接通道建立模块1630之外,还可以包括心跳检测模块。心跳检测模块用于在监测到该用户交互进程回到前台时或者该推送进程与外部服务器的长连接连接超时的情况下,该推送进程向该外部服务器发送心跳包,以检测该推送进程与外部服务器的长连接的有效性。
示例性计算设备
在介绍了本发明示例性实施方式的方法、介质和装置之后,接下来,参考图17对本发明示例性实施方式的用于即时通信的计算设备进行说明。
本发明实施例还提供了一种计算设备。所属技术领域的技术人员能够理解,本发明的各个方面可以实现为系统、方法或程序产品。因此,本发明的各个方面可以具体实现为以下形式,即:完全的硬件实施方式、完全的软件实施方式(包括围件、微代码等),或硬件和软件方面结合的实施方式,这里可以统称为“电路”、“模块”或“系统”。
在一些可能的实施方式中,根据本发明的计算设备可以至少包括至少一个处理单元、以及至少一个存储单元。其中,所述存储单元存储有程序代码,当所述程序代码被所述处理单元执行时,使得所述处理单元执行本说明书上述“示例性方法”部分中描述的根据本发明各种示例性实施方式的用于即时通信的方法。例如,该处理单元可以执行如图2中所示的操作S201:建立该用户交互进程与该推送进程之间的通信链接通道,其中,该通信链接通道用于该用户交互进程和该推送进程之间的信息传输,该通信链接通道的信息被记录在连接记录中;操作S202:从该连接记录中移除该通信链接通道的信息;以及操作S203:建立该用户交互进程与该推送进程之间的辅助连接通道,其中,该辅助连接通道的信息被记录在该连接记录中,用于保持该推送进程的优先级。
图17示意性示出了根据本发明实施例的用于即时通信的计算设备1700的方框图。该计算设备1700可以用于实现参考图2~图14所描述的用于即时通信的方法。
下面参照图17来描述根据本发明的这种实施方式的用于即时通信的计算设备1700。如图17所示的计算设备1700仅仅是一个示例,不应对本发明实施例的功能和使用范围带来任何限制。
如图17所示,计算设备1700以通用计算设备的形式表现。计算设备1700的组件可以包括但不限于:上述至少一个处理单元1710、上述至少一个存储单元1720、连接不同系统组件(包括存储单元1720和处理单元1710)的总线1730。
总线1730表示几类总线结构中的一种或多种,包括存储器总线或者存储器控制器、外围总线、图形加速端口、处理器或者使用多种总线结构中的任意总线结构的局域总线。
存储单元1720可以包括易失性存储器形式的可读介质,例如随机存取存储器(RAM)1721和/或高速缓存存储器1722,还可以进一步包括只读存储器(ROM)1723。
存储单元1720还可以包括具有一组(至少一个)程序模块1724的程序/实用工具1725,这样的程序模块1724包括但不限于:操作系统、一个或者多个应用程序、其它程序模块以及程序数据,这些示例中的每一个或某种组合中可能包括网络环境的实现。
计算设备1700也可以与一个或多个外部设备1740(例如键盘、指向设备、蓝牙设备等)通信,还可与一个或者多个使得用户能与计算设备1700交互的设备通信,和/或与使得计算设备1700能与一个或多个其它计算设备进行通信的任何设备(例如路由器、调制解调器等等)通信。这种通信可以通过输入/输出(I/0)接口1750进行。并且,计算设备1700还可以通过网络适配器1760与一个或者多个网络(例如局域网(LAN),广域网(WAN)和/或公共网络,例如因特网)通信。如图所示,网络适配器1760通过总线1730与计算设备1700的其它模块通信。应当明白,尽管图中未示出,可以结合计算设备1700使用其它硬件和/或软件模块,包括但不限于:微代码、设备驱动器、冗余处理单元、外部磁盘驱动阵列、RAID系统、磁带驱动器以及数据备份存储系统等。
应当注意,尽管在上文详细描述中提及了装置的若干单元/模块或子单元/模块,但是这种划分仅仅是示例性的并非强制性的。实际上,根据本发明的实施方式,上文描述的两个或更多单元/模块的特征和功能可以在一个单元/模块中具体化。反之,上文描述的一个单元/模块的特征和功能可以进一步划分为由多个单元/模块来具体化。
此外,尽管在附图中以特定顺序描述了本发明方法的操作,但是,这并非要求或者暗示必须按照该特定顺序来执行这些操作,或是必须执行全部所示的操作才能实现期望的结果。附加地或备选地,可以省略某些步骤,将多个步骤合并为一个步骤执行,和/或将一个步骤分解为多个步骤执行。
虽然已经参考若干具体实施方式描述了本发明的精神和原理,但是应该理解,本发明并不限于所公开的具体实施方式,对各方面的划分也不意味着这些方面中的特征不能组合以进行受益,这种划分仅是为了表述的方便。本发明旨在涵盖所附权利要求的精神和范围内所包括的各种修改和等同布置。

Claims (42)

1.一种用于即时通信的方法,所述即时通信包括通过用户交互进程和推送进程进行信息传输,其中,所述用户交互进程用于接收和处理用户交互信息,所述推送进程用于维护与外部服务器的长连接,所述方法包括:
建立所述用户交互进程与所述推送进程之间的通信链接通道,其中,所述通信链接通道用于所述用户交互进程和所述推送进程之间的信息传输,所述通信链接通道的信息被记录在连接记录中;
从所述连接记录中移除所述通信链接通道的信息;以及
建立所述用户交互进程与所述推送进程之间的辅助连接通道,所述辅助连接通道的信息包括表征所述用户交互进程绑定了所述推送进程的信息,其中,所述辅助连接通道的信息被记录在所述连接记录中,用于保持所述推送进程的优先级。
2.根据权利要求1所述的方法,其中,所述通信链接通道的信息包括表征所述用户交互进程绑定了所述推送进程的信息。
3.根据权利要求1所述的方法,其中,从所述连接记录中移除所述通信链接通道的信息包括:
在监测到将所述用户交互进程和所述推送进程解除绑定的情况下,从所述连接记录中移除所述通信链接通道的信息。
4.根据权利要求1所述的方法,还包括:
所述用户交互进程与所述推送进程通过所述通信链接通道传输信息。
5.根据权利要求4所述的方法,其中,当所述用户交互进程与所述推送进程之间传输的数据包的数据量大于阈值数据量时,所述用户交互进程与所述推送进程通过所述通信链接通道传输信息包括:
将所述数据包拆分成多个子数据包,其中所述多个子数据包中的每个数据包的数据量小于所述阈值数据量;
通过所述通信链接通道依次传输所述多个子数据包;以及
将传输完成的所述多个子数据包进行组装,得到所述数据包。
6.根据权利要求4所述的方法,其中,所述用户交互进程与所述推送进程通过所述通信链接通道传输信息包括:
所述用户交互进程接收到所述推送进程发送的数据包后向所述推送进程发送确认回执;以及
所述推送进程在接收到所述确认回执后再向所述用户交互进程发送下一个数据包。
7.根据权利要求6所述的方法,其中,所述推送进程在接收到所述确认回执后再向所述用户交互进程发送下一个数据包,包括:
当所述推送进程在预设确收时间内未收到所述确认回执时,所述推送进程重复以下操作,直到接收到所述确认回执:
向所述外部服务器发送所述数据包补充请求;以及
在接收到所述外部服务器发送的所述数据包后将所述数据包发送至所述用户交互进程。
8.根据权利要求1所述的方法,还包括:
所述推送进程监听所述用户交互进程的生命周期是否结束;以及
响应于所述用户交互进程的生命周期的结束,所述推送进程执行自杀机制以退出服务且不被自动唤醒。
9.根据权利要求8所述的方法,其中,所述推送进程执行自杀机制以退出服务且不被自动唤醒包括:
所述推送进程切断所述推送进程的唤醒路径;以及
所述推送进程退出服务。
10.根据权利要求1所述的方法,还包括:
所述推送进程创建与所述通信链接通道对应的第一前台服务,
所述推送进程创建与所述辅助连接通道对应的第二前台服务,其中第二前台服务与所述第一前台服务的标识相同;以及
所述推送进程取消所述第一前台服务和所述第二前台服务其中之一。
11.根据权利要求10所述的方法,当所述推送进程接收到所述外部服务器发送的消息时,且在所述用户交互进程处于未运行的状态下,所述方法还包括:
所述推送进程唤醒所述用户交互进程。
12.根据权利要求11所述的方法,其中,所述推送进程唤醒所述用户交互进程包括:
在所述用户交互进程未被唤醒之前每隔预设唤醒时长唤醒一次,直到所述用户交互进程被唤醒为止,或者直到当唤醒的持续时长大于阈值持续时长为止。
13.根据权利要求12所述的方法,在当唤醒的持续时长大于阈值持续时长时所述用户交互进程仍未被唤醒的情况下,所述方法还包括:
所述推送进程启动自杀机制以退出服务且不被自动唤醒。
14.根据权利要求1所述的方法,还包括:
所述用户交互进程与所述推送进程通过内容提供器Content Provider共享数据。
15.根据权利要求14所述的方法,其中,所述用户交互进程与所述推送进程通过内容提供器Content Provider共享数据包括:
所述用户交互进程获取所述推送进程的最新数据;和/或
所述用户交互进程更新所述推送进程的数据,以及决定是否通知所述内容提供器Content Provider提供的数据源观察者;和/或
所述用户交互进程监听所述推送进程的数据变更;和/或
所述用户交互进程发送数据包给所述推送进程进行处理;和/或
所述用户交互进程移除所述推送进程的数据。
16.根据权利要求15所述的方法,其中,所述用户交互进程与所述推送进程通过内容提供器Content Provider共享数据还包括:
所述推送进程更新所述用户交互进程的数据,以及通知所述用户交互进程。
17.根据权利要求1所述的方法,还包括:
所述推送进程通过安卓系统的精准闹钟Alarm执行心跳机制,以确定所述推送进程与外部服务器的长连接的有效性。
18.根据权利要求17所述的方法,还包括:
从执行心跳机制中首次未收到外部服务器的回应信息超过阈值回应时长时,以第二时间间隔补充发送心跳包,所述第二时间间隔与精准闹钟Alarm中的定时时间间隔相同或不同。
19.根据权利要求18所述的方法,在以第二时间间隔补充发送心跳包的次数达到第二阈值次数时,所述方法还包括:
所述推送进程断开所述推送进程与外部服务器的连接;以及
所述推送进程启动重新建立所述推送进程与外部服务器的长连接。
20.根据权利要求1所述的方法,还包括:
在监测到所述用户交互进程回到前台时或者所述推送进程与外部服务器的长连接连接超时的情况下,所述推送进程向所述外部服务器发送心跳包,以检测所述推送进程与外部服务器的长连接的有效性。
21.一种计算机可读介质,其上存储有可执行指令,所述指令在被处理器执行时使处理器执行权利要求1~20任意一项所述的方法。
22.一种用于即时通信的装置,所述即时通信包括通过用户交互进程和推送进程进行信息传输,其中,所述用户交互进程用于接收和处理用户交互信息,所述推送进程用于维护与外部服务器的长连接,所述装置包括:
通信链接通道建立模块,用于建立所述用户交互进程与所述推送进程之间的通信链接通道,其中,所述通信链接通道用于所述用户交互进程和所述推送进程之间的信息传输,所述通信链接通道的信息被记录在连接记录中;
通信链接通道的记录信息移除模块,用于从所述连接记录中移除所述通信链接通道的信息;以及
辅助连接通道建立模块,用于建立所述用户交互进程与所述推送进程之间的辅助连接通道,所述辅助连接通道的信息包括表征所述用户交互进程绑定了所述推送进程的信息,其中,所述辅助连接通道的信息被记录在所述连接记录中,用于保持所述推送进程的优先级。
23.根据权利要求22所述的装置,其中,所述通信链接通道的信息包括表征所述用户交互进程绑定了所述推送进程的信息。
24.根据权利要求22所述的装置,其中,所述通信链接通道的记录信息移除模块从所述连接记录中移除所述通信链接通道的信息包括:
在监测到将所述用户交互进程和所述推送进程解除绑定的情况下,从所述连接记录中移除所述通信链接通道的信息。
25.根据权利要求22所述的装置,还包括:
进程间信息传输模块,用于所述用户交互进程与所述推送进程通过所述通信链接通道传输信息。
26.根据权利要求25所述的装置,其中,当所述用户交互进程与所述推送进程之间传输的数据包的数据量大于阈值数据量时,所述用户交互进程与所述推送进程通过所述通信链接通道传输信息包括:
将所述数据包拆分成多个子数据包,其中所述多个子数据包中的每个数据包的数据量小于所述阈值数据量;
通过所述通信链接通道依次传输所述多个子数据包;以及
将传输完成的所述多个子数据包进行组装,得到所述数据包。
27.根据权利要求25所述的装置,其中,所述用户交互进程与所述推送进程通过所述通信链接通道传输信息包括:
所述用户交互进程接收到所述推送进程发送的数据包后向所述推送进程发送确认回执;以及
所述推送进程在接收到所述确认回执后再向所述用户交互进程发送下一个数据包。
28.根据权利要求27所述的装置,其中,所述推送进程在接收到所述确认回执后再向所述用户交互进程发送下一个数据包,包括:
当所述推送进程在预设确收时间内未收到所述确认回执时,所述推送进程重复以下操作,直到接收到所述确认回执:
向所述外部服务器发送所述数据包补充请求;以及
在接收到所述外部服务器发送的所述数据包后将所述数据包发送至所述用户交互进程。
29.根据权利要求22所述的装置,还包括:
监听模块,用于所述推送进程监听所述用户交互进程的生命周期是否结束;以及
推送进程自杀模块,用于响应于所述用户交互进程的生命周期的结束,所述推送进程执行自杀机制以退出服务且不被自动唤醒。
30.根据权利要求29所述的装置,其中,所述推送进程执行自杀机制以退出服务且不被自动唤醒包括:
所述推送进程切断所述推送进程的唤醒路径;以及
所述推送进程退出服务。
31.根据权利要求22所述的装置,还包括:
第一前台服务创建模块,用于所述推送进程创建与所述通信链接通道对应的第一前台服务;
第二前台服务创建模块,用于所述推送进程创建与所述辅助连接通道对应的第二前台服务,其中第二前台服务与所述第一前台服务的标识相同;以及
前台服务取消模块,用于所述推送进程取消所述第一前台服务和所述第二前台服务其中之一。
32.根据权利要求31所述的装置,当所述推送进程接收到所述外部服务器发送的消息时,且在所述用户交互进程处于未运行的状态下,所述装置还包括:
用户交互进程唤醒模块,用于所述推送进程唤醒所述用户交互进程。
33.根据权利要求32所述的装置,其中,所述推送进程唤醒所述用户交互进程包括:
在所述用户交互进程未被唤醒之前每隔预设唤醒时长唤醒一次,直到所述用户交互进程被唤醒为止,或者直到当唤醒的持续时长大于阈值持续时长为止。
34.根据权利要求33所述的装置,在当唤醒的持续时长大于阈值持续时长时所述用户交互进程仍未被唤醒的情况下,所述装置还包括:
推送进程自杀模块,用于所述推送进程启动自杀机制以退出服务且不被自动唤醒。
35.根据权利要求22所述的装置,还包括:
共享数据模块,用于所述用户交互进程与所述推送进程通过内容提供器ContentProvider共享数据。
36.根据权利要求35所述的装置,其中,所述用户交互进程与所述推送进程通过内容提供器Content Provider共享数据包括:
所述用户交互进程获取所述推送进程的最新数据;和/或
所述用户交互进程更新所述推送进程的数据,以及决定是否通知所述内容提供器Content Provider提供的数据源观察者;和/或
所述用户交互进程监听所述推送进程的数据变更;和/或
所述用户交互进程发送数据包给所述推送进程进行处理;和/或
所述用户交互进程移除所述推送进程的数据。
37.根据权利要求36所述的装置,其中,所述用户交互进程与所述推送进程通过内容提供器Content Provider共享数据还包括:
所述推送进程更新所述用户交互进程的数据,以及通知所述用户交互进程。
38.根据权利要求22所述的装置,还包括:
心跳模块,用于所述推送进程通过安卓系统的精准闹钟Alarm执行心跳机制,以确定所述推送进程与外部服务器的长连接的有效性。
39.根据权利要求38所述的装置,还包括:
后补心跳模块,用于从执行心跳机制中首次未收到外部服务器的回应信息超过阈值回应时长时,以第二时间间隔补充发送心跳包,所述第二时间间隔与精准闹钟Alarm中的定时时间间隔相同或不同。
40.根据权利要求39所述的装置,在以第二时间间隔补充发送心跳包的次数达到第二阈值次数时,所述装置还包括:
长连接断开模块,用于所述推送进程断开所述推送进程与外部服务器的长连接;以及
长连接重连模块,用于所述推送进程启动重新建立所述推送进程与外部服务器的长连接。
41.根据权利要求22所述的装置,还包括:
心跳检测模块,用于在监测到所述用户交互进程回到前台时或者所述推送进程与外部服务器的长连接连接超时的情况下,所述推送进程向所述外部服务器发送心跳包,以检测所述推送进程与外部服务器的长连接的有效性。
42.一种用于即时通信的计算设备,包括:
一个或多个存储器,存储有可执行指令;
一个或多个处理器,执行所述可执行指令,用以实现权利要求1~21任意一项所述的方法。
CN201810169665.3A 2018-02-28 2018-02-28 用于即时通信的方法、介质、装置和计算设备 Active CN108363629B (zh)

Priority Applications (1)

Application Number Priority Date Filing Date Title
CN201810169665.3A CN108363629B (zh) 2018-02-28 2018-02-28 用于即时通信的方法、介质、装置和计算设备

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
CN201810169665.3A CN108363629B (zh) 2018-02-28 2018-02-28 用于即时通信的方法、介质、装置和计算设备

Publications (2)

Publication Number Publication Date
CN108363629A CN108363629A (zh) 2018-08-03
CN108363629B true CN108363629B (zh) 2020-10-27

Family

ID=63002900

Family Applications (1)

Application Number Title Priority Date Filing Date
CN201810169665.3A Active CN108363629B (zh) 2018-02-28 2018-02-28 用于即时通信的方法、介质、装置和计算设备

Country Status (1)

Country Link
CN (1) CN108363629B (zh)

Families Citing this family (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN109461238A (zh) * 2018-10-30 2019-03-12 北京摩拜科技有限公司 车辆控制方法、服务器、车辆及车辆系统
CN116450370A (zh) * 2022-01-06 2023-07-18 北京有竹居网络技术有限公司 一种进程间通信的方法及装置

Citations (5)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN103647768A (zh) * 2013-12-06 2014-03-19 北京奇虎科技有限公司 游戏客户端及其实现方法
CN104394270A (zh) * 2014-11-20 2015-03-04 北京安奇智联科技有限公司 辅助接听电话的方法和设备
CN205594346U (zh) * 2016-02-29 2016-09-21 湖南高至科技有限公司 基于rtx的实时数据辅助分析系统
CN106941713A (zh) * 2017-05-16 2017-07-11 努比亚技术有限公司 一种降低移动终端功耗的方法及其装置
CN107391285A (zh) * 2017-08-23 2017-11-24 美的智慧家居科技有限公司 内存共享方法和系统

Family Cites Families (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
DE502007002352D1 (de) * 2007-09-24 2010-01-28 Avaya Gmbh & Co Kg Verfahren zum Herstellen einer Kommunikationsverbindung und Telekommunikationsanlage zur Durchführung des Verfahrens

Patent Citations (5)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN103647768A (zh) * 2013-12-06 2014-03-19 北京奇虎科技有限公司 游戏客户端及其实现方法
CN104394270A (zh) * 2014-11-20 2015-03-04 北京安奇智联科技有限公司 辅助接听电话的方法和设备
CN205594346U (zh) * 2016-02-29 2016-09-21 湖南高至科技有限公司 基于rtx的实时数据辅助分析系统
CN106941713A (zh) * 2017-05-16 2017-07-11 努比亚技术有限公司 一种降低移动终端功耗的方法及其装置
CN107391285A (zh) * 2017-08-23 2017-11-24 美的智慧家居科技有限公司 内存共享方法和系统

Non-Patent Citations (1)

* Cited by examiner, † Cited by third party
Title
移动协作管理系统的设计与实现;梁宁;《中国优秀硕士学位论文全文数据库 信息科技辑》;20170531;全文 *

Also Published As

Publication number Publication date
CN108363629A (zh) 2018-08-03

Similar Documents

Publication Publication Date Title
EP3547715B1 (en) Method and apparatus for reducing continuous-wakeup delay of bluetooth loudspeaker, and bluetooth loudspeaker
US8782139B2 (en) Transferring applications and session state to a secondary device
CN110750393B (zh) 避免网络服务双机热备脑裂的方法、装置、介质和设备
EP3633957A1 (en) Data storage method, storage server, storage medium and system
CN109150662B (zh) 消息传输方法、分布式系统、设备、介质和无人车
CN110413432B (zh) 一种信息处理方法、电子设备及存储介质
CN108363629B (zh) 用于即时通信的方法、介质、装置和计算设备
CN114637475A (zh) 一种分布式存储系统控制方法、装置及可读存储介质
CN109982355B (zh) 保存和恢复网络通路的方法及其装置、终端和存储介质
CN114363154A (zh) 节点选举方法、装置、电子设备及存储介质
CN110740145A (zh) 消息消费方法、装置、存储介质及电子设备
CN112769876B (zh) 一种设备通道信息获取方法、装置、设备和介质
CN110881224B (zh) 一种网络长连接方法、装置、设备及存储介质
CN107733781B (zh) 一种即时通信的处理方法、设备和计算机存储介质
CN112513832B (zh) 一种数据的存储方法及设备
US8055991B2 (en) Error detection and recovery using an asynchronous transaction journal
CN113254274A (zh) 消息处理方法、装置、存储介质以及服务器
CN110321199B (zh) 一种共用数据变更的通知方法、装置、电子设备及介质
CN111274047A (zh) 信息处理方法、终端、系统、计算机设备和存储介质
CN112416641B (zh) 主从架构中被控端节点重启检测方法及主控端节点
US11386043B2 (en) Method, device, and computer program product for managing snapshot in application environment
CN116260747A (zh) 终端测试设备的监测方法、装置及电子设备
CN113079152A (zh) 一种数据传输方法、装置及介质
CN114051047B (zh) 一种会话消息的备份方法、装置、网络设备和存储介质
CN115328693A (zh) 一种业务进程恢复业务的方法、装置、设备及存储介质

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
TR01 Transfer of patent right

Effective date of registration: 20210926

Address after: 310052 Room 408, building 3, No. 399, Wangshang Road, Changhe street, Binjiang District, Hangzhou City, Zhejiang Province

Patentee after: Hangzhou Netease Zhiqi Technology Co.,Ltd.

Address before: 310052 Room 301, Building No. 599, Changhe Street Network Business Road, Binjiang District, Hangzhou City, Zhejiang Province

Patentee before: HANGZHOU LANGHE TECHNOLOGY Ltd.

TR01 Transfer of patent right