CN109766093B - 协同实时编辑的方法、装置、电子设备及存储介质 - Google Patents
协同实时编辑的方法、装置、电子设备及存储介质 Download PDFInfo
- Publication number
- CN109766093B CN109766093B CN201910046151.3A CN201910046151A CN109766093B CN 109766093 B CN109766093 B CN 109766093B CN 201910046151 A CN201910046151 A CN 201910046151A CN 109766093 B CN109766093 B CN 109766093B
- Authority
- CN
- China
- Prior art keywords
- time
- data
- file
- comparison result
- conflict
- 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
Links
Images
Landscapes
- Information Retrieval, Db Structures And Fs Structures Therefor (AREA)
Abstract
本发明提供一种协同实时编辑的方法、装置、电子设备及存储介质,所述方法通过判断第一时间和第二时间的时间先后顺序,在所述第二时间为距离当前时刻最近的时间,生成用于表征所述第二数据和第一文件中与所述比较结果对应的数据冲突的冲突结果,继而能够实现在多人协同实时对相同的数据进行编辑时,若出现编辑冲突,能够及时展示冲突结果,实现过程简单,提高提升了可视化编程的效率和用户体验。
Description
技术领域
本发明涉及可视化编程领域,具体而言,涉及一种协同实时编辑的方法、装置、电子设备及存储介质。
背景技术
可视化编程,以“所见即所得”的编程思想为原则,力图实现编程工作的可视化,即随时可以看到结果,程序与结果的调整同步,一个网站是有多个模块构成,所以就需要不同的人员协同编程,可视化编程也同样需要人员的协同编程。
可视化协同编程过程中,多个开发者可能在同一时间对同一个页面进行修改,这个操作可能会造成许多的冲突,要解决实现实时编辑不冲突的问题,需要解决两个技术点:实时通信问题、编辑冲突问题,其中实时通信问题比较好解决,用WebSocket便可以很好的解决,现在解决协同编辑冲突的技术主要有:编辑锁、Myer’s diff-patch、OperationalTransformation。
编辑锁方式实现协同编程最简单的方法,当有人在编辑某个页面时,系统会将这个页面锁定,避免其他人同时编辑,采用这种方式虽然可以在一定程度上避免覆盖问题,但它的使用体验不好。Myer’s diff-patch和Operational Transformation虽然可以比较好的比较出修改冲突,但是实现过程比较复杂,在用户体验上不是特别好。
发明内容
鉴于此,本发明实施例提供一种协同实时编辑的方法、装置、电子设备及存储介质,在出现编辑冲突时,能够及时展示冲突结果,实现多人协调实时编辑,提高可视化编程的效率和用户体验。
第一方面,本发明实施例提供一种协同实时编辑的方法,所述方法包括:获取用于表征保存第一文件请求,其中,所述请求包括:比较结果、第一时间,所述第一文件为对原文件执行第一操作后的文件,所述比较结果为用于表征所述第一文件与所述原文件中不同的数据,所述第一时间为用于表征所述第一操作结束的时间;基于所述比较结果,确定所述第一操作所属事务类别,其中,所述事务类别包括:删除事件、增加事件以及修改事件;在确定所述第一操作不属于所述增加事件时,获取第二数据,以及与所述第二数据对应的第二时间,其中,所述第二数据为对所述原文件中与所述比较结果对应的数据执行第二操作后的数据,所述第二时间为所述第二操作结束的时间;若所述第二时间为距离当前时刻最近的时间,生成用于表征所述第二数据和第一文件中与所述比较结果对应的数据冲突的冲突结果。通过判断第一时间和第二时间的时间先后顺序,在所述第二时间为距离当前时刻最近的时间,生成用于表征所述第二数据和第一文件中与所述比较结果对应的数据冲突的冲突结果,继而能够实现在多人协同实时对相同的数据进行编辑时,若出现编辑冲突,能够及时展示冲突结果,实现过程简单,提高提升了可视化编程的效率和用户体验。
基于第一方面,在一种可能的设计中,获取第二数据,以及与所述第二数据对应的第二时间,包括:获取与所述比较结果对应的标识;基于所述标识,在预先存储的标识与数据的对应关系中,获取与所述标识对应的第二数据,以及与所述第二数据对应的第二时间。通过该方式,能够快速准确的获取到与所述标识对应的第二数据。
基于第一方面,在一种可能的设计中,在确定所述第一操作所属事务类别之后,所述方法还包括:在确定所述第一操作属于所述增加事件时,将与所述比较结果对应的数据和所述第一时间一一对应的保存至数据库。通过该方式,在确定所述第一操作属于所述增加事件时,无需进行时间比较,也无需基于所述标识来查询数据,提高数据处理效率。
基于第一方面,在一种可能的设计中,获取第二数据,以及与所述第二数据对应的第二时间之后,所述方法还包括:若所述第一时间为距离当前时刻最近的时间,且在所述第一操作属于所述修改事件时,将与所述比较结果对应的数据和所述第一时间一一对应的保存至数据库。通过该方式,不仅能够实现对数据库的及时更新,也能够实现多人协同实时编辑。
基于第一方面,在一种可能的设计中,获取第二数据,以及与所述第二数据对应的第二时间之后,所述方法还包括:若所述第一时间为距离当前时刻最近的时间,且在所述第一操作属于所述删除事件时,将存储在数据库中的所述第二数据删除。通过该方式,不仅能够实现对数据库的及时更新,也能够实现多人协同实时编辑。
第二方面,本发明实施例提供一种协同实时编辑的的装置,所述装置包括:请求获取单元,用于获取用于表征保存第一文件请求,其中,所述请求包括:比较结果、第一时间,所述第一文件为对原文件执行第一操作后的文件,所述比较结果为用于表征所述第一文件与所述原文件中不同的数据,所述第一时间为用于表征所述第一操作结束的时间;确定单元,用于基于所述比较结果,确定所述第一操作所属事务类别,其中,所述事务类别包括:删除事件、增加事件以及修改事件;数据获取单元,用于在确定所述第一操作不属于所述增加事件时,获取第二数据,以及与所述第二数据对应的第二时间,其中,所述第二数据为对所述原文件中与所述比较结果对应的数据执行第二操作后的数据,所述第二时间为所述第二操作结束的时间;冲突结果生成单元,用于若所述第二时间为距离当前时刻最近的时间,生成用于表征所述第二数据和第一文件中与所述比较结果对应的数据冲突的冲突结果。
基于第二方面,在一种可能的设计中,所述数据获取单元,用于获取与所述比较结果对应的标识;以及基于所述标识,在预先存储的标识与数据的对应关系中,获取与所述标识对应的第二数据,以及与所述第二数据对应的第二时间。
基于第二方面,在一种可能的设计中,所述装置还包括:第一存储单元,用于在确定所述第一操作属于所述增加事件时,将与所述比较结果对应的数据和所述第一时间一一对应的保存至数据库。
基于第二方面,在一种可能的设计中,所述装置还包括:第二存储单元,用于若所述第一时间为距离当前时刻最近的时间,且在所述第一操作属于所述修改事件时,将与所述比较结果对应的数据和所述第一时间一一对应的保存至数据库。
基于第二方面,在一种可能的设计中,所述装置还包括:删除单元,用于若所述第一时间为距离当前时刻最近的时间,且在所述第一操作属于所述删除事件时,将存储在数据库中的所述第二数据删除。
第三方面,本发明实施例提供一种电子设备,包括处理器以及与所述处理器连接的存储器,所述存储器内存储计算机程序,当所述计算机程序被所述处理器执行时,使得所述电子设备执行第一方面所述的方法。
第四方面,本发明实施例提供一种存储介质,所述存储介质中存储有计算机程序,当所述计算机程序在计算机上运行时,使得所述计算机执行第一方面所述的方法。
本发明的其他特征和优点将在随后的说明书阐述,并且,部分地从说明书中变得显而易见,或者通过实施本发明实施例了解。本发明的目的和其他优点可通过在所写的说明书、权利要求书、以及附图中所特别指出的结构来实现和获得。
附图说明
为了更清楚地说明本发明实施例的技术方案,下面将对实施例中所需要使用的附图作简单地介绍,应当理解,以下附图仅示出了本发明的某些实施例,因此不应被看作是对范围的限定,对于本领域普通技术人员来讲,在不付出创造性劳动的前提下,还可以根据这些附图获得其他相关的附图。
图1为本发明实施例提供的电子设备的结构示意图;
图2为本发明第一实施例提供的协同实时编辑的方法的流程图;
图3为本发明第二实施例提供的协同实时编辑的装置的结构框图。
图标:100-电子设备;110-存储器;120-存储控制器;130-处理器;140-外设接口;150-输入输出单元;160-音频单元;170-显示单元;410-请求获取单元;420-确定单元;430-数据获取单元;440-冲突结果生成单元。
具体实施方式
下面将结合本发明实施例中附图,对本发明实施例中的技术方案进行清楚、完整地描述,显然,所描述的实施例仅仅是本发明一部分实施例,而不是全部的实施例。通常在此处附图中描述和示出的本发明实施例的组件可以以各种不同的配置来布置和设计。因此,以下对在附图中提供的本发明的实施例的详细描述并非旨在限制要求保护的本发明的范围,而是仅仅表示本发明的选定实施例。基于本发明的实施例,本领域技术人员在没有做出创造性劳动的前提下所获得的所有其他实施例,都属于本发明保护的范围。
应注意到:相似的标号和字母在下面的附图中表示类似项,因此,一旦某一项在一个附图中被定义,则在随后的附图中不需要对其进行进一步定义和解释。同时,在本发明的描述中,术语“第一”、“第二”等仅用于区分描述,而不能理解为指示或暗示相对重要性。
本发明实施例提供一种电子设备100的结构示意图,所述电子设备100可以是个人电脑(personal computer,PC)、平板电脑、智能手机、个人数字助理(personal digitalassistant,PDA)等。
如图1所示,所述电子设备100可以包括:协同实时编辑的装置、存储器110、存储控制器120、处理器130、外设接口140、输入输出单元150、音频单元160、显示单元170。
所述存储器110、存储控制器120、处理器130、外设接口140、输入输出单元150、音频单元160以及显示单元170各元件相互之间直接或间接地电性连接,以实现数据的传输或交互。例如,这些元件相互之间可通过一条或多条通讯总线或信号线实现电性连接。所述协同实时编辑的装置包括至少一个可以软件或固件(firmware)的形式存储于所述存储器110中或固化在客户端设备的操作装置(operating system,OS)中的软件功能模块。所述处理器130用于执行存储器110中存储的可执行模块,例如所述协同实时编辑的装置包括的软件功能模块或计算机程序。
其中,存储器110可以是,但不限于,随机存取存储器(Random Access Memory,RAM),只读存储器(Read Only Memory,ROM),可编程只读存储器(Programmable Read-OnlyMemory,PROM),可擦除只读存储器(Erasable Programmable Read-Only Memory,EPROM),电可擦除只读存储器(Electric Erasable Programmable Read-Only Memory,EEPROM)等。其中,存储器110用于存储程序,所述处理器130在接收到执行指令后,执行所述程序,前述本发明实施例任一实施例揭示的流程定义的电子设备100所执行的方法可以应用于处理器130中,或者由处理器130实现。
处理器130可能是一种集成电路芯片,具有信号的处理能力。上述的处理器130可以是通用处理器,包括中央处理器(Central Processing Unit,简称CPU)、网络处理器(Network Processor,简称NP)等;还可以是数字信号处理器(DSP)、专用集成电路(ASIC)、现场可编程门阵列(FPGA)或者其他可编程逻辑器件、分立门或者晶体管逻辑器件、分立硬件组件。可以实现或者执行本发明实施例中的公开的各方法、步骤及逻辑框图。通用处理器可以是微处理器或者该处理器也可以是任何常规的处理器等。
所述外设接口140将各种输入/输出装置耦合至处理器130以及存储器110。在一些实施例中,外设接口140,处理器130以及存储控制器120可以在单个芯片中实现。在其他一些实例中,他们可以分别由独立的芯片实现。
输入输出单元150用于提供给用户输入数据实现用户与电子设备100的交互。所述输入输出单元150可以是,但不限于,鼠标和键盘等。
音频单元160向用户提供音频接口,其可包括一个或多个麦克风、一个或者多个扬声器以及音频电路。
显示单元170在电子设备100与用户之间提供一个交互界面(例如用户操作界面)或用于显示图像数据给用户参考。在本实施例中,所述显示单元170可以是液晶显示器或触控显示器。若为触控显示器,其可为支持单点和多点触控操作的电容式触控屏或电阻式触控屏等。支持单点和多点触控操作是指触控显示器能感应到来自该触控显示器上一个或多个位置处同时产生的触控操作,并将该感应到的触控操作交由处理器130进行计算和处理。
第一实施例
请参照图2,图2为本发明第一实施例提供的一种协同实时编辑的方法的流程图,所述方法应用于如图1所示的电子设备100,下面将对图2所示的流程进行详细阐述,所述方法包括:
S100:获取用于表征保存第一文件请求,其中,所述请求包括:比较结果、第一时间,所述第一文件为对原文件执行第一操作后的文件,所述比较结果为用于表征所述第一文件与所述原文件中不同的数据,所述第一时间为用于表征所述第一操作结束的时间。
在可视化协同编程过程中,假设多个开发者在同一时间开始对同一个页面进行操作,其中,在本实施例中,文件中包含与开发页面对应的数据,例如,在A开发人员和B开发人员在2018年12月3日8点10分对页面甲进行修改,其中,A开发人员在2018年12月3日8点11分完成对A1控件的修改,例如,将A1控件的颜色由黑色修改为灰色,A开发人员在2018年12月3日8点12分完成对A2控件的修改,例如,将A2控件的形状由圆形修改为椭圆形,A开发人员在2018年12月3日8点12分30秒点击开发页面甲上的保存图标,以发送用于表征保存第一文件请求,作为一种实施方式,在A开发人员完成对页面甲进行操作后,基于预设时间间隔自动发送用于表征保存第一文件请求,其中,所述预设时间间隔可以2秒、5秒,10秒等。其中,所述请求包括:比较结果、第一时间,所述第一文件为对页面甲执行第一操作后的文件,所述比较结果为用于表征所述第一文件与所述原文件中不同的数据,在对所述第一文件保存之前,作为一种实施方式,利用diff算法对所述第一文件与所述原文件中的数据进行比较,获取用于表征所述第一文件与所述原文件中不同的diff数据,可以理解的是,基于diff数据可以获得如下信息:将A1控件的颜色由黑色修改为灰色,将A2控件的形状由圆形修改为椭圆形;第一时间为用于表征所述第一操作结束的时间,可以理解的是,对于控件A1,第一时间为2018年12月3日8点11分,对于控件A2,第一时间为2018年12月3日8点12分。
S200:基于所述比较结果,确定所述第一操作所属事务类别,其中,所述事务类别包括:删除事件、增加事件以及修改事件。
在本实施例中,基于所述比较结果,可以获取的信息:将A1控件的颜色由黑色修改为灰色,将A2控件的形状由圆形修改为椭圆形,继而能够确定所述第一操作属于修改事件。例如,基于所述比较结果,获取的信息:增加A1控件,其中,A1控件具有如下属性,A1控件的颜色为红色、形状为圆形等属性,继而能够确定所述第一操作属于增加事件。例如,基于所述比较结果,获取的信息:删除A1控件,继而能够确定所述第一操作属于删除事件。例如:基于所述比较结果,可以获取的信息:将A1控件的颜色由黑色修改为灰色,删除A3控件,继而能够确定所述第一操作属于修改事件和删除事件。
作为一种实施方式,在S200之后,所述方法还包括:
在确定所述第一操作属于所述增加事件时,将与所述比较结果对应的数据和所述第一时间一一对应的保存至数据库。
例如,A开发人员在2018年12月3日8点11分30秒在页面甲中完成对A3控件的添加,基于所述比较结果,获取的信息:增加A3控件,其中,A3控件具有如下属性,A3控件的颜色为红色、形状为圆形等属性,继而能够确定所述第一操作属于增加事件,将A3控件和添加完成A3控件的时间2018年12月3日8点11分30秒对应的保存至数据库中,在本实施例中,将A3控件的相关信息保存至存储在数据库中的与页面甲对应的文件中,以更新数据库。
通过该方式,在确定所述第一操作属于所述增加事件时,无需进行时间比较,也无需基于所述标识来查询数据,提高数据处理效率。
S300:在确定所述第一操作不属于所述增加事件时,获取第二数据,以及与所述第二数据对应的第二时间,其中,所述第二数据为对所述原文件中与所述比较结果对应的数据执行第二操作后的数据,所述第二时间为所述第二操作结束的时间。
作为一种实施方式,S300包括:
获取与所述比较结果对应的标识。
在确定所述第一操作不属于所述增加事件时,获取与所述比较结果对应的标识,在本实施例中,所述标识为用于表征数据身份的ID号,不同的数据具有不同的ID号,可以理解的是,不同的控件具有不同的ID号,其中,在本实施例中ID号为十进制数,在其他实施例中ID号也可以为二进制数、八进制数等,例如,控件A1的ID号为11,控件A2的ID号为12,控件A3的ID号为14。例如:基于所述比较结果获取的信息:将A1控件的颜色由黑色修改为灰色,其中,A1控件的ID号为11,因此,获取的ID号为11。
基于所述标识,在预先存储的标识与数据的对应关系中,获取与所述标识对应的第二数据,以及与所述第二数据对应的第二时间。
在获取的ID号为11时,基于ID查询条件,在预先存储的ID与数据的对应关系中,获取存储在数据库中的A1控件的相关信息(第二数据,以及与所述第二数据对应的第二时间),其中,所述第二数据为对所述原文件中的A1控件执行第二操作后的数据,所述第二时间为所述第二操作结束的时间。例如:在所述第二操作为对所述原文件中的A1控件的颜色由黑色修改为绿色,其中,所述第二操作结束的时间(第二时间)为2018年12月3日8点10分30秒。
通过该方式,能够快速准确的获取到与所述标识对应的第二数据。
作为一种实施方式,在S300之后,所述方法还包括:
若所述第一时间为距离当前时刻最近的时间,且在所述第一操作属于所述修改事件时,将与所述比较结果对应的数据和所述第一时间一一对应的保存至数据库。
在第一时间为2018年12月3日8点11分,第二时间为2018年12月3日8点10分30秒,因此,确定所述第一时间为距离当前时刻最近的时间,且在所述第一操作属于所述修改事件时,例如,在所述比较结果为将所述原文件中的A1控件的颜色由黑色修改为灰色时,确定所述第一操作为对所述原文件中的A1控件的颜色由黑色修改为灰色,将对原文件中的A1控件进行第一操作后的数据和第一时间一一对应的保存至数据库,作为一种实施方式,作为一种实施方式,首先基于A1控件的ID,将存储在数据库中的所述第二数据和所述第二时间删除,然后将对原文件中的A1控件进行第一操作后的数据和第一时间(2018年12月3日8点11分)一一对应的保存至数据库,以更新数据库。作为一种实施方式,基于所述比较结果和A1控件的ID,在数据库中将所述第二数据修改为与所述比较结果对应的数据,并将所述第二时间(2018年12月3日8点10分30秒)修改为所述第一时间(2018年12月3日8点11分)。
通过该方式,不仅能够实现对数据库的及时更新,也能够实现多人协同实时编辑。
作为一种实施方式,在S300之后,所述方法还包括:
若所述第一时间为距离当前时刻最近的时间,且在所述第一操作属于所述删除事件时,将存储在数据库中的所述第二数据删除。
在第一时间为2018年12月3日8点11分,第二时间为2018年12月3日8点10分30秒,因此,确定所述第一时间为距离当前时刻最近的时间,且在所述第一操作属于所述删除事件时,例如,在所述比较结果为将所述原文件中的A1控件删除时,确定所述第一操作为所述删除事件,将存储在数据库中的所述第二数据(原文件中的A1控件)删除,以更新数据库。作为一种实施方式,基于A1控件的ID,将存储在数据库中的与所述ID对应的所述第二数据(原文件中的A1控件)删除,以更新数据库。
通过该方式,不仅能够实现对数据库的及时更新,也能够实现多人协同实时编辑。
S400:若所述第二时间为距离当前时刻最近的时间,生成用于表征所述第二数据和第一文件中与所述比较结果对应的数据冲突的冲突结果。
在第一时间为2018年12月3日8点10分40秒,第二时间为2018年12月3日8点11分,因此,确定所述第二时间为距离当前时刻最近的时间,所述比较结果A开发人员将所述原文件中的A1控件的颜色由黑色修改为灰色,第二数据为B开发人员将所述原文件中的A1控件的颜色由黑色修改为绿色,由于存储在数据库中的第二数据对应的第二时间在第一时间之后,因此,A开发人员在第一时间执行完的第一操作和B开发人员在第二时间执行完的第二操作发生冲突,继而生成用于表征所述第二数据和第一文件中与所述比较结果对应的数据冲突的冲突结果,并将所述冲突结果发送至A开发人员的开发页面进行展示,以提示A开发人员。
通过该方式,能够实现在多人协同实时对相同的数据进行编辑时,若出现编辑冲突,能够及时展示冲突结果,实现过程简单,提高提升了可视化编程的效率和用户体验。
第二实施例
请参照图3,图3是本发明第二实施例提供的一种协同实时编辑的的装置的结构框图。所述装置存储于如图1所述的电子设备100,下面将对图3所示的结构框图进行阐述,所示装置包括:
请求获取单元410,用于获取用于表征保存第一文件请求,其中,所述请求包括:比较结果、第一时间,所述第一文件为对原文件执行第一操作后的文件,所述比较结果为用于表征所述第一文件与所述原文件中不同的数据,所述第一时间为用于表征所述第一操作结束的时间;
确定单元420,用于基于所述比较结果,确定所述第一操作所属事务类别,其中,所述事务类别包括:删除事件、增加事件以及修改事件;
数据获取单元430,用于在确定所述第一操作不属于所述增加事件时,获取第二数据,以及与所述第二数据对应的第二时间,其中,所述第二数据为对所述原文件中与所述比较结果对应的数据执行第二操作后的数据,所述第二时间为所述第二操作结束的时间;
冲突结果生成单元440,用于若所述第二时间为距离当前时刻最近的时间,生成用于表征所述第二数据和第一文件中与所述比较结果对应的数据冲突的冲突结果。
作为一种实施方式,所述数据获取单元430,用于获取与所述比较结果对应的标识;以及基于所述标识,在预先存储的标识与数据的对应关系中,获取与所述标识对应的第二数据,以及与所述第二数据对应的第二时间。
作为一种实施方式,所述装置还包括:第一存储单元,用于在确定所述第一操作属于所述增加事件时,将与所述比较结果对应的数据和所述第一时间一一对应的保存至数据库。
作为一种实施方式,所述装置还包括:第二存储单元,用于若所述第一时间为距离当前时刻最近的时间,且在所述第一操作属于所述修改事件时,将与所述比较结果对应的数据和所述第一时间一一对应的保存至数据库。
作为一种实施方式,所述装置还包括:删除单元,用于若所述第一时间为距离当前时刻最近的时间,且在所述第一操作属于所述删除事件时,将存储在数据库中的所述第二数据删除。
本实施例对协同实时编辑的装置的各功能单元实现各自功能的过程,请参见上述图2所示实施例中描述的内容,此处不再赘述。
此外,本发明实施例还提供了一种存储介质,在该存储介质中存储有计算机程序,当所述计算机程序在计算机上运行时,使得所述计算机执行本发明任一项实施方式所提供的协同实时编辑的方法。
综上所述,本发明各实施例提出协同实时编辑的方法、装置、电子设备及存储介质,所述方法包括:获取用于表征保存第一文件请求,其中,所述请求包括:比较结果、第一时间,所述第一文件为对原文件执行第一操作后的文件,所述比较结果为用于表征所述第一文件与所述原文件中不同的数据,所述第一时间为用于表征所述第一操作结束的时间;基于所述比较结果,确定所述第一操作所属事务类别,其中,所述事务类别包括:删除事件、增加事件以及修改事件;在确定所述第一操作不属于所述增加事件时,获取第二数据,以及与所述第二数据对应的第二时间,其中,所述第二数据为对所述原文件中与所述比较结果对应的数据执行第二操作后的数据,所述第二时间为所述第二操作结束的时间;若所述第二时间为距离当前时刻最近的时间,生成用于表征所述第二数据和第一文件中与所述比较结果对应的数据冲突的冲突结果。通过判断第一时间和第二时间的时间先后顺序,在所述第二时间为距离当前时刻最近的时间,生成用于表征所述第二数据和第一文件中与所述比较结果对应的数据冲突的冲突结果,继而能够实现在多人协同实时对相同的数据进行编辑时,若出现编辑冲突,能够及时展示冲突结果,实现过程简单,提高提升了可视化编程的效率和用户体验。
在本申请所提供的几个实施例中,应该理解到,所揭露的装置和方法,也可以通过其它的方式实现。以上所描述的装置实施例仅仅是示意性的,例如,附图中的流程图和框图显示了根据本发明的多个实施例的装置、方法和计算机程序产品的可能实现的体系架构、功能和操作。在这点上,流程图或框图中的每个方框可以代表一个模块、程序段或代码的一部分,所述模块、程序段或代码的一部分包含一个或多个用于实现规定的逻辑功能的可执行指令。也应当注意,在有些作为替换的实现方式中,方框中所标注的功能也可以以不同于附图中所标注的顺序发生。例如,两个连续的方框实际上可以基本并行地执行,它们有时也可以按相反的顺序执行,这依所涉及的功能而定。也要注意的是,框图和/或流程图中的每个方框、以及框图和/或流程图中的方框的组合,可以用执行规定的功能或动作的专用的基于硬件的装置来实现,或者可以用专用硬件与计算机指令的组合来实现。
另外,在本发明各个实施例中的各功能模块可以集成在一起形成一个独立的部分,也可以是各个模块单独存在,也可以两个或两个以上模块集成形成一个独立的部分。
Claims (10)
1.一种协同实时编辑的方法,其特征在于,所述方法包括:
获取用于表征保存第一文件请求,其中,所述请求包括:比较结果、第一时间,所述第一文件为对原文件执行第一操作后的文件,所述比较结果为用于表征所述第一文件与所述原文件中不同的数据,所述第一时间为用于表征所述第一操作结束的时间;
基于所述比较结果,确定所述第一操作所属事务类别,其中,所述事务类别包括:删除事件、增加事件以及修改事件;
在确定所述第一操作不属于所述增加事件时,获取第二数据,以及与所述第二数据对应的第二时间,其中,所述第二数据为对所述原文件中与所述比较结果对应的数据执行第二操作后的数据,所述第二时间为所述第二操作结束的时间;
若所述第二时间为距离当前时刻最近的时间,生成用于表征所述第二数据和第一文件中与所述比较结果对应的数据冲突的冲突结果。
2.根据权利要求1所述的方法,其特征在于,获取第二数据,以及与所述第二数据对应的第二时间,包括:
获取与所述比较结果对应的标识;
基于所述标识,在预先存储的标识与数据的对应关系中,获取与所述标识对应的第二数据,以及与所述第二数据对应的第二时间。
3.根据权利要求1所述的方法,其特征在于,在确定所述第一操作所属事务类别之后,所述方法还包括:
在确定所述第一操作属于所述增加事件时,将与所述比较结果对应的数据和所述第一时间一一对应的保存至数据库。
4.根据权利要求1所述的方法,其特征在于,获取第二数据,以及与所述第二数据对应的第二时间之后,所述方法还包括:
若所述第一时间为距离当前时刻最近的时间,且在所述第一操作属于所述修改事件时,将与所述比较结果对应的数据和所述第一时间一一对应的保存至数据库。
5.根据权利要求1所述的方法,其特征在于,获取第二数据,以及与所述第二数据对应的第二时间之后,所述方法还包括:
若所述第一时间为距离当前时刻最近的时间,且在所述第一操作属于所述删除事件时,将存储在数据库中的所述第二数据删除。
6.一种协同实时编辑的装置,其特征在于,所述装置包括:
请求获取单元,用于获取用于表征保存第一文件请求,其中,所述请求包括:比较结果、第一时间,所述第一文件为对原文件执行第一操作后的文件,所述比较结果为用于表征所述第一文件与所述原文件中不同的数据,所述第一时间为用于表征所述第一操作结束的时间;
确定单元,用于基于所述比较结果,确定所述第一操作所属事务类别,其中,所述事务类别包括:删除事件、增加事件以及修改事件;
数据获取单元,用于在确定所述第一操作不属于所述增加事件时,获取第二数据,以及与所述第二数据对应的第二时间,其中,所述第二数据为对所述原文件中与所述比较结果对应的数据执行第二操作后的数据,所述第二时间为所述第二操作结束的时间;
冲突结果生成单元,用于若所述第二时间为距离当前时刻最近的时间,生成用于表征所述第二数据和第一文件中与所述比较结果对应的数据冲突的冲突结果。
7.根据权利要求6所述的装置,其特征在于,所述数据获取单元,
用于获取与所述比较结果对应的标识;以及基于所述标识,在预先存储的标识与数据的对应关系中,获取与所述标识对应的第二数据,以及与所述第二数据对应的第二时间。
8.根据权利要求6所述的装置,其特征在于,所述装置还包括:
存储单元,用于在确定所述第一操作属于所述增加事件时,将与所述比较结果对应的数据和所述第一时间一一对应的保存至数据库。
9.一种电子设备,其特征在于,包括处理器以及与所述处理器连接的存储器,所述存储器内存储计算机程序,当所述计算机程序被所述处理器运行时,使得所述电子设备执行权利要求1-5中任意一项所述的方法。
10.一种存储介质,其特征在于,所述存储介质中存储有计算机程序,当所述计算机程序在计算机上运行时,使得所述计算机执行如权利要求1-5中任意一项所述的方法。
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN201910046151.3A CN109766093B (zh) | 2019-01-17 | 2019-01-17 | 协同实时编辑的方法、装置、电子设备及存储介质 |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN201910046151.3A CN109766093B (zh) | 2019-01-17 | 2019-01-17 | 协同实时编辑的方法、装置、电子设备及存储介质 |
Publications (2)
Publication Number | Publication Date |
---|---|
CN109766093A CN109766093A (zh) | 2019-05-17 |
CN109766093B true CN109766093B (zh) | 2022-03-15 |
Family
ID=66452480
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN201910046151.3A Active CN109766093B (zh) | 2019-01-17 | 2019-01-17 | 协同实时编辑的方法、装置、电子设备及存储介质 |
Country Status (1)
Country | Link |
---|---|
CN (1) | CN109766093B (zh) |
Families Citing this family (1)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN112165510A (zh) * | 2020-09-02 | 2021-01-01 | 北方民族大学 | 一种协同可视化服务器 |
Family Cites Families (3)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN102916998A (zh) * | 2012-03-26 | 2013-02-06 | 上海方正数字出版技术有限公司 | 一种基于云计算的网络公共白板系统及方法 |
CN106354732B (zh) * | 2015-07-17 | 2019-07-05 | 中国石油化工股份有限公司 | 一种支持并发协同的离线数据版本冲突解决方法 |
US20180107455A1 (en) * | 2015-12-29 | 2018-04-19 | Eyelead Software SA | Real-time collaborative development in a live programming system |
-
2019
- 2019-01-17 CN CN201910046151.3A patent/CN109766093B/zh active Active
Also Published As
Publication number | Publication date |
---|---|
CN109766093A (zh) | 2019-05-17 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
CN108228169B (zh) | 基于eCharts工具的图表制作方法、装置、设备及介质 | |
CN111049878B (zh) | 微服务调用链具象化的方法、装置、电子装置及存储介质 | |
US7571191B2 (en) | Defining a data analysis process | |
TW202113586A (zh) | 小程式產生方法以及裝置 | |
US20210333984A1 (en) | Method and apparatus for generating customized visualization component | |
CN110543306B (zh) | 交互式数据可视化方法及应用系统、存储介质 | |
CN108038894B (zh) | 动画创建方法、装置、电子设备及计算机可读存储介质 | |
CN108388623B (zh) | Er关系生成方法、装置、计算机设备及存储介质 | |
US20230153519A1 (en) | Document tracking through version hash linked graphs | |
CN111476007B (zh) | 表格生成方法、装置、计算机装置及计算机可读存储介质 | |
CN112130951A (zh) | 基于ai的rpa流程生成端的流程生成方法、设备及存储介质 | |
CN113590097B (zh) | 一种api接口的生成方法、装置、电子设备及存储介质 | |
CN109766093B (zh) | 协同实时编辑的方法、装置、电子设备及存储介质 | |
CN114493541A (zh) | 任务创建方法、装置、电子设备、存储介质和程序产品 | |
US20220405823A1 (en) | Object comparison method, and device | |
CN110780970A (zh) | 数据筛选方法、装置、设备及计算机可读存储介质 | |
CN114629800B (zh) | 工控网络靶场的可视化生成方法、装置、终端及存储介质 | |
CN115113862A (zh) | 一种派生指标创建方法、装置、电子设备及存储介质 | |
CN115033233A (zh) | 一种接口调用方法、装置、电子设备及存储介质 | |
CN109871214B (zh) | 程序代码生成方法、装置、计算机设备和存储介质 | |
CN108960433B (zh) | 用于运行机器学习建模过程的方法及系统 | |
CN113971993A (zh) | 临床试验数据转换方法、装置、计算机设备和存储介质 | |
CN109711809B (zh) | 商户属性设置方法、装置、计算机设备及存储介质 | |
CN113760317A (zh) | 一种页面显示方法、装置、设备及存储介质 | |
CN116204267B (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 |