本文主要是介绍AUTOSAR_EXP_ARAComAPI的5章笔记(1),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
5.1 High Level API Structure
ara::com提供了一个支持AUTOSAR服务模型的API。服务有Method、Event、Filed和Trigger。
-
Method:在服务应用程序中执行一个可以返回值的函数(如校准方法)。
-
Event:当特定条件发生时(例如制动事件),服务应用程序发送一个事件(也可能包括一个值)。客户端应用程序可以订阅事件。
-
Filed:在任何时候都有一个值,比如状态值。可以使用Get读取或使用Set修改(例如,UpdateRate )。当Filed值改变时,可以通知客户端应用程序。
-
Trigger:当特定条件发生时,服务应用程序发送一个触发器。客户端应用程序可以订阅触发器。
如4.1节所述,客户端和服务应用程序相互通信,因此API支持双方的Method、Event和Field。这意味着API定义了发送和接收事件的接口,提供和调用服务方法,为Field的setter和getter注册处理程序等等。 ara::com API还定义了ctors/dtor来创建和销毁Proxy Class和Skeleton Class的实例。 最后,ara::com API还提供了提供/查找服务和订阅/取消订阅事件的方法。
5.2 API Elements
接下来的章节将会介绍ara::com定义的不同API元素。由于我们将给出各种工件的代码示例,并从开发人员的角度提供如何使用这些API的示例代码,因此在我们的示例中保持某种一致性是一个好主意。所以我们会使用一个叫做“RadarService”的虚拟服务(接口)。以下是一种半正式的描述,它让您对这个“RadarService”(服务接口)提供/做什么有一个印象,并且可能比正式的AutoSar Arxml 服务描述更容易阅读:
RadarService 的定义如下:
RadarService
{// types used within servicetype RadarObjects {active : boolobjects : array {elementtype: uint8size: variable}}type Position {x: uint32y: uint32z: uint32}// events provided by serviceevent BrakeEvent {type:RadarObjects}// fields provided by servicefield UpdateRate {type:uint32get: trueset: true}error CalibrationFailed {errorCode : 1errorContext {failureText : string}}error InvalidConfigString {errorCode : 2errorContext {invalidConfig : stringcurrentValidConfig : string}}// methods provided by servicemethod Calibrate{param configuration {type: stringdirection: in}param result {type: booldirection: out}raises {CalibrationFailedInvalidConfigString}}method Adjust {param target_position {type: Positiondirection: in}param success {type: booldirection: out}param effective_position {type: Positiondirection: out}}oneway method LogCurrentState {}}
因此,示例服务RadarService提供了一个Event: “BrakeEvent”,它由一个包含标志和uint8的可变长度数组结构组成。然后它提供了一个Fileld :“UpdateRate ”,它是uint32类型,支持get和set调用,最后RadarService又提供了如下三个方法:
-
方法“Adjust”,用于定位雷达,它包含一个目标位置作为输入参数和两个输出参数(一个表示定位成功,一个(可能偏离)有效位置)。
-
方法“Calibrate”,用于校准雷达,获得一个配置字符串作为输入参数,并返回一个成功指示符作为输出参数。如果校准失败,此方法可能会引发两种不同的应用程序错误:“校准失败”和“无效配置字符串”。
-
“LogCurrentState”方法是一种单向方法,这意味着如果该方法被执行,则不会向调用者返回任何反馈。它指示服务RadarService将其当前状态输出到其本地日志文件中。AUTOSAR_EXP_ARAComAPI的3章节笔记
这篇关于AUTOSAR_EXP_ARAComAPI的5章笔记(1)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!