Vector CANoe(8.0)软件CAPL工具之局部变量

标准C对局部变量的定义:函数中的每个局部变量只在函数被调用时存在,在函数执行完毕退出时消失。所以在函数存在多次调用时,局部变量是不会保持前次调用时的赋值。

标准C对用static声明的局部变量(静态变量)的定义:static类型的局部变量同上述一样,只能在该函数中使用,但不同的是,不管其所在函数是否被调用,它一直存在,不会随所在函数的被调用和退出而存在和消失,也即一直占着存储空间。

然而,笔者在使用CANoe软件的CAPL工具编写测试案例时发现,当一个函数存在多次调用时,其内部的局部变量却有着标准C静态变量的特性。声明如下四个函数TestFunc_1~4()进行说明:

void TestFunc_1(void)
{
    byte a = 1, b = 2;
    
    write("a == %d ; b == %d", a, b);
}

void TestFunc_2(void)
{
    byte c = 3, d = 4;
    c = 3;
    d = 4;
    
    write("c == %d ; d == %d", c, d);
}

void TestFunc_3(void)
{
    byte a = 1, b = 2;
    
    a = a+a;    // 2
    b = b+b;    // 4
    write("a == %d ; b == %d", a, b);
}

void TestFunc_4(void)
{
    byte c = 3, d = 4;
    c = 3;
    d = 4;
    
    c = c+c;    // 6
    d = d+d;    // 8
    write("c == %d ; d == %d", c, d);
}

可见函数TestFunc_1()和TestFunc_3()仅在定义时对局部变量进行了显式的初始化,而函数TestFunc_2()和TestFunc_4()除了在定义时对局部变量进行了显式的初始化,还额外用指令进行了显式的初始化函数TestFunc_1()和TestFunc_2()中除了定义变量和赋初值,未对变量进行其它赋值操作,而函数TestFunc_3()和TestFunc_4()中除了定义变量和赋初值,还对变量进行了加减后的赋值操作。

在主函数中对四个子函数均调用两次,以下右图即为打印结果。

Vector CANoe(8.0)软件CAPL工具之局部变量_第1张图片      Vector CANoe(8.0)软件CAPL工具之局部变量_第2张图片

显然,在第二次调用函数TestFunc_3()时,其局部变量a、b的初值并不是1、2,而是上一次调用退出时的值2、4,可见具有标准C静态变量的特性。

所以在编写程序时,建议定义局部变量之后,再单独进行显示的初始化。

 

-------------------------------------------------------------------------END--------------------------------------------------------------------------------

 

CAPL使用的语言类C,其数据类型如下(可在CAPL中按键盘F1索引Data types):

Vector CANoe(8.0)软件CAPL工具之局部变量_第3张图片

你可能感兴趣的:(前车之鉴,CANoe,CAPL,Vector,局部变量,静态变量)