LoadRunner脚本编写(3)

发表于:2014-09-15来源:uml.org.cn作者:不详点击数: 标签:loadrunner
下面来回顾一下嵌套循环例子。 Action() { int i,j; //生命两个变量 for (i=1;i=5;i++) //第一重循环,循环5次 { if (i==3) break; //当i等于3时,跳出本重循环 else lr_ou

  下面来回顾一下嵌套循环例子。

Action()
{
int i,j; //生命两个变量
for (i=1;i<=5;i++) //第一重循环,循环5次
{
if (i==3)
break; //当i等于3时,跳出本重循环
else
lr_output_message("i=%d",i); //否则,输入i的值

for (j=1;j<=5;j++) //第二重循环,循环5次
{
if (j==2)
break; //当j等于2时,跳出本重循环
else
lr_output_message("j=%d",j); //否则,输入j的值
}
}
}

  上面的代码中我加了注释,这里就不用再解释。

  运行结果:

Starting iteration 1.
Starting action Action.
Action.c(9): i=1
Action.c(16): j=1
Action.c(9): i=2
Action.c(16): j=1
Ending action Action.
Ending iteration 1.

  函数

  函数,通常 一小段C语言程序仅有一个main()函数组成。然而,在实际编写应用程序中,需要开发人员编写大量的用户自定交函数,不仅要在程序中定义函数本身,而且在主调函数模块中还必须对该被调函数进行类型说明,然后才能使用,与用户自定义函数相对应的是函数库,C语言集成开发环境(IDE)提供,我们只要调用就是行了。就就所谓前人种树,后人乘凉,不然看似一个简单的东西,寻其源头来做,都是一个相当复杂的过程。

void SsyHello() //打招呼函数
{
lr_output_message("hello %s",lr_get_host_name());
}

int GetBigger(int x,int y) //得到最大值函数
{
if (x>y) {
return x;
}
else{
return y;
}

}

Action(){
int x=10,y=20, result; //声明变量

SsyHello(); //无形参,无返回值函数
result = GetBigger(x,y);
lr_output_message("GetBigger(%d,%d)=%d",x,y,result); //带形参,带返回值函数

return 0;
}

  上面的程序加注解了,简单来说就是前面定义了两个函数SsyHello() 和 GetBigger(),主函数Action()对前面两个函数进行调用

  运行结果:

Starting iteration 1. Starting action Action. Action.c(4): hello 2011-20120624YO Action.c(23): GetBigger(10,20)=20 Ending action Action. Ending iteration 1.

  动态存储方式与静态存储方式

  我们在定义变量是,根据定义的位置不同,分为全局变量与局部变量。我出生在一个叫“舞阳”的小县城,在这个县城中也有人名“舞阳”,前一个作用于整个县城,后一个只作用于他个人。那么从变量值的存在生存期角度,又可分为静态存储方式和动态存储方式两类。

  静态存储方式:是指在程序运行期间分配固定的存储空间方式。

  动态存储方式:是在程序运行期间根据需要进行动态的分配存储空间的方式。

  用户存储空间可分三部分:

  1、程序区

  2、静态存储区

  3、动态存储区

  全局变量全部存放在静态存储区,在程序开始执行时给全局变量分配存储区,程序运行完毕就释放,在程序执行过程中它们占据固定的存储单元,而不动态地进行分配和释放。

  动态存储区存放以下数据:

  (1)函数形式参数

  (2)自动变量(未加static声明的局部变量)

  (3)函数调用时的现场保护和返回地址

  上面这些数据,在函数开始调用时分配动态空间,函数结果时释放这些空间。

  在C语言中,每个变量和函数有两个属性:数据类型和数据的存储类别

原文转自:http://www.uml.org.cn/Test/201303151.asp