
技术摘要:
本发明公开了一种对象克隆的方法、系统、设备和存储介质,方法包括:基于被克隆对象创建父对象,并建立父对象与被克隆对象的键值对数据的关联;基于父对象创建多个子对象,并建立多个子对象与父对象的键值对数据的关联;响应于在子对象中增加键值对数据,将待增加的键 全部
背景技术:
克隆操作要求创建一个kv(key-value,键值对)数据与被克隆对象完全相同的全 新对象,当被克隆对象包含的kv数据很多时,克隆操作会存在相同的数据被保存两份甚至 多份的问题造成存储空间的浪费,而且在拷贝过程中需要较长时间与本地数据库进行交 互,并且需要进行大批量的数据读取与写入以处理全部kv数据,在这个过程中可能对程序 性能造成影响。 一种优化的方法的是采用写时复制机制,在克隆操作时不进行真正的拷贝而是在 克隆对象内部保存一份被克隆对象的引用,这样两个对象可以共享同一份数据以避免和数 据库产生交互,待到需要对克隆对象kv数据进行修改时再把数据真正拷贝过来,这种方法 能够一定程度上避免空间浪费,但是当只需要对克隆对象的少量kv数据进行修改时,依然 会将全部数据从被克隆对象拷贝过来,这样还是无法避免上述的空间浪费和影响程序性能 的问题。
技术实现要素:
有鉴于此,本发明实施例的目的在于提出一种对象克隆的方法、系统、计算机设备 及计算机可读存储介质,基于被克隆对象新创建一个父对象,从而避免数据的拷贝,节省存 储空间,并在删除键值对数据时只拷贝部分数据而不是一次全部拷贝,避免了全部拷贝造 成的空间浪费和大量数据拷贝造成的性能影响。 基于上述目的,本发明实施例的一方面提供了一种对象克隆的方法,包括如下步 骤:基于被克隆对象创建父对象,并建立所述父对象与所述被克隆对象的键值对数据的关 联;基于所述父对象创建多个子对象,并建立多个所述子对象与所述父对象的键值对数据 的关联;响应于在所述子对象中增加键值对数据,将待增加的键值对数据保存在所述子对 象;以及响应于在所述子对象中删除键值对数据,基于所述子对象与所述父对象的关联将 待删除的键值对数据及排在所述待删除的键值对数据后面的连续预定数量的键值对数据 从所述父对象拷贝到所述子对象,并删除所述待删除的键值对数据。 在一些实施方式中,所述基于所述子对象与所述父对象的关联将待删除的键值对 数据及排在所述待删除的键值对数据后面的连续预定数量的键值对数据从所述父对象拷 贝到所述子对象,并删除所述待删除的键值对数据包括:判断所述待删除的键值对数据是 否已被拷贝到所述子对象;以及响应于所述待删除的键值对数据已被拷贝到所述子对象, 将所述待删除的键值对数据删除,并继续上次拷贝的顺序将连续预定数量的键值对数据从 所述父对象拷贝到所述子对象。 在一些实施方式中,还包括:判断所有的子对象是否将父对象的键值对数据拷贝 4 CN 111581288 A 说 明 书 2/7 页 或删除完成;以及响应于所有的子对象将父对象的键值对数据拷贝或删除完成,删除所述 父对象。 在一些实施方式中,所述判断所有的子对象是否将父对象的键值对数据拷贝或删 除完成包括:建立完成列表,将已完成拷贝或删除的键值对数据写入所述完成列表,并判断 所述完成列表中的键值对数据与所述父对象的键值对数据是否存在差异。 本发明实施例的另一方面,还提供了一种对象克隆的系统,包括:第一创建模块, 配置用于基于被克隆对象创建父对象,并建立所述父对象与所述被克隆对象的键值对数据 的关联;第二创建模块,配置用于基于所述父对象创建多个子对象,并建立多个所述子对象 与所述父对象的键值对数据的关联;增加模块,配置用于响应于在所述子对象中增加键值 对数据,将待增加的键值对数据保存在所述子对象;以及删除模块,配置用于响应于在所述 子对象中删除键值对数据,基于所述子对象与所述父对象的关联将待删除的键值对数据及 排在所述待删除的键值对数据后面的连续预定数量的键值对数据从所述父对象拷贝到所 述子对象,并删除所述待删除的键值对数据。 在一些实施方式中,所述删除模块还配置用于:判断所述待删除的键值对数据是 否已被拷贝到所述子对象;以及响应于所述待删除的键值对数据已被拷贝到所述子对象, 将所述待删除的键值对数据删除,并继续上次拷贝的顺序将连续预定数量的键值对数据从 所述父对象拷贝到所述子对象。 在一些实施方式中,还包括执行模块,配置用于:判断所有的子对象是否将父对象 的键值对数据拷贝或删除完成;以及响应于所有的子对象将父对象的键值对数据拷贝或删 除完成,删除所述父对象。 在一些实施方式中,所述执行模块还配置用于:建立完成列表,将已完成拷贝或删 除的键值对数据写入所述完成列表,并判断所述完成列表中的键值对数据与所述父对象的 键值对数据是否存在差异。 本发明实施例的又一方面,还提供了一种计算机设备,包括:至少一个处理器;以 及存储器,所述存储器存储有可在所述处理器上运行的计算机指令,所述指令由所述处理 器执行时实现如上方法的步骤。 本发明实施例的再一方面,还提供了一种计算机可读存储介质,计算机可读存储 介质存储有被处理器执行时实现如上方法步骤的计算机程序。 本发明具有以下有益技术效果:基于被克隆对象新创建一个父对象,从而避免数 据的拷贝,节省存储空间,并在删除键值对数据时只拷贝部分数据而不是一次全部拷贝,避 免了全部拷贝造成的空间浪费和大量数据拷贝造成的性能影响。 附图说明 为了更清楚地说明本发明实施例或现有技术中的技术方案,下面将对实施例或现 有技术描述中所需要使用的附图作简单地介绍,显而易见地,下面描述中的附图仅仅是本 发明的一些实施例,对于本领域普通技术人员来讲,在不付出创造性劳动的前提下,还可以 根据这些附图获得其他的实施例。 图1为本发明提供的对象克隆的方法的实施例的示意图; 图2为本发明提供的对象克隆的计算机设备的实施例的硬件结构示意图。 5 CN 111581288 A 说 明 书 3/7 页