CN114598567A - 通信方法、设备及存储介质 - Google Patents
通信方法、设备及存储介质 Download PDFInfo
- Publication number
- CN114598567A CN114598567A CN202210208015.1A CN202210208015A CN114598567A CN 114598567 A CN114598567 A CN 114598567A CN 202210208015 A CN202210208015 A CN 202210208015A CN 114598567 A CN114598567 A CN 114598567A
- Authority
- CN
- China
- Prior art keywords
- ecu
- data
- communication
- response message
- target data
- 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.)
- Pending
Links
Images
Classifications
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L12/00—Data switching networks
- H04L12/28—Data switching networks characterised by path configuration, e.g. LAN [Local Area Networks] or WAN [Wide Area Networks]
- H04L12/40—Bus networks
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L67/00—Network arrangements or protocols for supporting network services or applications
- H04L67/01—Protocols
- H04L67/12—Protocols specially adapted for proprietary or special-purpose networking environments, e.g. medical networks, sensor networks, networks in vehicles or remote metering networks
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L12/00—Data switching networks
- H04L12/28—Data switching networks characterised by path configuration, e.g. LAN [Local Area Networks] or WAN [Wide Area Networks]
- H04L12/40—Bus networks
- H04L2012/40267—Bus for use in transportation systems
- H04L2012/40273—Bus for use in transportation systems the transportation system being a vehicle
Landscapes
- Engineering & Computer Science (AREA)
- Computer Networks & Wireless Communication (AREA)
- Signal Processing (AREA)
- Small-Scale Networks (AREA)
- Health & Medical Sciences (AREA)
- Computing Systems (AREA)
- General Health & Medical Sciences (AREA)
- Medical Informatics (AREA)
Abstract
本申请公开了一种通信方法、设备及存储介质,属于通信技术领域。所述方法包括第一ECU先向第二ECU发送数据订阅请求,数据订阅请求携带向第二ECU请求的目标数据的通信策略,然后接收第二ECU根据通信策略发送的携带目标数据的通信响应报文,从通信响应报文中获取目标数据。如此,发送ECU可以在需要时向接收ECU发送数据订阅请求,接收ECU根据发送ECU主动发送的数据订阅请求携带的通信策略,向发送ECU发送实际所需的目标数据,从而避免接收ECU以出厂固化的通信策略向发送ECU发送的目标数据可能不是发送ECU需要的问题,减少了车用总线传输的无效通信响应报文,降低了车用总线的负载率和延迟率。
Description
技术领域
本申请涉及通信技术领域,特别涉及一种通信方法、设备及存储介质。
背景技术
随着车辆智能化的程度越来越高,车辆内部各系统之间的通信越加重要。
现有技术中,车辆的多ECU(电子控制单元,Electronic Control Unit)之间的通信策略通常在车辆出厂时被固化在不可进行写操作的存储区中,使得各ECU之间通过车用总线以固定的通信策略传输通信报文,以实现多ECU通信。比如,空调ECU以固定时间间隔不断地向车用总线发送固定的通信报文,该通信报文携带空调模式、空调风速等空调状态信息的目标数据,然后仪表ECU通过车用总线接收空调ECU发送的通信报文,根据通信报文中的目标数据显示空调的状态信息。
但是在多ECU之间的通信策略固化,发送ECU以固定的通信策略向接收ECU发送通信报文的情况下,可能存在接收ECU在某段时间或场景是不需要获取发送ECU发送的通信报文的问题,导致车用总线传输了大量的无效通信报文,车用总线负载率较高,另外由于车用总线的带宽有限,因此大量的通信报文还会造成传输拥堵,延迟率较高。
发明内容
本申请提供了一种通信方法、系统、车辆及存储介质,可以减少车用总线上传输的无效的通信报文,降低车用总线的负载率和延迟率。所述技术方案如下:
第一方面,提供了一种通信方法,所述方法应用于第一ECU,所述方法包括:
向第二ECU发送数据订阅请求,所述数据订阅请求携带向所述第二ECU请求的目标数据的通信策略;
接收所述第二ECU根据所述通信策略发送的通信响应报文,所述通信响应报文携带所述目标数据;
从所述通信响应报文中获取所述目标数据。
作为一个示例,所述接收所述第二ECU根据所述通信策略发送的通信响应报文之前,所述方法还包括:
接收所述第二ECU发送的订阅成功响应报文,所述订阅成功响应报文携带数据发送格式,所述订阅成功响应报文用于指示所述目标数据订阅成功,所述数据发送格式指示所述第二ECU向所述第一ECU发送所述目标数据的格式,所述数据发送格式包括所述目标数据的数据标识在所述通信响应报文中的位置、所述目标数据在所述通信响应报文中的位置、占用位数和进制类型中的一种或多种;
所述从所述通信响应报文中获取所述目标数据,包括:
根据所述数据发送格式,从所述通信响应报文中解析出所述目标数据。
作为一个示例,所述数据订阅请求包括用于指示数据订阅的标识。
第二方面,提供了另一种通信方法,所述方法应用于第二ECU,所述方法包括:
接收第一ECU发送的数据订阅请求,所述数据订阅请求携带所述第一ECU请求的目标数据的通信策略;
根据所述通信策略向所述第一ECU发送通信响应报文,所述通信响应报文携带所述目标数据。
作为一个示例,通信策略包括所述目标数据的数据标识;
所述根据所述通信策略向所述第一ECU发送通信响应报文之前,所述方法还包括:
根据所述目标数据的数据标识,确定所述第二ECU支持发送的数据中是否存在所述目标数据;
若确定所述第二ECU支持发送的数据中存在所述目标数据,则向所述第一ECU发送订阅成功响应报文,所述订阅成功响应报文用于指示所述目标数据订阅成功;
若确定所述第二ECU支持发送的数据中不存在所述目标数据,则向所述第一ECU发送订阅失败响应报文,所述订阅失败响应报文用于指示所述目标数据订阅失败。
作为一个示例,所述通信策略还包括请求的所述目标数据的发送次数、发送时间间隔、开始发送条件和结束发送条件中的一种或多种。
作为一个示例,所述根据所述通信策略向所述第一ECU发送通信响应报文,包括:
根据所述通信策略和预设的数据发送格式向所述第一ECU发送所述通信响应报文,所述数据发送格式包括请求的所述目标数据的数据标识在所述通信响应报文中的位置、所述目标数据在所述通信响应报文中的位置、占用位数和进制类型中的一种或多种。
第三方面,提供了再一种通信方法,所述方法应用于终端设备,所述终端设备至少包括第一ECU和第二ECU,所述第一ECU和所述第二ECU通信连接,所述方法包括:
所述第一ECU向所述第二ECU发送数据订阅请求,所述数据订阅请求携带所述第一ECU向所述第二ECU请求的目标数据的通信策略;
所述第二ECU接收所述第一ECU发送的所述数据订阅请求;
所述第二ECU根据所述通信策略向所述第一ECU发送通信响应报文,所述通信响应报文携带所述目标数据;
所述第一ECU接收所述第二ECU发送的所述通信响应报文,从所述通信响应报文中获取所述目标数据。
第四方面,提供了一种计算机设备,所述计算机设备至少包括第一ECU和第二ECU,所述第一ECU和所述第二ECU分别包括存储器、处理器以及存储在所述存储器中并可在所述处理器上运行的计算机程序,所述第一ECU对应的计算机程序被对应的处理器执行时实现上述的第一方面提供的通信方法的步骤,所述第二ECU对应的计算机程序被对应的处理器执行时实现上述的第二方面提供的通信方法的步骤。
第五方面,提供了一种计算机可读存储介质,所述计算机可读存储介质存储有计算机程序,所述计算机程序被处理器执行时实现上述的第一方面、第二方面或第三方面提供的通信方法的步骤。
可以理解的是,上述第二方面、第三方面、第四方面、第五方面的有益效果可以参见上述第一方面中的相关描述,在此不再赘述。
本申请实施例提供的技术方案带来的有益效果是:
本申请实施例中,第一ECU先向第二ECU发送数据订阅请求,数据订阅请求携带向第二ECU请求的目标数据的通信策略,然后接收第二ECU根据通信策略发送的携带目标数据的通信响应报文,从通信响应报文中获取目标数据。如此,一个ECU(发送ECU)可以在需要时向另一个ECU(接收ECU)发送数据订阅请求,从而接收ECU根据发送ECU主动发送的数据订阅请求携带的通信策略,向发送ECU发送携带实际所需的目标数据的通信响应报文,可以避免接收ECU以出厂固化的通信策略向发送ECU发送的目标数据可能不是发送ECU需要的问题,减少了车用总线传输的无效通信响应报文,降低了车用总线的负载率和延迟率。
附图说明
为了更清楚地说明本申请实施例中的技术方案,下面将对实施例描述中所需要使用的附图作简单地介绍,显而易见地,下面描述中的附图仅仅是本申请的一些实施例,对于本领域普通技术人员来讲,在不付出创造性劳动的前提下,还可以根据这些附图获得其他的附图。
图1是本申请实施例提供的一种多ECU系统的结构框图;
图2是本申请实施例提供的一种通信方法的流程图;
图3是本申请实施例提供的另一种通信方法的流程图;
图4是本申请实施例提供的再一种通信方法的流程图;
图5为本申请实施例提供的一种ECU的结构示意图。
具体实施方式
为使本申请的目的、技术方案和优点更加清楚,下面将结合附图对本申请实施方式作进一步地详细描述。
应当理解的是,本申请提及的“多个”是指两个或两个以上。在本申请的描述中,除非另有说明,“/”表示或的意思,比如,A/B可以表示A或B;本文中的“和/或”仅仅是一种描述关联对象的关联关系,表示可以存在三种关系,比如,A和/或B,可以表示:单独存在A,同时存在A和B,单独存在B这三种情况。另外,为了便于清楚描述本申请的技术方案,采用了“第一”、“第二”等字样对功能和作用基本相同的相同项或相似项进行区分。本领域技术人员可以理解“第一”、“第二”等字样并不对数量和执行次序进行限定,并且“第一”、“第二”等字样也并不限定一定不同。
在对本申请实施例进行详细地解释说明之前,先对本申请实施例的应用场景予以说明。
随着技术的发展,车辆的智能化成为车辆技术发展的重要方向之一。车辆的智能化包括自动化或网络化等,可以使车辆具有数据处理的能力,从而实现智能驾驶或车联网等。其中,车辆内部各系统之间的通信是实现车辆智能化的基础。通常,车辆内部各系统由独立的电子控制单元(Electronic Control Unit,ECU)进行控制,因此车辆内部的各系统又称为多ECU系统,各系统之间的通信又称为多ECU通信(各ECU之间的通信)。
作为一个示例,ECU用于对对应的系统进行控制,发送与对应系统相关的信号(数据)。比如,车辆内部可以包括控制发动机系统的发动机ECU、控制空调系统的空调ECU或控制仪表系统的仪表ECU等。发动机ECU用于对车辆的发动机进行控制,发送与发动机相关的信号。空调ECU用于对车辆的空调进行控制,发送与空调相关的信号。仪表ECU用于对车辆的仪表进行控制,发送与仪表相关的信号。
其中,与发动机相关的信号可以包括发动机转速、氧传感器电压、油轨压力值或发动机燃料消耗率等信号,与空调相关的信号可以包括空调模式、空调风速或空调功率等信号,与仪表相关的信号可以包括仪表显示参数的单位(公制或英制)、显示语言(中英文等)、机油保养里程或保养天数等信号。
需要说明的是,本申请实施例只是作为一个示例,并不作为对车辆内部系统的限制。比如,车辆内部还可以包括车灯系统,用于对车辆的车灯进行控制,发送与车灯相关的信号,与车灯相关的信号可以包括刹车灯、转向灯等信号。
现有技术中,各ECU中存储有被固化的通信策略,该通信策略在车辆出厂后不可被更改。多ECU之间可以根据通信策略传输携带目标数据(目标信号)的通信报文,从而实现各ECU之间通信。比如,ECU可以根据固定的通信策略通过车用总线向其它ECU发送通信报文,或者根据固定的通信策略从车用总线上接收其它ECU发送的通信报文,从而实现与其它ECU的通信。
但是,现有技术中多ECU之间的通信策略固化,可能会存在车用总线负载率较高,车用总线上的数据传输的延迟率较高的问题。
比如,在一定时间段内空调的相关信号没有发生变化的情况下,空调ECU仍然根据通信策略,以固定时间间隔不间断地通过车用总线发送固定的携带空调相关信号(目标数据)的通信报文,仪表ECU在该一定时间段内从车用总线上接收到携带相同的空调相关信号的通信报文,使得车用总线在该一定时间段内传输了大量的无效的通信报文,车用总线的负载率较高。另外,由于车用总线的带宽有限,因此大量的无效的通信报文还会造成传输拥堵,使得数据传输的延迟率较高。
基于此,为解决由于通信策略固化造成的车用总线的负载率和延迟率较高的问题,本申请实施例提出了一种通信方法,可以减少车用总线上传输的无效的通信响应报文,从而降低车用总线的负载率和延迟率。
下面对本申请实施例提供的多ECU系统进行详细地解释说明。
请参考图1,图1是本申请实施例提供的一种多ECU系统的结构框图。
其中,多ECU系统包括多个ECU。比如,如图1所示,多ECU系统包括第一ECU10和第二ECU20。
其中,多ECU系统可以应用于终端设备中,即终端设备可以包括多个ECU,比如包括图1示出的第一ECU10和第二ECU20。
其中,第一ECU10和第二ECU20连接,第一ECU10与第二ECU20可以进行通信。比如,第一ECU10和第二ECU20可以通过有线或无线连接。
其中,第一ECU10用于向第二ECU20发送数据订阅请求,数据订阅请求携带向第二ECU请求的目标数据的通信策略。第一ECU10还用于接收第二ECU20根据通信策略发送的通信响应报文,从通信响应报文中获取目标数据,通信响应报文携带目标数据。
其中,第二ECU20用于接收第一ECU10发送的数据订阅请求,数据订阅请求携带第一ECU10请求的目标数据的通信策略。第二ECU20还用于根据通信策略向第一ECU10发送通信响应报文,通信响应报文携带目标数据。
另外,第一ECU10可以向第二ECU20发送数据订阅请求,数据订阅请求携带第一ECU10向第二ECU20请求的目标数据的通信策略。第二ECU20接收第一ECU10发送的数据订阅请求,根据通信策略向第一ECU10发送通信响应报文,通信响应报文携带目标数据。之后第一ECU10接收第二ECU20发送的通信响应报文,从通信响应报文中获取目标数据。
作为一个示例,通信策略可以存储于第一ECU10的可读写的存储区内。由于通信策略存储于可进行读写的存储区内,因此通信策略可根据实际需求灵活地修改。比如,通信策略可以在车辆出厂前或出厂后写入存储区内,也可以根据实际需求更改通信策略,能够满足不同的实际需求,灵活性和可适用性较高。
此外,第一ECU10和第二ECU20均可以发送或接收数据订阅请求,发送或接收通信响应报文。本申请实施例仅是以第一ECU10发送数据订阅请求和接收通信响应报文,第二ECU20接收数据订阅请求和发送通信响应报文为例进行说明,并不作为限定。其中,第一ECU10也可以称为发送ECU,指示发送数据订阅请求,第二ECU20可以称为接收ECU,指示接收数据订阅请求。
如此第一ECU10可以在需要时向第二ECU20发送数据订阅请求,以请求第二ECU20根据数据订阅请求携带的通信策略向第一ECU10发送通信响应报文,从而第二ECU20根据第一ECU10主动发送的数据订阅请求携带的通信策略,向第一ECU10发送实际所需的目标数据,可以避免第二ECU20以出厂固化的通信策略向第一ECU10发送的目标数据可能不是第一ECU10需要的问题,减少了车用总线传输的无效通信响应报文,降低了车用总线的负载率和延迟率。
作为一个示例,如图1所示,多ECU系统可以应用于终端设备中,终端设备可以为车辆,第一ECU10和第二ECU20可以为车辆内部各系统中的任两个系统对应的ECU,第一ECU10和第二ECU20可以通过车用总线连接,通过车用总线进行通信。
比如,第一ECU10为车辆内部仪表系统的仪表ECU,第二ECU20为车辆内部空调系统的空调ECU。仪表ECU可以通过车用总线向空调ECU发送携带目标数据(与空调相关的信号)的数据订阅请求,空调ECU接收该数据订阅请求,再根据该数据订阅请求通过车用总线向仪表ECU发送通信响应报文,之后仪表ECU接收车用总线上传输的空调ECU发送的通信响应报文,从通信响应报文中获取目标数据(与空调相关的信号)。如此,通过第一ECU10主动发送的数据订阅请求,以及第二ECU20对接收的数据订阅请求的响应,实现第一ECU10和第二ECU20之间的通信,即本申请实施例通过发送订阅请求和接收订阅请求的通信机制实现通信。
另外,多ECU系统还可以包括更多的ECU。比如,如图1所示,多ECU系统还包括第三ECU30,第一ECU10、第二ECU20可以分别与第三ECU30连接,第一ECU10、第二ECU20可以分别与第三ECU30进行通信。当然,图1仅作为示例,并不作为对ECU系统的限定。比如,第三ECU30仅与第一ECU10连接,而无法与第二ECU20连接(通信),当然第三ECU30也可以仅与第二ECU20连接(通信),而无法与第一ECU10连接(通信)。
作为一个示例,第三ECU30可以为发动机ECU或刹车ECU等,本申请实施例对此不做限定。
作为一个示例,多ECU系统中的任一个ECU可以为任一具有运算、控制和存储功能的设备,本申请实施例对ECU不做限定。比如,车辆内部各系统中的任一个系统对应的ECU可以称为“行车电脑”或“车载电脑”等,ECU可以为专用微型计算机设备或专用嵌入式设备等,用于对对应的系统进行控制。
作为一个示例,多ECU系统可以为其它设备中的多ECU系统,本申请实施例对比不做限定。
接下来,对本申请实施例提供的通信方法予以说明。
请参考图2,图2是本申请实施例提供的一种通信方法的流程图,该方法可以应用于第一ECU,比如应用于上述图1所示的多ECU系统中的第一ECU。如图2所示,该方法包括如下步骤:
步骤201,第一ECU向第二ECU发送数据订阅请求,数据订阅请求携带向第二ECU请求的目标数据的通信策略。
其中,通信策略可以包括至少一种参数。比如通信策略包括向第二ECU请求的目标数据的数据标识,数据标识用于唯一标识数据,数据标识可以为数据名称或数据ID(Identity Document,身份证标识号)等。
当然,通信策略也可以包括多个数据标识,以便第一ECU一次获取多个数据且,该多个数据应均为同一个ECU支持发送的数据。
另外,通信策略还可以包括请求的目标数据的发送次数、发送时间间隔、开始发送条件和结束发送条件中的一种或多种。
作为一个示例,通信策略可以存储于第一ECU的可读写的存储区内。由于通信策略存储于ECU的可读写的存储区内,因此通信策略可根据实际需求修改,灵活性和可适用性较高。
比如,通信策略所包括的向第二ECU请求的目标数据的数据标识、请求的目标数据的发送次数、发送时间间隔、开始发送条件和结束发送条件均可更改。另外,为满足不同实际需要,通信策略还可以包括更多或更少的参数,本申请实施例对通信策略不做限定。
作为一个示例,每个ECU内存储有预先设置的与其它ECU通信的通信策略。第一ECU可以在满足预设条件时,获取与第二ECU通信的通信策略,向第二ECU发送携带与第二ECU通信的通信策略的数据订阅请求。
比如,第一ECU为仪表ECU,第二ECU为空调ECU。仪表ECU可以在其上电后,获取与空调ECU通信的通信策略,向空调ECU发送数据订阅请求,数据订阅请求携带与空调ECU通信的通信策略。其中,车辆开启后仪表ECU即可上电。
当然,每个ECU内可以存储多个通信策略,多个通信策略可以为与不同ECU通信的通信策略,也可以为与同一个ECU通信的不同策略。比如,在不同的情况下,第一ECU与同一个ECU通信的通信策略不同。
作为一个示例,车辆包括TBOX(telematics box,车载智能终端)系统,用于对车辆进行监测,第一ECU可以为TBOX系统对应的TBOX-ECU。对不同车辆,TBOX系统对应的TBOX-ECU从仪表ECU中获取的目标数据(信号)可能不同,即进行监测的参数不同。比如,对于私人车辆,TBOX-ECU需要对机油保养里程或保养天数进行监控,因此需要从仪表ECU中获取机油保养里程或保养天数等数据,用来确定车辆是否需要保养。对于出租车辆,可以由公司统一管理保养,因此出租车的TBOX-ECU不需要对机油保养里程或保养天数进行监控,即不需要从仪表ECU中获取机油保养里程或保养天数等数据。由于不同车辆的TBOX-ECU从仪表ECU中获取的数据不同,因此与仪表ECU通信的通信策略不同,本申请实施例提供的通信方法中,可以根据不同的车辆对通信策略进行相应的修改,满足不同实际需要,灵活性和可适用性较高。
其中,第一ECU与第二ECU可以通过无线或有线连接。比如,第一ECU和第二ECU为车辆中的ECU,第一ECU和第二ECU通过车用总线连接,车用总线为第一ECU和第二ECU实现通信的数据传输通道。比如,第一ECU通过车用总线向第二ECU发送数据订阅请求。
作为一个示例,数据订阅请求可以以报文的形式在数据传输通道(比如车用总线)中传输。
其中,数据订阅请求可以包括用于指示数据订阅的标识。比如,数据订阅请求包括用于指示类型的类型标识,类型标识可以为数据订阅的标识、取消订阅的标识、通信响应的标识、订阅失败响应的标识或订阅成功响应的标识等。数据订阅的标识可以标识数据订阅请求,取消订阅的标识可以标识取消订阅请求,通信响应的标识可以标识通信响应报文,订阅失败响应的标识可以标识订阅失败响应报文,订阅成功响应的标识可以标识订阅成功响应报文。
其中,类型标识可以为类型名称或类型ID等。
比如,第一ECU向第二ECU发送的数据订阅请求中包括类型标识,类型标识为数据订阅的标识。如此,第二ECU在接收到第一ECU发送的数据订阅请求后,可以根据数据订阅的标识确定接收到的数据为数据订阅请求。
其中,数据订阅请求还可以包括至少一个接收ECU标识,接收ECU标识用于指示接收数据订阅请求的ECU,接收ECU标识可以为接收ECU名称或接收ECU的ID等。
需要说明的是,根据接收ECU标识,可以使第二ECU在接收第一ECU发送的数据订阅请求之后,根据接收ECU标识,确定是否解析数据订阅请求。根据数据订阅请求包括的用于指示数据订阅的标识(类型标识),可以使第二ECU确定接收到的数据为数据订阅请求报文。
步骤202,第一ECU接收第二ECU根据通信策略发送的通信响应报文。
其中,通信响应报文携带目标数据。
作为一个示例,通信响应报文可以包括用于指示通信响应的标识。比如,通信响应报文包括类型标识,类型标识为通信响应的标识。第一ECU根据通信响应报文中的类型标识,确定接收到的数据为通信响应报文。
其中,第一ECU通过有线或无线接收第二ECU发送的通信响应报文。比如,第一ECU通过车用总线接收第二ECU发送的通信响应报文。
作为一个示例,第一ECU与第二ECU的数据传输通道(比如车用总线)中可能传输有多个不同ECU或相同ECU发送的多个通信响应报文。这种情况下,第一ECU数据传输通道中获取通信响应报文时,应从多个通信响应报文中选择其它ECU向第一ECU发送的通信响应报文。
比如,通信响应报文包括至少一个接收ECU标识。第一ECU可以在接收第二ECU发送的通信响应报文之后,根据通信响应报文中的接收ECU标识确定是否解析通信响应报文(是否执行步骤203,是否从通信响应报文中获取目标数据)。
具体地,第一ECU可以在接收第二ECU发送的通信响应报文之后,确定通信响应报文中的接收ECU标识是否包括第一ECU标识。若确定接收ECU标识中包括第一ECU标识,则确定该通信响应报文是其它ECU发送给自身的数据,解析该通信响应报文(执行步骤203,从通信响应报文中获取目标数据)。若确定接收ECU标识中不包括第一ECU标识,则确定该通信响应报文不是其它ECU发送给自身的数据,不解析该通信响应报文,或者丢弃该通信响应报文。
作为一个示例,通信响应报文包括的接收ECU标识可以为多个,这种情况下,第二ECU可以通过同一个通信响应报文(报文)同时向多个ECU发送目标数据,多个ECU均可以接收该通信响应报文,从而减少第二ECU发送的通信响应报文(报文),降低负载率和延迟率。
作为一个示例,第一ECU在接收第二ECU根据通信策略发送的通信响应报文之前,还可以接收第二ECU发送的订阅成功响应报文。
其中,订阅成功响应报文携带数据发送格式,订阅成功响应报文用于指示目标数据订阅成功,数据发送格式指示第二ECU向第一ECU发送目标数据的格式,数据发送格式包括目标数据的数据标识在通信响应报文中的位置、目标数据在通信响应报文中的位置、占用位数和进制类型中的一种或多种。
如此,第一ECU可以根据订阅成功响应报文携带的数据发送格式,从通信响应报文中获取目标数据。
其中,订阅成功响应报文可以包括指示订阅成功响应的标识。比如,订阅成功响应报文包括用于指示类型的类型标识,类型标识为订阅成功响应的标识。如此,第一ECU可以在接收到第二ECU发送的订阅成功响应报文之后,可以根据类型标识确定接收到的数据为订阅成功响应报文,从而确定与第二ECU通信成功,并在接收到第二ECU发送的通信响应报文之后,根据订阅成功响应报文中的数据发送格式从通信响应报文中获取目标数据。
需要说明的是,第一ECU接收第二ECU发送的携带数据发送格式的订阅成功响应报文,是在第一ECU和第二ECU之间确定通信响应报文中目标数据的数据发送格式,从而第二ECU可以根据该数据发送格式向第一ECU发送携带目标数据的通信响应报文,第一ECU可以根据该数据发送格式从通信响应报文中获取目标数据,如此可以实现第一ECU和第二ECU之间的通信。
作为一个示例,第一ECU还可以接收第二ECU发送的订阅失败响应报文,根据订阅失败响应报文确定目标数据订阅失败,即确定与第二ECU通信失败。这种情况下,第一ECU可以发出报警信息,以通知相关人员对通信策略进行修改,实现与第二ECU的通信,获取目标数据。
其中,订阅失败响应报文包括至少一个接收ECU标识和用于指示订阅失败响应的标识。比如,订阅失败响应报文包括接收ECU标识和类型标识,接收ECU标识中包括第一ECU标识,类型标识为订阅失败响应的标识。如此,第一ECU可以在接收到第二ECU发送的订阅失败响应报文之后,根据接收ECU标识中的第一ECU标识确定解析订阅失败响应报文,比如根据类型标识确定接收到的数据为订阅失败响应报文,从而确定与第二ECU通信失败。
需要说明的是,由于通信策略是第一ECU根据实际需要主动向第二ECU发送的数据订阅请求携带的策略,因此第二ECU根据接收到的通信策略向第一ECU发送的通信响应报文中的目标数据是第一ECU实际所需的数据。
步骤203,第一ECU从通信响应报文中获取目标数据。
比如,第一ECU可以根据之前接收到的数据发送格式,从通信响应报文中解析出目标数据。
比如,第一ECU为仪表ECU,第二ECU为空调ECU,第一ECU需要获取第二ECU中的第一数据,第一数据是与空调相关的数据。第一ECU可以对从通信响应报文中解析出的第一数据进行相关信息显示等处理。
作为一个示例,第一ECU还可以向第二ECU发送携带目标数据的取消订阅请求,取消订阅请求用于指示第二ECU停止向第一ECU发送目标数据。如此,第二ECU可以在接收第一ECU发送的取消订阅请求后,停止向第一ECU发送携带目标数据的通信响应报文,从而第一ECU和第二ECU停止通信。
其中,取消订阅请求可以以报文的形式在数据传输通道(比如车用总线)中传输。
取消订阅请求可以包括用于指示数据订阅的标识。比如,数据订阅请求包括用于指示类型的类型标识,类型标识可以为取消订阅的标识。如此,第二ECU再接收到第一ECU发送的取消订阅请求后,可以根据取消订阅的标识确定接收到的数据为取消订阅请求。
取消订阅请求还可以包括至少一个接收ECU标识,接收ECU标识用于指示接收取消订阅请求的ECU。
需要说明的是,本申请实施例仅以第一ECU发送数据订阅请求为例进行说明,即仅以第一ECU执行步骤201-步骤203为例进行说明,并不作为执行步骤201-步骤203的ECU的限定。比如,执行步骤201-步骤203的ECU可以为上述图1示出的第二ECU或第三ECU等,本申请实施例对此不做限定。
本申请实施例中,第一ECU先向第二ECU发送数据订阅请求,数据订阅请求携带向第二ECU请求的目标数据的通信策略,然后接收第二ECU根据通信策略发送的携带目标数据的通信响应报文,从通信响应报文中获取目标数据。如此,一个ECU(发送ECU)可以在需要时向另一个ECU(接收ECU)发送数据订阅请求,从而接收ECU根据发送ECU主动发送的数据订阅请求携带的通信策略,向发送ECU发送携带实际所需的目标数据的通信响应报文,可以避免接收ECU以出厂固化的通信策略向发送ECU发送的目标数据可能不是发送ECU需要的问题,减少了车用总线传输的无效通信响应报文,降低了车用总线的负载率和延迟率。
请参考图3,图3是本申请实施例提供的另一种通信方法的流程图,该方法可以应用于第二ECU,比如应用于上述图1所示的多ECU系统中的第二ECU。如图3所示,该方法包括如下步骤:
步骤301,第二ECU接收第一ECU发送的数据订阅请求,数据订阅请求携带第一ECU请求的目标数据的通信策略。
其中,通信策略可以包括第一ECU请求的目标数据的数据标识,数据标识用于唯一标识数据,数据标识可以为数据名称或数据ID(Identity Document,身份证标识号)等。
其中,通信策略还可以包括请求的目标数据的发送次数、发送时间间隔、开始发送条件和结束发送条件中的一种或多种。
比如,第二ECU通过有线或无线接收第一ECU发送的数据订阅请求。比如,车用总线中传输有第一ECU发送的数据订阅请求,第二ECU可以从车用总线中获取该数据订阅请求。
作为一个示例,第一ECU和第二ECU之间的数据传输通道(比如车用总线)中可能传输有不同ECU或相同ECU发送的多个数据订阅请求。这种情况下,第二ECU从数据传输通道中获取数据订阅请求之后,先确定是否对该数据订阅请求进行解析。
比如,第一ECU向第二ECU发送的数据订阅请求可以包括接收ECU标识。第二ECU在接收到数据订阅请求之后,先确定数据订阅请求中的接收ECU标识是否包括第二ECU标识。第二ECU若确定接收ECU标识中包括第二ECU标识,则确定该数据订阅请求是其它ECU发送给自身的请求,解析第一ECU发送的数据订阅请求。第二ECU若确定接收ECU标识中不包括第二ECU标识,则确定该数据订阅请求不是其它ECU发送给自身的请求,不解析第一ECU发送的数据订阅请求,丢弃数据订阅请求。
另外,数据订阅请求还可以包括类型标识,类型标识为数据订阅的标识。第二ECU解析第一ECU发送的数据订阅请求可以包括解析数据订阅请求中的类型标识,确定接收到的数据为数据订阅请求。
作为一个示例,数据订阅请求中的接收ECU标识包括第二ECU标识,比如第二ECU标识为0x16,类型标识为数据订阅的标识,比如为0x0fff。则第二ECU可以在接收第一ECU发送的数据订阅请求之后,根据接收ECU标识确定接收到的数据是其它ECU发送给自身的数据,根据类型标识确定接收的数据是数据订阅请求。
此外,第二ECU解析第一ECU发送的数据订阅请求还可以包括解析数据订阅请求携带的通信策略。比如,解析通信策略中的第一ECU请求的目标数据、以及目标数据的发送次数、发送时间间隔、开始发送条件或结束发送条件,从而第二ECU可以根据解析的第一ECU请求的目标数据、以及目标数据的发送次数、发送时间间隔、开始发送条件或结束发送条件等向第一ECU发送通信响应报文。
需要说明是,在车辆开启后,即使ECU对应的系统没有开启,ECU也可以获取与其它ECU的通信策略,向其它ECU发送数据订阅请求,或者接收其它ECU发生的数据订阅请求。比如,第一ECU为仪表ECU,第二ECU为空调ECU。仪表ECU可以在车辆开启后,获取与空调ECU通信的通信策略,向空调ECU发送数据订阅请求,而空调ECU也可以接收仪表ECU发送的数据订阅请求。这种情况下,可能存在空调ECU对应的空调系统没有开启的情况,虽然空调系统没有开启,但是空调ECU也可以接收仪表ECU向其发送的数据订阅请求。由于数据订阅请求携带通信策略,因此空调ECU可以在空调系统开启后根据之前接收到的通信策略向仪表ECU发送通信响应报文。
步骤302,第二ECU根据通信策略向第一ECU发送通信响应报文,通信响应报文携带目标数据。
其中,第二ECU可以通过有线或无线向第一ECU发送通信响应报文。比如,第二ECU可以通过车用总线向第一ECU发送通信响应报文。
其中,通信响应报文可以包括类型标识或至少一个接收ECU标识,类型标识为通信响应的标识,至少一个接收ECU标识中包括第一ECU标识,如此第一ECU可以在接收第二ECU发送的通信响应报文之后,可以根据至少一个接收ECU标识中的第一ECU标识,确定解析接收到的通信响应报文,比如根据类型标识确定接收到的数据为通信响应报文,或者根据预先接收到的数据发送格式从通信响应报文中解析出目标数据。
另外,第二ECU可以根据通信策略包括的第一ECU请求的目标数据的发送次数、发送时间间隔、开始发送条件或结束发送条件向第一ECU发送包括目标数据的通信响应报文。
比如,第二ECU在满足开始发送条件时,根据发送次数和发送时间间隔向第一ECU发送包括目标数据的通信响应报文,在满足结束发送条件时,停止向第一ECU发送包括目标数据的通信响应报文。
此外,第二ECU也可以在接收到第一ECU发送的取消订阅请求后,停止向第一ECU发送通信响应报文。比如,第二ECU接收到第一ECU发送的取消订阅请求,向第一ECU发送停止通信响应数据,停止通信响应数据用于指示第二ECU停止向第一ECU发送通信响应报文。第一ECU接收第二ECU发送的停止通信响应数据。如此第一ECU和第二ECU停止通信。
其中,取消订阅请求包括至少一个接收ECU标识或类型标识,接收ECU标识中包括第一ECU标识。第二ECU可以在接收到取消订阅请求后,根据接收ECU标识中包括的第一ECU标识,确定解析取消订阅请求,比如根据类型标识确定接收到的数据为取消订阅请求。
其中,第二ECU向第一ECU发送的通信响应报文具有一定的数据发送格式,数据发送格式用于指示第二ECU向第一ECU发送目标数据的格式,数据发送格式包括第一ECU请求的目标数据的数据标识在通信响应报文中的位置、目标数据在通信响应报文中的位置、占用位数和进制类型中的一种或多种。
因此,第二ECU根据通信策略向第一ECU发送通信响应报文时,还应确定发送通信响应报文的预设的数据发送格式,以根据通信策略和预设的数据发送格式向第一ECU发送通信响应报文。
其中,目标数据的数据标识在通信响应报文中的位置可以为数据标识在通信响应报文中的起始位置和/或终止位置等。目标数据在通信响应报文中的进制类型是指目标数据在通信响应报文中的进制数表示,比如为目标数据在通信响应报文中用二进制、十六进制等表示,以便第二ECU可以根据进制类型解析出目标数据的信号值。
作为一个示例,第二ECU在根据通信策略向第一ECU发送通信响应报文之前,还应向第一ECU发送数据发送格式,以便第一ECU在接收到第二ECU发送的通信响应报文之后,根据数据发送格式从通信响应报文中获取(解析出)目标数据。
比如,第一ECU向第二ECU发送订阅成功响应报文,订阅成功响应指示目标数据订阅成功,订阅成功响应可以携带数据发送格式。
需要说明的是,第二ECU向第一ECU发送的携带数据发送格式的订阅成功响应报文,是在第一ECU和第二ECU之间确定通信响应报文中目标数据的数据发送格式,从而第二ECU可以根据该数据发送格式向第一ECU发送携带目标数据的通信响应报文,第一ECU可以根据该数据发送格式从通信响应报文中获取目标数据,如此可以实现第一ECU和第二ECU之间的通信。
作为一个示例,第二ECU也可以根据通信策略和预设的数据发送格式生成数据发送策略,根据数据发送策略向第一ECU发送通信响应报文。
其中,数据发送策略包括向第二ECU请求的目标数据的数据标识在通信响应报文中的位置、目标数据在通信响应报文中的位置、占用位数和进制类型、以及通信响应报文的发送次数、发送时间间隔、开始发送条件和结束发送条件中的一种或多种。
如此,第二ECU可以根据目标数据的数据标识在通信响应报文中的位置、目标数据在通信响应报文中的位置、占用位数和进制类型确定发送通信响应报文的格式,根据发送次数、发送时间间隔、开始发送条件或结束发送条件发送通信响应报文。
其中,第二ECU在生成数据发送策略后,可以直接根据数据发送策略自动发送通信响应报文。比如,在车辆第一次开启时,第一ECU向第二ECU发送携带通信策略的数据订阅请求。第二ECU接收数据订阅请求,生成并保存数据发送策略,根据数据发送策略向第一ECU发送通信响应报文。在车辆下次开启时,若第一ECU中的通信策略没有被更改,则第一ECU不再向第二ECU发送携带通信策略的数据订阅请求,第二ECU也不需要在接收到数据订阅请求后向第一ECU发送通信响应报文,而是直接根据存储的数据发送策略自动向第一ECU发送通信响应报文,如此可以减少第一ECU向第二ECU发送数据订阅请求的次数,从而减少车用总线上传输的数据(报文),降低车用总线的负载率和延迟率。另外,第二ECU也可以及时根据数据发送策略向第一ECU发送通信响应报文,提高通信效率。
作为一个示例,每个ECU支持发送的数据可以包括多个,且ECU支持发送的多个数据是与对应系统相关的数据(信号)。这种情况下,第二ECU根据通信策略向第一ECU发送通信响应报文之前,还应确定第一ECU请求的目标数据是否为第二ECU支持发送的数据。
比如,通信策略包括请求的目标数据的数据标识,第二ECU可以根据目标数据的数据标识确定第一ECU请求的数据是否为第二ECU支持发送的数据。具体地,第二ECU根据通信策略向第一ECU发送通信响应报文之前,还可以包括以下步骤:
步骤1)根据目标数据的数据标识,确定第二ECU支持发送的数据中是否存在目标数据。
其中,第二ECU支持发送的数据具有对应的数据标识,第二ECU可以根据第二ECU支持发送的数据标识,确定目标数据是否为第二ECU支持发送的数据。
比如,第二ECU中预先存储有第二ECU支持发送的数据标识列表,第二ECU在接收到数据订阅请求之后,可以确定数据标识列表中是否存在目标数据的数据标识。若数据标识列表中存在目标数据的数据标识,则确定第二ECU支持发送的数据中存在目标数据。若数据标识列表中不存在目标数据的数据标识,则确定第二ECU支持发送的数据中不存在目标数据。
步骤2)若确定第二ECU支持发送的数据中存在目标数据,则向第一ECU发送订阅成功响应报文。
其中,订阅成功响应报文用于指示目标数据订阅成功。
其中,订阅成功响应报文包括指示订阅成功响应的标识。比如,订阅成功响应报文包括用于指示类型的类型标识,类型标识为订阅成功响应的标识。如此,第一ECU可以在接收到第二ECU发送的订阅成功响应报文之后,根据类型标识确定接收到的数据为订阅成功响应报文,从而确定与第二ECU通信成功。
其中,订阅成功响应报文可以携带数据发送格式,数据发送格式指示第二ECU向第一ECU发送目标数据的格式,以便第一ECU接收第二ECU发送的通信响应报文之后,可以根据数据发送格式从通信响应报文中解析出目标数据。
需要说明的是,第二ECU向第一ECU发送的携带数据发送格式的订阅成功响应报文,是在第一ECU和第二ECU之间确定通信响应报文中目标数据的数据发送格式,从而第二ECU可以根据该数据发送格式向第一ECU发送携带目标数据的通信响应报文,第一ECU可以根据该数据发送格式从通信响应报文中获取目标数据,如此可以实现第一ECU和第二ECU之间的通信。
步骤3)若确定第二ECU支持的数据中不存在目标数据,则向第一ECU发送订阅失败响应报文。
其中,订阅失败响应报文用于指示目标数据订阅失败。
其中,订阅失败响应报文包括至少一个接收ECU标识和用于指示订阅失败响应的标识。比如,订阅失败响应报文包括接收ECU标识和类型标识,接收ECU标识中包括第一ECU标识,类型标识为订阅失败响应的标识。如此,第一ECU可以在接收到第二ECU发送的订阅失败响应报文之后,根据接收ECU标识中第一ECU标识确定解析订阅失败响应报文,比如,根据根据类型标识确定接收到的数据为订阅失败响应报文,从而确定与第二ECU通信失败。
需要说明的是,本申请实施例仅以第二ECU接收数据订阅请求为例进行说明,即仅以第二ECU执行步骤301-步骤302为例进行说明,并不作为执行步骤301-步骤302的ECU的限定。比如,执行步骤301-步骤302的ECU可以为上述图1示出的第一ECU或第三ECU等,本申请实施例对此不做限定。
本申请实施例中,第二ECU先接收第一ECU发送的数据订阅请求,数据订阅请求携带第一ECU请求的目标数据的通信策略,然后根据通信策略向第一ECU发送携带目标数据通信响应报文。如此,接收ECU(第二ECU)根据发送ECU(第一ECU)主动发送的数据订阅请求携带的通信策略,向发送ECU发送实际所需的目标数据,从而避免接收ECU以出厂固化的通信策略向发送ECU发送的目标数据可能不是发送ECU需要的问题,减少了车用总线传输的无效通信响应报文,降低了车用总线的负载率和延迟率。
请参考图4,图4是本申请实施例提供的再一种通信方法的流程图,该方法可以应用于终端设备,终端设备包括上述图1所示的多ECU系统,终端设备(多ECU系统)至少包括第一ECU和第二ECU,第一ECU和第二ECU连接。如图4所示,该方法包括如下步骤:
步骤401,第一ECU向第二ECU发送数据订阅请求,数据订阅请求携带第一ECU向第二ECU请求的目标数据的通信策略。
其中,第一ECU与第二ECU可以通过有线或无线的方式连接,第一ECU可以通过有线或无线向第二ECU发送数据订阅请求。比如,第一ECU与第二ECU通过车辆总线连接,第一ECU可以通过车辆总线连接向第二ECU发送数据订阅请求。
其中,数据订阅请求可以包括用于指示数据订阅的标识。
比如,数据订阅请求包括用于指示类型的类型标识,类型标识为数据订阅的标识,如此第二ECU在接收到第一ECU发送的数据订阅请求后,可以根据数据订阅的标识确定接收到的数据为数据订阅请求。
其中,数据订阅请求还可以包括至少一个接收ECU标识。比如,至少一个接收ECU标识中包括第一ECU标识。
其中,通信策略可以包括向第二ECU请求的目标数据的数据标识、目标数据的发送次数、发送时间间隔、开始发送条件和结束发送条件中的一种或多种。
作为一个示例,第一ECU为仪表ECU,第二ECU为空调ECU,仪表ECU需要获取空调ECU中的第一数据。仪表ECU可以向空调ECU发送数据订阅请求,数据订阅请求携带第一数据的通信策略。
其中,数据订阅请求中可以包括类型标识或至少一个接收ECU标识,类型标识为数据订阅的标识,至少一个接收ECU标识中包括空调ECU标识。
其中,通信策略包括仪表ECU向空调ECU请求的第一数据的数据标识、第一数据的发送次数、发送时间间隔、开始发送条件和结束发送条件中的一种或多种。
步骤402,第二ECU接收第一ECU发送的数据订阅请求。
其中,第二ECU在接收到数据订阅请求之后,可以根据数据订阅请求中包括的至少一个接收ECU标识,确定是否解析该数据订阅请求。
比如,第一ECU为仪表ECU,第二ECU为空调ECU,仪表ECU需要获取空调ECU中的第一数据。空调ECU在接收到仪表ECU发送的数据订阅请求之后,可以根据数据订阅请求中的至少一个接收ECU标识确定是否解析该数据订阅请求。若至少一个接收ECU标识中包括空调ECU标识,则解析该数据订阅请求。若至少一个接收ECU标识中不包括空调ECU标识,则解析该数据订阅请求,丢弃该数据订阅请求。
其中,解析该数据订阅请求可以包括空调ECU根据数据订阅请求中的类型标识,确定接收到的数据为数据订阅请求,或者包括从数据订阅请求中解析出通信策略,即解析出通信策略中的仪表ECU向空调ECU请求的第一数据的数据标识、第一数据的发送次数、发送时间间隔、开始发送条件或结束发送条件等。
步骤403,第二ECU根据通信策略向第一ECU发送通信响应报文。
其中,通信响应报文携带目标数据。
其中,通信响应报文可以包括类型标识或至少一个接收ECU标识,类型标识为通信响应的标识。
比如,第二ECU可以根据通信策略中的第一ECU向第二ECU请求的目标数据的发送次数、发送时间间隔、开始发送条件或结束发送条件向第一ECU发送包括目标数据的通信响应报文。
作为一个示例,第一ECU为仪表ECU,第二ECU为空调ECU,仪表ECU需要获取空调ECU中的第一数据。仪表ECU向空调ECU发送的数据订阅请求的通信策略中包括第一数据的数据标识、发送次数和开始发送条件。第一数据为空调风速信号,发送次数为1次,开始发送条件为空调开启、空调关闭或空调风速信号的信号值发生变化。如此,空调ECU在接收到数据订阅请求之后,可以在满足空调开启、空调关闭或空调风速信号的信号值发生变化的条件时,向仪表ECU发送1次包括空调风速信号的通信响应报文。在其它情况下,不向仪表ECU发送包括空调风速信号的通信响应报文。如此,可以有效减少空调ECU向仪表ECU发送的通信响应报文,从而减少车用总线上传输的通信响应报文,降低车用总线的负载率和延迟率。
由于通信策略存储于仪表ECU的可读写的存储区内,因此可以将仪表ECU中存储的与空调ECU进行通信的通信策略修改为包括第一数据的数据标识、第二数据的数据标识、发送次数、开始发送条件和结束发送条件,如此可以满足不同环境,增加灵活性和可适用性。当然,根据实际需要也可以将通信策略更改为其它,本申请实施例对此不做限定。
另外,由于通信策略是仪表ECU根据实际需要主动向空调ECU发送的数据订阅请求携带的策略,因此空调ECU根据接收到的通信策略向仪表ECU发送的通信响应报文中的第一数据是仪表ECU实际所需的数据。
作为一个示例,通信响应报文携带的目标数据具有一定的格式,因此第二ECU可以根据通信策略和预设的数据发送格式向第一ECU发送通信响应报文。数据发送格式包括第一ECU请求的目标数据的数据标识在通信响应报文中的位置、目标数据在通信响应报文中的位置、占用位数和进制类型中的一种或多种。
作为一个示例,第二ECU在向第一ECU发送通信响应报文之前,还可以向第一ECU发送数据发送格式,以在第一ECU和第二ECU之间确定通信响应报文中目标数据的数据发送格式,从而第一ECU可以根据该数据发送格式从通信响应报文中获取目标数据,如此可以实现第一ECU和第二ECU之间的通信。
作为一个示例,每个ECU支持发送的数据可以包括多个,且ECU支持发送的多个数据是与对应系统相关的数据(信号)。这种情况下,第二ECU在根据通信策略向第一ECU发送携带目标数据的通信响应报文之前,还可以确定第一ECU请求的目标数据是否为第二ECU支持发送的数据。
比如,第二ECU根据目标数据的数据标识,先确定第二ECU支持发送的数据中是否存在目标数据。若确定第二ECU支持发送的数据中存在目标数据,则向第一ECU发送订阅成功响应报文。若确定第二ECU支持的数据中不存在目标数据,则向第一ECU发送订阅失败响应报文。
其中,订阅成功响应报文用于指示目标数据订阅成功,订阅失败响应报文用于指示目标数据订阅失败。
其中,订阅成功响应报文还可以携带数据发送格式。
比如,第一ECU为仪表ECU,第二ECU为空调ECU,第一ECU需要获取第二ECU中的第一数据,空调ECU支持发送的数据是与空调相关的数据,比如,空调ECU支持发送的数据包括空调模式、空调风速或空调功率等数据(信号)。空调ECU在向仪表ECU发送通信响应报文之前,还可以确定第一数据是否为空调ECU支持发送的数据。若第一数据不是空调ECU支持发送的数据,则向仪表ECU发送订阅成功响应报文,否则,向仪表ECU发送订阅失败响应报文。
步骤404,第一ECU接收第二ECU发送的通信响应报文,从通信响应报文中获取目标数据。
其中,本申请实施例提供的通信方法是通过发送订阅请求和接收订阅请求的通信机制实现通信,即通过订阅机制实现通信。该发送订阅请求是ECU主动向其它ECU发送的获取其实际所需的目标数据的请求,因此其它ECU发送的通信响应报文中的目标数据数据是该ECU实际所需的数据,即该ECU可以接收到其它ECU发送的包括实际所需的目标数据的通信响应报文。
其中,第一ECU可以确定通信响应报文中的至少一个接收ECU标识中是否包括第一ECU标识。若至少一个接收ECU标识中包括第一ECU标识,则解析通信响应报文。若至少一个接收ECU标识中不包括第一ECU标识,则不解析通信响应报文,或者丢弃该通信响应报文。
其中,解析通信响应报文可以包括根据通信响应报文中的类型标识,确定接收到的数据为通信响应报文,或者包括从通信响应中获取目标数据。
其中,第一ECU可以根据预先接收到的数据发送格式从通信响应报文中解析出目标数据。
比如,第一ECU为仪表ECU,第二ECU为空调ECU,第一ECU需要获取第二ECU中的第一数据,第一数据是与空调相关的数据。仪表ECU可以根据预先接收到的订阅成功响应报文中的数据发送格式从通信响应报文中解析出第一数据,根据第一数据进行相关信息显示等处理。比如,数据发送格式中的进制类型为十六进制,目标数据在通信响应报文中表示为0x0203,则第一ECU从通信响应报文中解析出的目标数据的值为2*256+3=515。
其中,上述步骤401-步骤404的解释说明可以参考上述实施例2的步骤201-步骤203,以及上述实施例3的步骤301-步骤302,这里不再赘述。
本申请实施例中,第一ECU向第二ECU发送数据订阅请求,数据订阅请求携带第一ECU向第二ECU请求的目标数据的通信策略。然后,第二ECU接收第一ECU发送的数据订阅请求,根据通信策略向第一ECU发送携带目标数据的通信响应报文。之后,第一ECU接收第二ECU发送的通信响应报文,从通信响应报文中获取目标数据。如此,多ECU系统中一个ECU(发送ECU)可以在需要时向另一个ECU(接收ECU)发送数据订阅请求,以请求接收ECU根据数据订阅请求携带的通信策略向发送ECU发送携带目标数据的通信响应报文,从而接收ECU向发送ECU发送的通信响应报文中的目标数据是发送ECU实际所需的数据,可以避免接收ECU以出厂固化的通信策略向发送ECU发送的目标数据可能不是发送ECU需要的问题,减少了车用总线传输的无效通信响应报文,降低了车用总线的负载率和延迟率。
本申请实施例还提供了一种计算机设备,计算机设备至少包括第一ECU和第二ECU,第一ECU和第二ECU分别包括存储器、处理器以及存储在存储器中并可在处理器上运行的计算机程序,第一ECU对应的计算机程序被对应的处理器执行时实现如上述实施例2中的任一项所述的方法,第二ECU对应的计算机程序被对应的处理器执行时实现上述实施例3中的任一项所述的方法。
其中,上述实施例1提供的多ECU系统可以应用于计算机设备中,计算机设备可以为上述实施例4中的终端设备。在具体实现中,计算机设备可以为车辆等至少包括第一ECU和第二ECU的设备,本申请实施例对计算机设备不做限定。
请参考图5,图5为本申请实施例提供的一种ECU的结构示意图。如图5所示,ECU包括:处理器501、存储器502以及存储在存储器502中并可在处理器501上运行的计算机程序503,处理器501执行计算机程序503时实现上述实施例2、实施例3和实施例4中的步骤。
ECU可以是一个专用微型计算机设备或专用嵌入式设备等。本领域技术人员可以理解,图5仅仅是ECU的举例,并不构成对ECU的限定,可以包括比图示更多或更少的部件,或者组合某些部件,或者不同的部件,比如还可以包括输入输出设备、网络接入设备等。
处理器501可以是中央处理单元(Central Processing Unit,CPU),处理器TH0还可以是其他通用处理器、数字信号处理器(Digital Signal Processor,DSP)、专用集成电路(Application Specific Integrated Circuit,ASIC)、现成可编程门阵列(Field-Programmable Gate Array,FPGA)或者其他可编程逻辑器件、分立门或者晶体管逻辑器件、分立硬件组件等。通用处理器可以是微处理器或者也可以是任何常规的处理器。
存储器502在一些实施例中可以是ECU的内部存储单元,比如ECU的硬盘或内存。存储器502在另一些实施例中也可以是ECU的外部存储设备,比如ECU上配备的插接式硬盘、智能存储卡(Smart Media Card,SMC)、安全数字(Secure Digital,SD)卡、闪存卡(FlashCard)、多媒体卡(Multimedia Card,MMC)等。进一步地,存储器502还可以既包括ECU的内部存储单元也包括外部存储设备。存储器502用于存储操作系统、应用程序、引导装载程序(Boot Loader)、数据以及其他程序等。存储器502还可以用于暂时地存储已经输出或者将要输出的数据。
本申请实施例还提供了一种计算机可读存储介质,该计算机可读存储介质存储有计算机程序,该计算机程序被处理器执行时可实现上述各个方法实施例中的步骤。实现上述实施例2、实施例3和实施例4中的步骤。
本申请实施例提供了一种计算机程序产品,当其在计算机上运行时,使得计算机执行上述各个方法实施例中的步骤。
集成的单元如果以软件功能单元的形式实现并作为独立的产品销售或使用时,可以存储在一个计算机可读取存储介质中。基于这样的理解,本申请实现上述方法实施例中的全部或部分流程,可以通过计算机程序来指令相关的硬件来完成,该计算机程序可存储于一计算机可读存储介质中,该计算机程序在被处理器执行时,可实现上述各个方法实施例的步骤。其中,该计算机程序包括计算机程序代码,该计算机程序代码可以为源代码形式、对象代码形式、可执行文件或某些中间形式等。该计算机可读介质至少可以包括:能够将计算机程序代码携带到拍照装置/终端设备的任何实体或装置、记录介质、计算机存储器、ROM(Read-Only Memory,只读存储器)、RAM(Random Access Memory,随机存取存储器)、CD-ROM(Compact Disc Read-Only Memory,只读光盘)、磁带、软盘和光数据存储设备等。本申请提到的计算机可读存储介质可以为非易失性存储介质,换句话说,可以是非瞬时性存储介质。
应当理解的是,实现上述实施例的全部或部分步骤可以通过软件、硬件、固件或者其任意结合来实现。当使用软件实现时,可以全部或部分地以计算机程序产品的形式实现。该计算机程序产品包括一个或多个计算机指令。该计算机指令可以存储在上述计算机可读存储介质中。
在上述实施例中,对各个实施例的描述都各有侧重,某个实施例中没有详述或记载的部分,可以参见其它实施例的相关描述。
本领域普通技术人员可以意识到,结合本文中所公开的实施例描述的各示例的单元及算法步骤,能够以电子硬件、或者计算机软件和电子硬件的结合来实现。这些功能究竟以硬件还是软件方式来执行,取决于技术方案的特定应用和设计约束条件。专业技术人员可以对每个特定的应用来使用不同方法来实现所描述的功能,但是这种实现不应认为超出本申请的范围。
在本申请所提供的实施例中,应该理解到,所揭露的装置/计算机设备和方法,可以通过其它的方式实现。例如,以上所描述的装置/计算机设备实施例仅仅是示意性的,例如,模块或单元的划分,仅仅为一种逻辑功能划分,实际实现时可以有另外的划分方式,例如多个单元或组件可以结合或者可以集成到另一个系统,或一些特征可以忽略,或不执行。另一点,所显示或讨论的相互之间的耦合或直接耦合或通讯连接可以是通过一些接口,装置或单元的间接耦合或通讯连接,可以是电性,机械或其它的形式。
作为分离部件说明的单元可以是或者也可以不是物理上分开的,作为单元显示的部件可以是或者也可以不是物理单元,即可以位于一个地方,或者也可以分布到多个网络单元上。可以根据实际的需要选择其中的部分或者全部单元来实现本实施例方案的目的。
以上所述实施例仅用以说明本申请的技术方案,而非对其限制;尽管参照前述实施例对本申请进行了详细的说明,本领域的普通技术人员应当理解:其依然可以对前述各实施例所记载的技术方案进行修改,或者对其中部分技术特征进行等同替换;而这些修改或者替换,并不使相应技术方案的本质脱离本申请各实施例技术方案的精神和范围,均应包含在本申请的保护范围之内。
Claims (10)
1.一种通信方法,其特征在于,所述方法应用于第一ECU,所述方法包括:
向第二ECU发送数据订阅请求,所述数据订阅请求携带向所述第二ECU请求的目标数据的通信策略;
接收所述第二ECU根据所述通信策略发送的通信响应报文,所述通信响应报文携带所述目标数据;
从所述通信响应报文中获取所述目标数据。
2.如权利要求1所述的方法,其特征在于,所述接收所述第二ECU根据所述通信策略发送的通信响应报文之前,所述方法还包括:
接收所述第二ECU发送的订阅成功响应报文,所述订阅成功响应报文携带数据发送格式,所述订阅成功响应报文用于指示所述目标数据订阅成功,所述数据发送格式指示所述第二ECU向所述第一ECU发送所述目标数据的格式,所述数据发送格式包括所述目标数据的数据标识在所述通信响应报文中的位置、所述目标数据在所述通信响应报文中的位置、占用位数和进制类型中的一种或多种;
所述从所述通信响应报文中获取所述目标数据,包括:
根据所述数据发送格式,从所述通信响应报文中解析出所述目标数据。
3.如权利要求1所述的方法,其特征在于,所述数据订阅请求包括用于指示数据订阅的标识。
4.一种通信方法,其特征在于,所述方法应用于第二ECU,所述方法包括:
接收第一ECU发送的数据订阅请求,所述数据订阅请求携带所述第一ECU请求的目标数据的通信策略;
根据所述通信策略向所述第一ECU发送通信响应报文,所述通信响应报文携带所述目标数据。
5.如权利要求4所述的方法,其特征在于,所述通信策略包括所述目标数据的数据标识;
所述根据所述通信策略向所述第一ECU发送通信响应报文之前,所述方法还包括:
根据所述目标数据的数据标识,确定所述第二ECU支持发送的数据中是否存在所述目标数据;
若确定所述第二ECU支持发送的数据中存在所述目标数据,则向所述第一ECU发送订阅成功响应报文,所述订阅成功响应报文用于指示所述目标数据订阅成功;
若确定所述第二ECU支持发送的数据中不存在所述目标数据,则向所述第一ECU发送订阅失败响应报文,所述订阅失败响应报文用于指示所述目标数据订阅失败。
6.如权利要求4-5任一所述的方法,其特征在于,所述通信策略还包括请求的所述目标数据的发送次数、发送时间间隔、开始发送条件和结束发送条件中的一种或多种。
7.如权利要求4-5任一所述的方法,其特征在于,所述根据所述通信策略向所述第一ECU发送通信响应报文,包括:
根据所述通信策略和预设的数据发送格式向所述第一ECU发送所述通信响应报文,所述数据发送格式包括请求的所述目标数据的数据标识在所述通信响应报文中的位置、所述目标数据在所述通信响应报文中的位置、占用位数和进制类型中的一种或多种。
8.一种通信方法,其特征在于,所述方法应用于终端设备,所述终端设备至少包括第一ECU和第二ECU,所述第一ECU和所述第二ECU通信连接,所述方法包括:
所述第一ECU向所述第二ECU发送数据订阅请求,所述数据订阅请求携带所述第一ECU向所述第二ECU请求的目标数据的通信策略;
所述第二ECU接收所述第一ECU发送的所述数据订阅请求;
所述第二ECU根据所述通信策略向所述第一ECU发送通信响应报文,所述通信响应报文携带所述目标数据;
所述第一ECU接收所述第二ECU发送的所述通信响应报文,从所述通信响应报文中获取所述目标数据。
9.一种计算机设备,其特征在于,所述计算机设备至少包括第一ECU和第二ECU,所述第一ECU和所述第二ECU分别包括存储器、处理器以及存储在所述存储器中并可在所述处理器上运行的计算机程序,所述第一ECU对应的计算机程序被对应的处理器执行时实现如权利要求1至3的任一项所述的方法,所述第二ECU对应的计算机程序被对应的处理器执行时实现如权利要求4至7的任一项所述的方法。
10.一种计算机可读存储介质,其特征在于,所述计算机可读存储介质存储有计算机程序,所述计算机程序被处理器执行时实现如权利要求1至3、如权利要求4至7、或如权利要求8的任一项所述的方法。
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202210208015.1A CN114598567A (zh) | 2022-03-03 | 2022-03-03 | 通信方法、设备及存储介质 |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202210208015.1A CN114598567A (zh) | 2022-03-03 | 2022-03-03 | 通信方法、设备及存储介质 |
Publications (1)
Publication Number | Publication Date |
---|---|
CN114598567A true CN114598567A (zh) | 2022-06-07 |
Family
ID=81816387
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN202210208015.1A Pending CN114598567A (zh) | 2022-03-03 | 2022-03-03 | 通信方法、设备及存储介质 |
Country Status (1)
Country | Link |
---|---|
CN (1) | CN114598567A (zh) |
Cited By (3)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN115001897A (zh) * | 2022-06-30 | 2022-09-02 | 阿波罗智能技术(北京)有限公司 | 通信方法、装置、电子设备及自动驾驶车辆 |
CN115134186A (zh) * | 2022-06-29 | 2022-09-30 | 深圳市元征科技股份有限公司 | 数据处理方法以及相关设备 |
WO2023231892A1 (zh) * | 2022-05-30 | 2023-12-07 | 华为技术有限公司 | 传输数据的方法和装置 |
Citations (6)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN101299766A (zh) * | 2008-06-19 | 2008-11-05 | 中兴通讯股份有限公司 | 定位信息格式处理方法 |
CN106506307A (zh) * | 2016-12-22 | 2017-03-15 | 南京因泰莱电器股份有限公司 | 一种Modbus帧格式自描述方法 |
CN112001156A (zh) * | 2020-07-29 | 2020-11-27 | 中国银联股份有限公司 | 一种表单处理方法、装置及计算机可读存储介质 |
WO2021102691A1 (zh) * | 2019-11-26 | 2021-06-03 | Oppo广东移动通信有限公司 | 资源订阅方法、装置、计算机设备和存储介质 |
CN113489653A (zh) * | 2021-07-20 | 2021-10-08 | 深圳市元征未来汽车技术有限公司 | 报文发送方法、装置以及计算机设备 |
CN113837636A (zh) * | 2021-09-29 | 2021-12-24 | 平安养老保险股份有限公司 | 业务数据获取方法、装置、设备及存储介质 |
-
2022
- 2022-03-03 CN CN202210208015.1A patent/CN114598567A/zh active Pending
Patent Citations (6)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN101299766A (zh) * | 2008-06-19 | 2008-11-05 | 中兴通讯股份有限公司 | 定位信息格式处理方法 |
CN106506307A (zh) * | 2016-12-22 | 2017-03-15 | 南京因泰莱电器股份有限公司 | 一种Modbus帧格式自描述方法 |
WO2021102691A1 (zh) * | 2019-11-26 | 2021-06-03 | Oppo广东移动通信有限公司 | 资源订阅方法、装置、计算机设备和存储介质 |
CN112001156A (zh) * | 2020-07-29 | 2020-11-27 | 中国银联股份有限公司 | 一种表单处理方法、装置及计算机可读存储介质 |
CN113489653A (zh) * | 2021-07-20 | 2021-10-08 | 深圳市元征未来汽车技术有限公司 | 报文发送方法、装置以及计算机设备 |
CN113837636A (zh) * | 2021-09-29 | 2021-12-24 | 平安养老保险股份有限公司 | 业务数据获取方法、装置、设备及存储介质 |
Cited By (4)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
WO2023231892A1 (zh) * | 2022-05-30 | 2023-12-07 | 华为技术有限公司 | 传输数据的方法和装置 |
CN115134186A (zh) * | 2022-06-29 | 2022-09-30 | 深圳市元征科技股份有限公司 | 数据处理方法以及相关设备 |
CN115001897A (zh) * | 2022-06-30 | 2022-09-02 | 阿波罗智能技术(北京)有限公司 | 通信方法、装置、电子设备及自动驾驶车辆 |
CN115001897B (zh) * | 2022-06-30 | 2024-03-15 | 阿波罗智能技术(北京)有限公司 | 通信方法、装置、电子设备及自动驾驶车辆 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
CN114598567A (zh) | 通信方法、设备及存储介质 | |
CN102594594B (zh) | 连接装置及其连接控制方法 | |
EP4099655A1 (en) | Software version rollback method, apparatus and system | |
CN113613953A (zh) | 车载更新装置、更新处理程序、及程序的更新方法 | |
JP7192415B2 (ja) | プログラム更新システム及び更新処理プログラム | |
CN113691623B (zh) | 车载Tbox的软件配置方法、装置及云端平台 | |
EA029338B1 (ru) | Система для передачи данных и способ передачи данных в транспортном средстве в составе транспортных средств | |
US20200117188A1 (en) | Autonomous driving control apparatus, vehicle having the apparatus, and method of controlling the apparatus | |
JP2006256457A (ja) | 車載データ管理装置、及び、車両情報供給システム | |
US20230179659A1 (en) | On-board relay device, information processing method, and program | |
CN114827184A (zh) | 车辆异常唤醒的处理方法、装置、车辆及云服务器 | |
US20070038337A1 (en) | Method for operating a network | |
CN113645097A (zh) | 车辆信号监测方法、终端设备及电子控制单元 | |
CN113992713A (zh) | 车云通信方法、装置、电子设备及存储介质 | |
CN113839847B (zh) | 车载通信方法、车载电子设备、车载通信系统和介质 | |
CN110731089A (zh) | 数据传输装置和一车辆用数据传输方法 | |
US20230004375A1 (en) | Vehicle-mounted update device, program, and program update method | |
CN113422738A (zh) | 一种智能主机的mcu通信服务方法 | |
CN116456301B (zh) | 一种程序刷写方法、装置、设备及存储介质 | |
WO2024026593A1 (zh) | 一种协同控车方法及相关装置 | |
CN116566905A (zh) | Can数据调度方法、装置、设备及可读存储介质 | |
CN107454574B (zh) | 设备到设备d2d的通信方法、装置和车联网终端 | |
US20230195445A1 (en) | On-board device, information processing method, and computer program | |
CN114449484A (zh) | 一种车载设备的管理方法、装置以及设备 | |
CN116781733A (zh) | 一种车载以太网DoIP节点车辆标识信息同步方法及车辆 |
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 |