当前位置: 首页 > news >正文

LR C语言语句复习,几个简单代码

嵌套循环

Action()
{
    int i,j;
    for(i=1;i<=5;i++)
    {
        if(i==3)
           beark;
        else
           lr_output_message("i=%d",i);
        
        for(j=1;j<=5;j++)
        {
            if(j==2)
                break;
            else
            lr_output_message("j=%d",j); 
        
        }
    
    }

}

运行结果

虚拟用户脚本已从 : 2016-05-16 16:12:34 启动
正在开始操作 vuser_init。
Windows 7 版 LoadRunner 11.0.0 的 Web Turbo 重播; 内部版本 8859 (Aug 18 2010 20:14:31)      [MsgId: MMSG-27143]
Run Mode: HTML      [MsgId: MMSG-26000]
运行时设置文件: "C:\Users\246\AppData\Local\Temp\无名称1\\default.cfg"      [MsgId: MMSG-27141]
正在结束操作 vuser_init。
正在运行 Vuser...
正在开始迭代 1。
正在开始操作 Action。
Action.c(9): i=1
Action.c(16): j=1
Action.c(9): i=2
Action.c(16): j=1
正在结束操作 Action。
正在结束迭代 1。
正在结束 Vuser...
正在开始操作 vuser_end。
正在结束操作 vuser_end。
Vuser 已终止。

函数调用

函数,通常 一小段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(int x,int y)函数,并在Action()中调用这两个函数

其中,lr_get_host_name()为LR自带函数,用来显示当前主机名,运行结果如下:

虚拟用户脚本已从 : 2016-05-16 16:35:11 启动
正在开始操作 vuser_init。
Windows 7 版 LoadRunner 11.0.0 的 Web Turbo 重播; 内部版本 8859 (Aug 18 2010 20:14:31)      [MsgId: MMSG-27143]
Run Mode: HTML      [MsgId: MMSG-26000]
运行时设置文件: "C:\Users\246\AppData\Local\Temp\无名称1\\default.cfg"      [MsgId: MMSG-27141]
正在结束操作 vuser_init。
正在运行 Vuser...
正在开始迭代 1。
正在开始操作 Action。
Action.c(4): hello lt
Action.c(23): GetBigger(10,20)=20
正在结束操作 Action。
正在结束迭代 1。
正在结束 Vuser...
正在开始操作 vuser_end。
正在结束操作 vuser_end。
Vuser 已终止。

动态存储方式和静态存储方式

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

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

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

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

1、程序区

2、静态存储区

3、动态存储区

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

   动态存储区存放以下数据

(1)函数形式参数

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

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

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

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

* 自动(auto)变量

函数中的局部变量,如不专门的声明为static存储类别,都是动态地分配存储空间的。

* 静态(static)声明局部变量

有时希望函数中的局部变量的值在函数调用结束后不消失而保留,这时就应该指定局部变量为“静态局部变量”,用static关键字。

*  寄存器(register)变量

为了提高效率,C语言允许把局部变量的值放在CPU中的寄存器中,这种变量叫“寄存器变量”,用关键字register变量。

static int c;

int prime(register int number)   //判断是否为素数
{
    register int flag=1;
    auto int n;
    for (n=2;n<number/2 && flag==1;n++) {
        if (number % n==0) flag=0;
    return(flag);    
        
    }
}

demo(int a)    //static、auto变量的演示函数
{
    auto int b=0;
    int d;
    static c=3;
    b=b+1;
    c=c+1;
    lr_output_message("demo()函数中的b=%d",b);
    lr_output_message("demo()函数中的static c=%d",c);
    return a+b+c;

}
Action(){
    int a=2,i;   //变量声明

    for (i=0;i<3;i++) {
        lr_output_message("demo()函数部分第%d运行情况如下:",i+1);
        lr_output_message("函数demo运行结果为:%d",demo(a));
        lr_output_message("-------------------\n\r");
    }

    //判断13是否为素数,并输出提示信息
    if (prime(13)==0)
        lr_output_message("13不是素数!");
    else
        lr_output_message("13是素数!");

    lr_output_message("c=%d",c);  //输入变理的值,注意局部静态变量的值不能被其它函数调用,保存的只是多次调用同一函数时数值不需要初始化。初值为0

     
    return 0;
}

运行结果如下:

虚拟用户脚本已从 : 2016-05-16 17:13:19 启动
正在开始操作 vuser_init。
Windows 7 版 LoadRunner 11.0.0 的 Web Turbo 重播; 内部版本 8859 (Aug 18 2010 20:14:31)      [MsgId: MMSG-27143]
Run Mode: HTML      [MsgId: MMSG-26000]
运行时设置文件: "C:\Users\246\AppData\Local\Temp\无名称1\\default.cfg"      [MsgId: MMSG-27141]
正在结束操作 vuser_init。
正在运行 Vuser...
正在开始迭代 1。
正在开始操作 Action。
Action.c(30): demo()函数部分第1运行情况如下:
Action.c(21): demo()函数中的b=1
Action.c(22): demo()函数中的static c=4
Action.c(31): 函数demo运行结果为:7
Action.c(32): -------------------

Action.c(30): demo()函数部分第2运行情况如下:
Action.c(21): demo()函数中的b=1
Action.c(22): demo()函数中的static c=5
Action.c(31): 函数demo运行结果为:8
Action.c(32): -------------------

Action.c(30): demo()函数部分第3运行情况如下:
Action.c(21): demo()函数中的b=1
Action.c(22): demo()函数中的static c=6
Action.c(31): 函数demo运行结果为:9
Action.c(32): -------------------

Action.c(39): 13是素数!
Action.c(41): c=0
正在结束操作 Action。
正在结束迭代 1。
正在结束 Vuser...
正在开始操作 vuser_end。
正在结束操作 vuser_end。
Vuser 已终止。

指针

指针是C语言中广泛使用的一种数据类型,指针可以使我们的程序变得非常灵活,但也让不少程序员头痛,一不小心就会使程序出错。

指针一般指向一个函数或一个变量。在使用一个指针时,一个程序既可以直接使用这个指针所储存的内存地址,又可以使用这个地址里储存的变量或函数的值。 

有一本很厚小说,为了便于读者找到某一段内容,我们会给某一段内容起一个小标题并标注上页数。这样找起来就非常方便了。那在内存中,小标题页数就相当于内存单元的指针,具体的小说内容就是内存单元的内容。

Action(){
    int score[5]={100,98,78,55};   //一维数组
    int *p=score;         //一维数组指针
    int sixnum[2][3]={{1,2,3},{4,5,6}};  //二维数组
    int (*p1)[3];        //二维数组指针
    int i,j;      //定义两个变量

    for (i=0;i<=4;i++) {
        lr_output_message("score[%d]=%d",i,score[i]);  //以下标形式标识数组
        lr_output_message("*(p++)=%d",*(p++));   //以指针方式输出数组
    }
    lr_output_message("--------------------------");

    p=score;
    for (i=0;i<=4;i++) {
        lr_output_message("score[%d]=%d",i,score[i]);  //以下标形式标识数组
        lr_output_message("*(p+%d)=%d",*(p+i));   //以指针方式输出数组
    }
    lr_output_message("--------------------------");

    p1=sixnum;
    for (i=0;i<=1;i++) {
        for (j=0;j<=2;j++) {
             lr_output_message("sixnum[%d][%d]=%d",i,j,sixnum[i][j]);   //以下标形式标识数组
             lr_output_message("*(*(p1+%d)+%d)=%d",*(*(p1+i)+j));  //以指针方式输出数组
        }

    }
    
    return 0;
}

运行结果如下:

虚拟用户脚本已从 : 2016-05-16 17:46:44 启动
正在开始操作 vuser_init。
Windows 7 版 LoadRunner 11.0.0 的 Web Turbo 重播; 内部版本 8859 (Aug 18 2010 20:14:31)      [MsgId: MMSG-27143]
Run Mode: HTML      [MsgId: MMSG-26000]
运行时设置文件: "C:\Users\246\AppData\Local\Temp\无名称1\\default.cfg"      [MsgId: MMSG-27141]
正在结束操作 vuser_init。
正在运行 Vuser...
正在开始迭代 1。
正在开始操作 Action。
Action.c(9): score[0]=100
Action.c(10): *(p++)=100
Action.c(9): score[1]=98
Action.c(10): *(p++)=98
Action.c(9): score[2]=78
Action.c(10): *(p++)=78
Action.c(9): score[3]=55
Action.c(10): *(p++)=55
Action.c(9): score[4]=0
Action.c(10): *(p++)=0
Action.c(12): --------------------------
Action.c(16): score[0]=100
Action.c(17): *(p+100)=0
Action.c(16): score[1]=98
Action.c(17): *(p+98)=0
Action.c(16): score[2]=78
Action.c(17): *(p+78)=0
Action.c(16): score[3]=55
Action.c(17): *(p+55)=0
Action.c(16): score[4]=0
Action.c(17): *(p+0)=0
Action.c(19): --------------------------
Action.c(24): sixnum[0][0]=1
Action.c(25): *(*(p1+1)+0)=49735464
Action.c(24): sixnum[0][1]=2
Action.c(25): *(*(p1+2)+0)=49735464
Action.c(24): sixnum[0][2]=3
Action.c(25): *(*(p1+3)+0)=49735464
Action.c(24): sixnum[1][0]=4
Action.c(25): *(*(p1+4)+0)=49735464
Action.c(24): sixnum[1][1]=5
Action.c(25): *(*(p1+5)+0)=49735464
Action.c(24): sixnum[1][2]=6
Action.c(25): *(*(p1+6)+0)=49735464
正在结束操作 Action。
正在结束迭代 1。
正在结束 Vuser...
正在开始操作 vuser_end。
正在结束操作 vuser_end。
Vuser 已终止。

 

转载于:https://www.cnblogs.com/zhuzhutest/p/5498933.html

相关文章:

  • 符号表
  • 动态生成服务器控件
  • Linux下s3c-2410开发环境的搭建
  • HDOJ/HDU 2567 寻梦(字符串简单处理)
  • C# 设置Excel打印选项及打印excel文档
  • 软件工程之软件项目管理
  • 时间管理
  • Linux_RHEL7_LDAP、Autofs服务
  • Oracle权限(二)权限相关的动态性能视图与数据字典视图
  • 线程的实现
  • Java 动态生成复杂 Word
  • Competition-based User Expertise Score Estimation-20160520
  • 地址转换协议ARP
  • netstat -aon|findstr 8888 终止进程
  • 判断jQuery元素是否隐藏
  • 【划重点】MySQL技术内幕:InnoDB存储引擎
  • 11111111
  • cookie和session
  • C学习-枚举(九)
  • ES6核心特性
  • jdbc就是这么简单
  • Js基础知识(四) - js运行原理与机制
  • learning koa2.x
  • leetcode-27. Remove Element
  • leetcode46 Permutation 排列组合
  • oldjun 检测网站的经验
  • Python进阶细节
  • Spring-boot 启动时碰到的错误
  • spring学习第二天
  • 翻译:Hystrix - How To Use
  • 干货 | 以太坊Mist负责人教你建立无服务器应用
  • 跨域
  • 免费小说阅读小程序
  • 模型微调
  • 前端每日实战 2018 年 7 月份项目汇总(共 29 个项目)
  • 前端面试之CSS3新特性
  • 如何利用MongoDB打造TOP榜小程序
  • 数据库写操作弃用“SELECT ... FOR UPDATE”解决方案
  • 一个JAVA程序员成长之路分享
  • 运行时添加log4j2的appender
  • 正则表达式小结
  • 智能网联汽车信息安全
  • scrapy中间件源码分析及常用中间件大全
  • 第二十章:异步和文件I/O.(二十三)
  • 容器镜像
  • !! 2.对十份论文和报告中的关于OpenCV和Android NDK开发的总结
  • # Apache SeaTunnel 究竟是什么?
  • #HarmonyOS:基础语法
  • #多叉树深度遍历_结合深度学习的视频编码方法--帧内预测
  • (03)光刻——半导体电路的绘制
  • (04)Hive的相关概念——order by 、sort by、distribute by 、cluster by
  • (11)MATLAB PCA+SVM 人脸识别
  • (173)FPGA约束:单周期时序分析或默认时序分析
  • (二)斐波那契Fabonacci函数
  • (二)基于wpr_simulation 的Ros机器人运动控制,gazebo仿真