当前位置: 首页> 专利交易> 详情页
    待售中

    一种文件处理方法、装置、设备、存储介质、系统及车辆[ZH]

    专利编号: ZL202507020056

    收藏

    拟转化方式: 转让;普通许可;独占许可;排他许可;作价投资;质押融资

    交易价格:面议

    专利类型:发明专利

    法律状态:授权

    技术领域:智能网联汽车

    发布日期:2025-07-02

    发布有效期: 2025-07-02 至 2041-11-29

    专利顾问 — 王老师

    电话咨询

    咨询电话

    13760886304

    专利基本信息
    >
    申请号 CN202111436733.6 公开号 CN114153606A
    申请日 2021-11-29 公开日 2022-03-08
    申请人 中汽创智科技有限公司 专利授权日期 2025-03-14
    发明人 秦民;姜壮;闫国启 专利权期限届满日 2041-11-29
    申请人地址 211100 江苏省南京市江宁区秣陵街道胜利路88号 最新法律状态 授权
    技术领域 智能网联汽车 分类号 G06F9/50
    技术效果 可靠性 有效性 有效(授权、部分无效)
    专利代理机构 广州三环专利商标代理有限公司 44202 代理人 方秀琴;贾允
    专利技术详情
    >
    01

    专利摘要

    本申请涉及数据处理技术领域,尤其涉及一种文件处理方法、装置、设备、存储介质、系统及车辆。方法包括:接收文件处理模块发送的针对目标文件的文件打开请求;根据文件打开请求在内存中打开目标文件,并向文件处理模块发送目标文件的操作句柄;接收文件处理模块根据操作句柄发送的与读写类型相对应的处理对象;根据处理对象对目标文件进行处理,并向文件处理模块发送处理结果。该文件处理方法在持久化存储管理模块进行功能封装,由持久化存储管理模块提供统一的调用函数,实现文件处理功能,避免了文件读写功能的冗余。此外,当文件读写功能进行修改时,只需要对持久化存储管理模块进行修改即可,大大减轻开发工作量,节约资源。
    展开 >
    02

    专利详情

    技术领域 本申请涉及数据处理技术领域,尤其涉及一种文件处理方法、装置、设备、存储介质、系统及车辆。 背景技术 自动驾驶应用的加入使整车功能更加复杂,不同的应用可能由很多供应商提供,其次应用也越来越复杂,对计算资源和性能要求越来越高,需要性能更高的硬件来支持。自适应汽车开放式系统架构(Adaptive Autosar,AP)是一款高度灵活、高性能且支持动态通讯等特性的新软件架构平台。AP架构既能满足应用对高性能计算的需求又具有一定的功能安全等级。AP主要提供高性能的计算和通信机制,并提供灵活的软件配置,主要分为12个功能模块和3个服务模块。 持久化存储管理模块是提供键值存储和文件存储的功能模块。其中,文件存储只是提供存取文件内容的功能,而文件内容以及格式是由应用来决定的。这样存在以下几个问题。 第一,如果各模块使用相同格式的文件,则需要各自实现解析此类文件的功能。例如,每个模块都需要解析自己的配置文件,这种配置文件的格式基本类似,各模块都实现解析功能,会造成功能的冗余。此外,很多模块对写文件也有相应的格式要求,这样也会存在格式转换的功能冗余。 第二,对于某些只读的文件,例如配置文件可能需要读取多次,有的可能只需要读取一次,如果是读取一次存放在内存中,后续直接从内存中读取,那么对于只读一次的模块来说可能会造成内存的浪费。如果是每次都从文件中读取,那么可能会存在效率问题。如果是混合使用,则会提升编码的难度以及逻辑的复杂度。 第三,因为同一功能在不同模块都实现,如果这个功能有变动,则所有模块都需要同步开发,开发工作量巨大。 发明内容 本发明提供一种文件处理方法、装置、设备、存储介质、系统及车辆,以至少解决自适应汽车开放式系统架构中各模块各自实现文件读写功能所造成的功能冗余问题。 为解决上述技术问题,第一方面,本申请实施例公开了一种文件处理方法,方法包括: 接收文件处理模块发送的针对目标文件的文件打开请求; 根据文件打开请求在内存中打开目标文件,并向文件处理模块发送目标文件的操作句柄; 接收文件处理模块根据操作句柄发送的与读写类型相对应的处理对象; 根据处理对象对目标文件进行处理,并向文件处理模块发送处理结果。 进一步的,当读写类型为读类型时,根据处理对象对目标文件进行处理,包括: 根据处理对象对目标文件进行读文件操作的处理。 进一步的,处理对象为主键;根据处理对象对目标文件进行读文件操作的处理,包括: 根据主键解析目标文件的内容; 根据目标文件的内容获得与主键所对应的参数。 进一步的,当读写类型为写类型时,根据处理对象对目标文件进行处理,包括: 根据处理对象对目标文件进行写文件操作的处理。 进一步的,处理对象为结构化数据;根据处理对象对目标文件进行写文件操作的处理,包括: 根据结构化数据确定与结构化数据对应的格式模板;格式模板为根据目标文件的保存格式预先配置在持久化存储管理模块中; 根据格式模板将结构化数据写入目标文件。 进一步的,根据格式模板将结构化数据写入目标文件之前,还包括: 若未找到与结构化数据对应的格式模板,则向文件处理模块发送错误提示信息。 进一步的,根据文件打开请求在内存中打开目标文件,包括: 根据文件打开请求在存储磁盘中确定目标文件; 将目标文件在内存中打开。 进一步的,将目标文件在内存中打开之前,还包括: 在存储磁盘中确定出目标文件的情况下,确定打开目标文件所需要的打开内存大小及内存中所剩余存储空间大小; 若剩余存储空间小于打开内存,则释放已占用内存,以使目标文件能够在内存中打开。 进一步的,释放已占用内存,包括: 基于淘汰算法在内存中确定待解除占用文件; 将待解除占用文件关闭以释放已占用内存。 第二方面,本申请实施例公开了一种文件处理装置,装置包括: 文件打开请求接收单元,用于接收文件处理模块发送的针对目标文件的文件打开请求; 目标文件确定单元,用于根据文件打开请求在内存中打开目标文件,并向文件处理模块发送目标文件的操作句柄; 处理对象接收单元,用于接收文件处理模块根据操作句柄发送的与读写类型相对应的处理对象; 目标文件处理单元,用于根据处理对象对目标文件进行处理,并向文件处理模块发送处理结果。 在一些可选的实施方式中,当读写类型为读类型时,目标文件处理单元包括: 读文件处理子单元,用于根据处理对象对目标文件进行读文件操作的处理。 在一些可选的实施方式中,处理对象为主键;读文件处理子单元包括: 目标文件解析分单元,用于根据主键解析目标文件的内容; 参数获得分单元,用于根据目标文件的内容获得与主键所对应的参数。 在一些可选的实施方式中,当读写类型为写类型时,目标文件处理单元包括: 写文件处理子单元,用于根据处理对象对目标文件进行写文件操作的处理。 在一些可选的实施方式中,处理对象为结构化数据;写文件处理子单元包括: 格式模板确定分单元,用于根据结构化数据确定与结构化数据对应的格式模板;格式模板为根据目标文件的保存格式预先配置在持久化存储管理模块中; 目标文件写入分单元,用于根据格式模板将结构化数据写入目标文件。 在一些可选的实施方式中,写文件处理子单元还包括: 错误提示信息发送分单元,用于若未找到与结构化数据对应的格式模板,则向文件处理模块发送错误提示信息。 在一些可选的实施方式中,目标文件确定单元包括: 目标文件磁盘确定子单元,用于根据文件打开请求在存储磁盘中确定目标文件; 目标文件打开子单元,用于将目标文件在内存中打开。 在一些可选的实施方式中,目标文件确定单元还包括: 存储空间确定子单元,用于在存储磁盘中确定出目标文件的情况下,确定打开目标文件所需要的打开内存大小及内存中所剩余存储空间大小; 内存释放子单元,用于若剩余存储空间小于打开内存,则释放已占用内存,以使目标文件能够在内存中打开。 在一些可选的实施方式中,内存释放子单元包括: 占用文件确定分单元,用于基于淘汰算法在内存中确定待解除占用文件; 占用内存释放分单元,用于将待解除占用文件关闭以释放已占用内存。 第三方面,本申请实施例公开了一种电子设备,设备包括处理器和存储器,存储器中存储有至少一条指令或至少一段程序,至少一条指令或至少一段程序由处理器加载并执行如上所述的文件处理方法。 第四方面,本申请实施例公开了一种计算机可读存储介质,存储介质中存储有至少一条指令或至少一段程序,至少一条指令或至少一段程序由处理器加载并执行以实现如上所述的文件处理方法。 第五方面,本申请实施例公开了一种文件处理系统,系统包括持久化存储管理模块和至少一个文件处理模块; 持久化存储管理模块用于接收文件处理模块发送的针对目标文件的文件打开请求; 持久化存储管理模块还用于根据文件打开请求在内存中打开目标文件,并向文件处理模块发送目标文件的操作句柄; 持久化存储管理模块还用于接收文件处理模块根据操作句柄发送的与读写类型相对应的处理对象; 持久化存储管理模块还用于根据处理对象对目标文件进行处理,并向文件处理模块发送处理结果。 第六方面,本申请实施例公开了一种车辆,车辆包括如上所述的文件处理系统。 本申请实施例提供的文件处理方法、装置、设备、存储介质、系统及车辆,具有如下技术效果: 该文件处理方法在持久化存储管理模块进行功能封装,由持久化存储管理模块提供统一的调用函数,实现文件处理功能。当自适应汽车开放式系统架构中的其他模块需要读写文件时,通过发送请求,由持久化存储管理模块执行文件解析或写文件,从而不需要在每个模块实现文件读写功能,避免了文件读写功能的冗余。此外,当文件读写功能进行修改时,只需要对持久化存储管理模块内调用函数进行修改即可,大大减轻开发工作量,节约资源。 附图说明 为了更清楚地说明本申请实施例或现有技术中的技术方案和优点,下面将对实施例或现有技术描述中所需要使用的附图作简单的介绍,显而易见地,下面描述中的附图仅仅是本申请的一些实施例,对于本领域普通技术人员来讲,在不付出创造性劳动的前提下,还可以根据这些附图获得其它附图。 图1是本申请实施例提供的一种应用环境的示意图; 图2是本申请实施例提供的一种文件处理方法的流程示意图; 图3是本申请实施例提供的一种文件读取方法的流程示意图; 图4是本申请实施例提供的一种写文件的方法流程示意图; 图5是本申请实施例提供的一种文件处理装置的结构示意图; 图6是本申请实施例提供的一种文件处理装置的结构示意图。 具体实施方式 下面将结合本申请实施例中的附图,对本申请实施例中的技术方案进行清楚、完整地描述,显然,所描述的实施例仅仅是本申请一部分实施例,而不是全部的实施例。基于本申请中的实施例,本领域普通技术人员在没有做出创造性劳动的前提下所获得的所有其他实施例,都属于本申请保护的范围。 需要说明的是,本申请的说明书和权利要求书及上述附图中的术语 " 第一 " 、 " 第二 " 等是用于区别类似的对象,而不必用于描述特定的顺序或先后次序。应该理解这样使用的数据在适当情况下可以互换,以便这里描述的本申请的实施例能够以除了在这里图示或描述的那些以外的顺序实施。此外,术语 " 包括 " 和 " 具有 " 以及他们的任何变形,意图在于覆盖不排他的包含,例如,包含了一系列步骤或单元的过程、方法、系统、产品或服务器不必限于清楚地列出的那些步骤或单元,而是可包括没有清楚地列出的或对于这些过程、方法、产品或设备固有的其它步骤或单元。 目前,自适应汽车开放式系统架构中的持久化存储管理模块仅提供存取文件内容的功能,而不具备读取文件和写文件的功能。读取文件和写文件的功能由其他各个功能模块在各自模块中实现。这就导致了读取文件和写文件的功能冗余。此外,基于目前汽车开放式系统架构所实现配置文件读取功能,由于有的配置文件读取次数较少,有的配置文件读取次数较为频繁,如果将配置文件都存放在内存中,对于读取次数较少的配置文件来说,就造成了内存的浪费。然而,如果将配置文件不存放在内存中,对于读取较为频繁的配置文件来说,每次都要解析配置文件,造成效率低下。 有鉴于此,本申请实施例提供了一种文件处理方法,实现自适应汽车开放式系统架构的各模块中对于文件解析、格式转换等冗余功能的优化,同时对读取配置文件时的效率与内存使用限制之间做出了平衡优化。 请参阅图1,图1是本申请实施例提供的一种应用环境的示意图,自适应汽车开放式系统架构包括一个或多个文件处理模块和一个持久化存储管理模块。文件处理模块为用于文件处理的模块,持久化存储管理模块为用于文件存储的模块。持久化存储管理模块还为文件处理模块提供文件存储、文件读取、写文件等功能。持久化存储管理模块封装有统一调用函数,文件处理模块通过统一调用函数来获取文件中的参数,或向文件中写入固定格式的文件内容。 以下介绍本申请一种文件处理方法的具体实施例,图2是本申请实施例提供的一种文件处理方法的流程示意图,本说明书提供了如实施例或流程图的方法操作步骤,但基于常规或者无创造性的劳动可以包括更多或者更少的操作步骤。实施例中列举的步骤顺序仅仅为众多步骤执行顺序中的一种方式,不代表唯一的执行顺序。在实际中的系统或服务器产品执行时,可以按照实施例或者附图所示的方法顺序执行或者并行执行(例如并行处理器或者多线程处理的环境)。具体的如图2所示,该文件处理方法应用于持久化存储管理模块,该方法可以包括: S201:接收文件处理模块发送的针对目标文件的文件打开请求。 本申请实施例中,当文件处理模块需要进行读文件或写文件时,文件处理模块先向持久化存储管理模块发送打开文件的请求,以使持久化存储管理模块将要读取的文件或要写入的文件在内存中打开。具体的,文件处理模块发送的文件打开请求中携带有函数入参,文件处理模块通过持久化存储管理模块的应用程序接口(Application ProgrammingInterface,API)调用持久化存储管理模块中的统一调用函数打开文件存储。可选的,函数入参包括文件名和文件类型。 S203:根据文件打开请求在内存中打开目标文件,并向文件处理模块发送目标文件的操作句柄。 本申请实施例中,持久化存储管理模块接收到文件打开请求后,根据文件请求中所携带的文件名和文件类型通过统一调用函数在内存中查找目标文件。如果目标文件已经在内存中打开,则持久化存储管理模块直接向文件处理模块发送该目标文件的操纵句柄。如果并没有在内存中打开,则持久化存储管理模块根据文件打开请求,即根据文件名和文件类型在存储磁盘中确定出该目标文件,然后将该目标文件在内存中打开。 在一个可选的实施方式中,持久化存储管理模块将目标文件在内存中打开之前还包括对内存进行优化的过程。持久化存储管理模块在存储磁盘中确定出目标文件的情况下,确定打开目标文件所需要的打开内存大小,以及内存中所剩余存储空间大小。并根据打开内存和剩余存储空间大小判断剩余存储空间是否足够目标文件在内存中打开。如果剩余存储空间小于打开内存,则释放已占用内存,以使目标文件能够在内存中打开。具体的,释放已占用内存可以包括:持久化存储管理模块基于淘汰算法在内存中确定待解除占用文件,然后将待解除占用文件关闭以释放已占用内存。可选的,淘汰算法可以是LRU(Leastrecently used)算法,即最近最少使用算法。即根据数据的历史访问记录来进行确定待解除占用文件。可选的,淘汰算法还可以是FIFO(First Input First Output)算法,即先进先出算法。可选的,淘汰算法还可以是LFU(Least Frequently Used)算法,即最少使用算法。可以理解的是,在内存足够的前提下,所有的文件都可以存放在内存中。该实施方式中,通过对内存的优化,使读取较为频繁的配置文件一直存放在内存中,一方面避免了内存资源的浪费,另一方面提高了文件读取效率。 S205:接收文件处理模块根据操作句柄发送的与读写类型相对应的处理对象。 本申请实施例中,文件处理模块接收到持久化存储管理模块发送的目标文件的操作句柄后,文件处理模块使用该操作句柄向持久化存储管理模块发送处理对象,以使持久化存储管理模块对目标文件进行处理。处理对象与文件处理模块所要进行的处理进程有关,即与读写类型相关。例如,读写类型为读类型,表明文件处理模块需要读取目标文件,则向持久化存储管理模块发送的处理对象为主键或键值对请求。读写类型为写类型,表明文件处理模块需要写入目标文件,则向持久化存储管理模块发送的处理对象为结构化数据。 S207:根据处理对象对目标文件进行处理,并向文件处理模块发送处理结果。 本申请实施例中,持久化存储管理模块接收到处理对象后,根据处理对象对目标文件进行读文件操作或写文件操作的处理,具体的为文件解析或文件写入操作,并在执行文件解析或文件写入操作后向文件处理模块发送处理的结果。 本申请实施例中,如果文件处理模块需要读取目标文件,持久化存储管理模块根据处理对象对目标文件进行读文件操作的处理。即文件处理模块向持久化存储管理模块发送的处理对象为主键或键值对请求,持久化存储管理模块根据处理对象对目标文件进行处理的过程可以是:持久化存储管理模块根据主键解析目标文件的内容,持久化存储管理模块根据目标文件的内容向文件处理模块发送与主键所对应的参数。 本申请实施例中,如果文件处理模块需要写入目标文件,即文件处理模块向持久化存储管理模块发送的处理对象为结构化数据。持久化存储管理模块根据处理对象对目标文件进行处理的过程可以是:持久化存储管理模块根据结构化数据确定与结构化数据对应的格式模板,格式模板为根据目标文件的保存格式预先配置在持久化存储管理模块中。然后持久化存储管理模块根据格式模板将结构化数据写入目标文件。持久化存储管理模块根据结构化数据确定与结构化数据对应的格式模板时,如果没有找到与结构化数据对应的格式模板,则向文件处理模块发送错误提示信息。 作为一种可选的实施方式,图3是本申请实施例提供的一种文件读取方法的流程示意图,如图3所示,读文件的过程可以包括: S301:文件处理模块发送打开文件请求,打开文件请求中携带有函数入参,函数入参包括文件名和文件类型。 本申请实施例中,当文件处理模块需要进行读文件时,文件处理模块先向持久化存储管理模块发送打开文件的请求,以使持久化存储管理模块将要读取的文件或要写入的文件在内存中打开。 S303:持久化存储管理模块根据函数入参,通过统一调用函数在内存中查找目标文件。 本申请实施例中,统一调用函数是一个函数集合,该函数集合中包括多个用于实现不同功能的函数。持久化存储管理模块接收到函数入参后,通过统一调用函数中的查找函数在内存中查找目标文件。 S305:持久化存储管理模块确定目标文件是否已经在内存中打开。 本申请实施例中,持久化存储管理模块通过查找判断目标文件是否已经在内存中打开。如果目标文件已经在内存中打开则转至步骤S307,如果目标文件并未在内存中打开则转至步骤S309。 S307:持久化存储管理模块向文件处理模块发送目标文件的操作句柄。 本申请实施例中,如果目标文件已经在内存中打开,则持久化存储管理模块直接向文件处理模块发送该目标文件的操纵句柄。文件处理模块通过使用持久化存储操作模块发送的操作句柄可以实现对目标文件进行处理。 S309:持久化存储管理模块查找目标文件是否存在。 本申请实施例中,如果目标文件并未在内存中打开,则持久化存储管理模块需要确定目标文件是否存在。具体的,持久化存储管理模块通过查找函数在存储磁盘中确定是否存在该目标文件,如果存在则转至步骤S313,如果不存在则转至步骤S311。 S311:持久化存储管理模块向文件处理模块发送错误码。 本申请实施例中,持久化存储管理模块通过查找函数并没有在存储磁盘中找到该目标文件,则向文件处理模块发送错误码,文件处理模块接收到错误码可进行确认所输入的函数入参是否有误。 S313:持久化存储管理模块确定剩余存储空间是否足够打开目标文件。 本申请实施例中,持久化存储管理模块通过查找函数在存储磁盘中找到该目标文件后,首先需要确定剩余存储空间是否足够打开该目标文件。具体的,持久化存储管理模块确定出目标文件的打开内存大小以及内存中剩余存储空间大小,通过比对确定剩余存储空间是否足够打开该目标文件。如果剩余存储空间足够打开该目标文件,则转至步骤S317。如果剩余存储空间不够打开该目标文件,则转至步骤S315。 S315:持久化存储管理模块使用LRU算法释放最早最少使用的文件内存,以使剩余存储空间足够打开目标文件。 本申请实施例中,如果剩余存储空间不够打开目标文件,持久化存储管理模块使用LRU算法释放最早最少使用的文件内存,以使剩余存储空间足够打开目标文件。该步骤中,所使用的算法也可以是FIFO算法、LFU算法等淘汰算法。 S317:持久化存储管理模块解析目标文件内容并加载到内存中。 本申请实施例中,在剩余存储空间足够打开目标文件的情况下,对目标文件进行解析,并将目标文件的内容加载到内存中,以便后续文件处理模块获取文件内容中的键值或键值对。 S319:持久化存储管理模块向文件处理模块发送目标文件的操作句柄。 本申请实施例中,当目标文件在内存中被打开后,持久化存储管理模块向文件处理模块发送该目标文件的操作句柄,以便文件处理模块使用操作句柄来获取对应的值。 S321:文件处理模块发送主键或键值对请求到持久化存储管理模块。 本申请实施例中,文件处理模块获取到目标文件的操作句柄后,使用操作句柄向持久化存储管理模块发送主键或键值对请求,其中,主键用于获取目标文件中与主键所对应的值,键值对请求用于获取目标文件中的所有键值对。 S323:持久化存储管理模块向文件处理模块发送值或键值对。 本申请实施例中,持久化存储管理模块接收到文件处理模块发送的主键或键值对请求后,通过统一调用函数中获取函数获取目标文件中与主键对应的值或全部键值对。作为一种示例,目标文件里的内容如下所示: { "id":1, "message":"hello" } 持久化存储管理模块中实现了一个通用的函数(get),就可以通过get( " id " )得到配置文件中的值1,通过get( " message " )得到配置文件中的值hello。然后持久化存储管理模块将值 " 1 " ,或值 " hello " 发送给文件处理模块。 本申请实施例所述的文件读取方法,由持久化存储管理模块实现文件的读取与解析,文件处理模块通过主键或键值对请求即可获取到相应的参数,无需在每个文件处理模块实现文件解析功能,从而避免文件解析功能的冗余。此外,持久化存储管理模块将使用频率较高的文件放在内存中,一方面方便文件处理模块使用,提高效率,另一方面避免使用频率不高的文件占用内存,造成内存浪费。 作为另一种可选的实施方式,图4是本申请实施例提供的一种写文件的方法流程示意图,如图4所示,写文件的过程可以包括: S401:文件处理模块发送打开文件请求,打开文件请求中携带有函数入参,函数入参包括文件名和文件类型。 本申请实施例中,当文件处理模块需要进行写文件时,文件处理模块先向持久化存储管理模块发送打开文件的请求,以使持久化存储管理模块将要读取的文件或要写入的文件在内存中打开。 S403:持久化存储管理模块根据函数入参和统一调用函数将目标文件在内存中打开。 本申请实施例中,在写文件时,持久化存储管理模块需要先将目标文件在内存中打开。与读文件流程相似的是,持久化存储管理模块首先确定目标文件是否已经在内存中打开,当目标文件已经在内存中打开时,则持久化存储管理模块可以直接向文件发送该目标文件的操作句柄。当目标文件没有在内存中打开时,则持久化存储管理模块根据接收到的函数入参,通过统一调用函数中的查找函数在存储磁盘中查找该目标文件,然后将该目标文件在内存中打开。如果持久化存储管理模块并未在存储磁盘中查找到该目标文件,则向文件处理模块发送错误码,文件处理模块接收到错误码可进行确认所输入的函数入参是否有误。 本申请实施例中,与读文件流程所不同的是,在写文件时,持久化存储管理模块并不需要对目标文件进行解析,只用将目标文件在内存中打开即可。 S405:持久化存储管理模块向文件处理模块发送目标文件的操作句柄。 本申请实施例中,当持久化存储管理模块将目标文件在内存中打开后,持久化存储管理模块将该目标文件的操作句柄发送给需要写文件为文件处理模块。 S407:文件处理模块向持久化存储管理模块发送写文件的结构化数据以及存储的文件格式。 本申请实施例中,文件处理模块获取到目标文件的操作句柄后,使用该操作句柄向持久化存储管理模块发送结构化数据,并同时把需要写入的文件格式发送给持久化存储管理模块。 S409:持久化存储管理模块根据文件格式查找配置的模板。 本申请实施例中,持久化存储管理模块中预先配置有不同格式的文件写入模板,例如,json、xml等格式的模板。持久化存储管理模块根据文件格式使用统一调用函数查找预先配置的模板。 S411:持久化存储管理模块确定模板是否存在。 本申请实施例中,持久化存储管理模块通过查找预先配置的模板,确定该种格式的模板是否存在,如果存在则转至步骤S415,如果不存在则转至步骤S413。 S413:持久化存储管理模块向文件处理模块发送错误码。 本申请实施例中,如果该结构化数据所需要保存的文件格式并没有在持久化存储管理模块中预先配置相应的模板,即持久化存储管理模块未找到相应文件格式的模板,则向文件处理模块发送错误提示信息。 S415:持久化存储管理模块根据结构化数据和配置的模板组合成固定格式的文件。 本申请实施例中,如果持久化存储管理模块确定出结构化数据所需要保存的文件格式所对应的模板,则持久化存储管理模块根据结构化数据和配置的模板组合成固定格式的文件进行存储。 作为一种示例,文件处理模块向持久化存储管理模块发送的结构数据如下: 该示例为一个结构体定义变量的内存指针。该实例中,结构化数据就是&book。文件处理模块需要将该结构化数据以json的文件格式写入目标文件,则持久化存储管理模块首先确定预先配置的模板,持久化存储管理模块确定预先配置的模板如下所示: title:Book_Title:char author:Book_Author:char subject:Book_Subject:char book_id:Book_ID:int 其中,列分隔符是;,第一列是结构体中的字段名字,第二列是需要输出在文件中的名字,第三列是字段的类型。 该示例中,文件处理模块向持久化存储管理模块所发送的结构化数据&book包括如下内容: strcpy(book.title,"C语言") strcpy(book.author,"zhangsan" strcpy(book.subject,"编程语言") book.book_id=12234 该示例中,持久化存储管理模块通过配置的模板生成的文件内容如下: { "Book_Title":"C语言", "Book_Author":"zhangsan", "Book_Subject":"编程语言", "Book_ID":12234 } 由此,持久化存储管理模块完成文件的写入。 S417:持久化存储管理模块向文件处理模块发送存储成功的提示信息。 本申请实施例中,在文件存储成功的情况下,即持久化存储管理模块将文件写入成功的情况下向文件处理模块发送存储成功的提示信息。 本申请实施例所述的写文件方法,通过在持久化存储管理模块中预先配置多种固定格式的模板,由持久化存储管理模块实现文件的写入功能,无需在每个文件处理模块实现文件写入功能,从而避免文件写入功能的冗余。 本申请实施例还提供了一种文件处理装置,该装置应用于持久化存储管理模块,持久化存储管理模块为自适应汽车开放式系统架构中用于文件存储的模块。图5是本申请实施例提供的一种文件处理装置的结构示意图,如图5所示,该装置包括: 文件打开请求接收单元501,用于接收文件处理模块发送的文件打开请求。文件处理模块为自适应汽车开放式系统架构中用于文件处理的模块,自适应汽车开放式系统架构中包括至少一个文件处理模块。 目标文件确定单元503,用于根据文件打开请求在内存中确定目标文件,并向文件处理模块发送目标文件的操作句柄。 处理对象接收单元505,用于接收文件处理模块根据操作句柄发送的处理对象。 目标文件处理单元507,用于根据处理对象对目标文件进行处理。 在一些可选的实施方式中,当读写类型为读类型时,目标文件处理单元包括: 读文件处理子单元,用于根据处理对象对目标文件进行读文件操作的处理。 在一些可选的实施方式中,处理对象为主键;读文件处理子单元包括: 目标文件解析分单元,用于根据主键解析目标文件的内容; 参数获得分单元,用于根据目标文件的内容获得与主键所对应的参数。 在一些可选的实施方式中,当读写类型为写类型时,目标文件处理单元包括: 写文件处理子单元,用于根据处理对象对目标文件进行写文件操作的处理。 在一些可选的实施方式中,处理对象为结构化数据;写文件处理子单元包括: 格式模板确定分单元,用于根据结构化数据确定与结构化数据对应的格式模板;格式模板为根据目标文件的保存格式预先配置在持久化存储管理模块中; 目标文件写入分单元,用于根据格式模板将结构化数据写入目标文件。 在一些可选的实施方式中,写文件处理子单元还包括: 错误提示信息发送分单元,用于若未找到与结构化数据对应的格式模板,则向文件处理模块发送错误提示信息。 在一些可选的实施方式中,目标文件确定单元包括: 目标文件磁盘确定子单元,用于根据文件打开请求在存储磁盘中确定目标文件; 目标文件打开子单元,用于将目标文件在内存中打开。 在一些可选的实施方式中,目标文件确定单元还包括: 存储空间确定子单元,用于在存储磁盘中确定出目标文件的情况下,确定打开目标文件所需要的打开内存大小及内存中所剩余存储空间大小; 内存释放子单元,用于若剩余存储空间小于打开内存,则释放已占用内存,以使目标文件能够在内存中打开。 在一些可选的实施方式中,内存释放子单元包括: 占用文件确定分单元,用于基于淘汰算法在内存中确定待解除占用文件; 占用内存释放分单元,用于将待解除占用文件关闭以释放已占用内存。 本申请实施例中的装置与方法实施例基于同样地申请构思。 本申请实施例还提供了一种电子设备,设备包括处理器和存储器,存储器中存储有至少一条指令或至少一段程序,至少一条指令或至少一段程序由处理器加载并执行如上所述的文件处理方法。 本申请实施例中,存储器可用于存储软件程序以及模块,处理器通过运行存储在存储器的软件程序以及模块,从而执行各种功能应用以及数据处理。存储器可主要包括存储程序区和存储数据区,其中,存储程序区可存储操作系统、功能所需的应用程序等;存储数据区可存储根据所述终端的使用所创建的数据等。此外,存储器可以包括高速随机存取存储器,还可以包括非易失性存储器,例如至少一个磁盘存储器件、闪存器件、或其他易失性固态存储器件。相应地,存储器还可以包括存储器控制器,以提供处理器对存储器的访问。作为一个示例,该设备为车载电脑,如电子控制单元(ECU,Electronic Control Unit)。 本申请实施例提供了一种计算机可读存储介质,存储介质中存储有至少一条指令或至少一段程序,至少一条指令或至少一段程序由处理器加载并执行以实现如上所述的文件处理方法。 本申请实施例中,上述存储介质可以位于计算机网络的多个网络客户端中的至少一个网络客户端。可选地,在本实施例中,上述存储介质可以包括但不限于:U盘、只读存储器(ROM,Read-Only Memory)、随机存取存储器(RAM,Random Access Memory)、移动硬盘、磁碟或者光盘等各种可以存储程序代码的介质。 本申请实施例提供了一种文件处理系统,图6是本申请实施例提供的一种文件处理装置的结构示意图,如图6所示,系统包括持久化存储管理模块和至少一个文件处理模块。 持久化存储管理模块用于接收文件处理模块发送的针对目标文件的文件打开请求; 持久化存储管理模块还用于根据文件打开请求在内存中打开目标文件,并向文件处理模块发送目标文件的操作句柄; 持久化存储管理模块还用于接收文件处理模块根据操作句柄发送的与读写类型相对应的处理对象; 持久化存储管理模块还用于根据处理对象对目标文件进行处理,并向文件处理模块发送处理结果。 本申请实施例中,文件处理系统基于自适应汽车开放式系统架构设置。持久化存储管理模块为自适应汽车开放式系统架构中用于文件存储的模块。文件处理模块为自适应汽车开放式系统架构中用于文件处理的模块。 本申请实施例提供了一种车辆,车辆包括如上所述的文件处理系统。 本申请实施例提供的文件处理方法、装置、设备、存储介质、系统及车辆,在持久化存储管理模块进行功能封装,由持久化存储管理模块提供统一的调用函数,实现文件解析和写文件功能。当自适应汽车开放式系统架构中的其他模块需要读写文件时,通过发送请求,由持久化存储管理模块执行文件解析或写文件,从而不需要在每个模块实现文件读写功能,避免了文件读写功能的冗余。当文件读写功能需要进行修改时,只需要对持久化存储管理模块进行修改即可,大大减轻开发工作量,节约资源。此外,持久化存储管理模块将使用频率较高的文件放在内存中,一方面方便文件处理模块使用,提高效率,另一方面避免使用频率不高的文件占用内存,造成内存浪费。 需要说明的是:上述本申请实施例先后顺序仅仅为了描述,不代表实施例的优劣。且上述对本说明书特定实施例进行了描述。其它实施例在所附权利要求书的范围内。在一些情况下,在权利要求书中记载的动作或步骤可以按照不同于实施例中的顺序来执行并且仍然可以实现期望的结果。另外,在附图中描绘的过程不一定要求示出的特定顺序或者连续顺序才能实现期望的结果。在某些实施方式中,多任务处理和并行处理也是可以的或者可能是有利的。 本说明书中的各个实施例均采用递进的方式描述,各个实施例之间相同相似的部分互相参见即可,每个实施例重点说明的都是与其他实施例的不同之处。尤其,对于设备实施例而言,由于其基本相似于方法实施例,所以描述的比较简单,相关之处参见方法实施例的部分说明即可。 本领域普通技术人员可以理解实现上述实施例的全部或部分步骤可以通过硬件来完成,也可以通过程序来指令相关的硬件完成,所述的程序可以存储于一种计算机可读存储介质中,上述提到的存储介质可以是只读存储器,磁盘或光盘等。 以上所述仅为本申请的较佳实施例,并不用以限制本申请,凡在本申请的精神和原则之内,所作的任何修改、等同替换、改进等,均应包含在本申请的保护范围之内。 一种文件处理方法、装置、设备、存储介质、系统及车辆
    展开 >
    说明书附图
    >
    交易服务流程
    >

    挑选中意的板块

    ----

    客服确认选择专利的交易信息和价格并支付相应款项

    办理转让材料

    ----

    协助双方准备相应的材料

    签订协议

    ----

    协助卖家签订协议

    办理备案手续

    ----

    买卖双方达成一致后

    交易完成

    ----

    交易完成可投入使用

    过户资料 & 安全保障 & 承诺信息
    >

    过户资料

    买卖双方需提供的资料
    公司 个人
    买家 企业营业执照
    企业组织机构代码证
    身份证
    卖家 企业营业执照
    专利证书原件
    身份证
    专利证书原件
    网站提供 过户后您将获得
    专利代理委托书
    专利权转让协议
    办理文件副本请求书
    发明人变更声明
    专利证书
    手续合格通知书
    专利登记薄副本

    安全保障

    承诺信息

    我方拟转让所持标的项目,通过中国汽车知识产权应用促进中心公开披露项目信息和组织交易活动,依照公开、公平、公正和诚信的原则作如下承诺:

    1、本次项目交易是我方真实意思表示,项目标的权属清晰,除已披露的事项外,我方对该项目拥有完全的处置权且不存在法律法规禁止或限制交易的情形;
    2、本项目标的中所涉及的处置行为已履行了相应程序,经过有效的内部决策,并获得相应批准;交易标的涉及共有或交易标的上设置有他项权利,已获得相关权利 人同意的有效文件。
    3、我方所提交的信息发布申请及相关材料真实、完整、准确、合法、有效,不存在虚假记载、误导性陈述或重大遗漏;我方同意平台按上述材料内容发布披露信息, 并对披露内容和上述的真实性、完整性、准确性、合法性、有效性承担法律责任;
    4、我方在交易过程中自愿遵守有关法律法规和平台相关交易规则及规定,恪守信息发布公告约定,按照相关要求履行我方义务;
    5、我方已认真考虑本次项目交易行为可能导致的企业经营、行业、市场、政策以及其他不可预计的各项风险因素,愿意自行承担可能存在的一切交易风险;
    6、我方在平台所组织交易期间将不通过其他渠道对标的项目进行交易;
    7、我方将按照平台收费办法及相关交易文件的约定及时、足额支付相关费用,不因与受让方争议或合同解除、终止等原因拒绝、拖延、减少交纳或主张退还相关费用。