结构在Loadrunner中的应用

2024-04-17 17:18
文章标签 应用 结构 loadrunner

本文主要是介绍结构在Loadrunner中的应用,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

结构在Loadrunner中的应用
 

 

版权声明:原创作品,如需转载,请与作者联系。


    在实际工作中,很多情况我们需要将不同类型的数据组织起来一起应用,比如:学校在期末考试结束后,通常都要进行学生成绩的填报和查询工作。一个一年级小学生的信息通常包括:姓名、学号、性别、年龄、语文成绩、数学成绩等。姓名、性别是一个字符类型的数据,而年龄、学号为整数类型,语文成绩、数学成绩通常都为单精度浮点类型数据。我们知道不同类型的数据是不能放到同一个数组里面的,那么在C语言中是否有方法将这些不同数据类别的数据组织到一起呢?回答是:“有,可以用结构来处理这种问题。”,接下来,就让我们来了解一下,什么叫结构。“结构”是一种构造类型,它是由若干“成员”组成的,每一个成员可以是一个基本数据类型或者又是一个构造类型。通常,一个结构的一般形式为:
struct 结构名
    {成员表列};
成员表列,由若干个成员组成,每个成员都是该结构的一个组成部分。对每个成员也必须作类型说明,其形式为:
类型说明符 成员名;
现在,让我们一起来给学生来定义一个“结构”
struct student
{
    int num;  //学号
    char name[20];      //姓名
    char sex[2];    //性别
       int  age;        //年龄
    float chinesescore;  //语文成绩
       float mathscore;     //数学成绩
};
上面我们定义了一个名称为“student”的结构,它包含了,学号、姓名、性别、年龄、语文成绩和数学成绩信息。
那么如何应用结构,在LoadRunner中应用结构的示例脚本如下:
struct student
{
    int num;  //学号
    char name[8]; //姓名
       int  age;        //年龄
    char sex[2];    //性别
    float chinesescore;  //语文成绩
       float mathscore;     //数学成绩
};

Action()
{  //为结构数组赋前2个结构数组元素值
       struct student stu[3]={{101,"孙悟空",30,"男",100.00,100.00},
                                             {102,"沙和尚",28,"男",99.00,99.00},};
       struct student stu1={103,"白骨精",99,"女"};  //为结构变量stu1赋部分数据
       int i;

       stu1.chinesescore=90.50;      //为stu1赋语文成绩
       stu1.mathscore=89.00;         //为stu1赋数学成绩

       stu[2]=stu1;    //将stu1变量赋给数组元素stu[2]

       for (i=0;i<=2;i++) {
              lr_output_message("-----------------------------");
              lr_output_message("第%d个学生信息:",i+1);
              lr_output_message("学号=%d",stu .num);
              lr_output_message("姓名=%s",stu.name);
              lr_output_message("性别=%s",stu.sex);
              lr_output_message("年龄=%d",stu.age);
              lr_output_message("语文成绩=%.2f",stu.chinesescore);
              lr_output_message("数学成绩=%.2f",stu.mathscore);
              lr_output_message("-----------------------------");
       }

      
       return 0;
}
上面脚本的输出内容为:
Running Vuser...
Starting iteration 1.
Starting action Action.
Action.c(24): -----------------------------
Action.c(25): 第1个学生信息:
Action.c(26): 学号=101
Action.c(27): 姓名=孙悟空
Action.c(28): 性别=男
Action.c(29): 年龄=30
Action.c(30): 语文成绩=100.00
Action.c(31): 数学成绩=100.00
Action.c(32): -----------------------------
Action.c(24): -----------------------------
Action.c(25): 第2个学生信息:
Action.c(26): 学号=102
Action.c(27): 姓名=沙和尚
Action.c(28): 性别=男
Action.c(29): 年龄=28
Action.c(30): 语文成绩=99.00
Action.c(31): 数学成绩=99.00
Action.c(32): -----------------------------
Action.c(24): -----------------------------
Action.c(25): 第3个学生信息:
Action.c(26): 学号=103
Action.c(27): 姓名=白骨精
Action.c(28): 性别=女
Action.c(29): 年龄=99
Action.c(30): 语文成绩=90.50
Action.c(31): 数学成绩=89.00
Action.c(32): -----------------------------
Ending action Action.
Ending iteration 1.
Ending Vuser...
当然,为了我们引用结构方便,您可以应用类型定义符“typedef”将“struct student”命名成简洁的、明了的名称。C语言允许由用户自己定义类型说明符,即:类型定义符“typedef”,允许由用户为数据类型取“别名”。上面的结构脚本,我们可以用“typedef”实现同样的功能。
typedef struct student
{
    int num;  //学号
    char name[8]; //姓名
       int  age;        //年龄
    char sex[2];    //性别
    float chinesescore;  //语文成绩
       float mathscore;     //数学成绩
} STU;

Action()
{     //为结构数组赋前2个结构数组元素值
       STU stu[3]={{101,"孙悟空",30,"男",100.00,100.00},
                                             {102,"沙和尚",28,"男",99.00,99.00},};
       STU stu1={103,"白骨精",99,"女"};//为结构变量stu1赋部分数据
       int i;

       stu1.chinesescore=90.50;      //为stu1赋语文成绩
       stu1.mathscore=89.00;         //为stu1赋数学成绩

       stu[2]=stu1;    //将stu1变量赋给数组元素stu[2]

       for (i=0;i<=2;i++) {
              lr_output_message("-----------------------------");
              lr_output_message("第%d个学生信息:",i+1);
              lr_output_message("学号=%d",stu.num);
              lr_output_message("姓名=%s",stu.name);
              lr_output_message("性别=%s",stu.sex);
              lr_output_message("年龄=%d",stu.age);
              lr_output_message("语文成绩=%.2f",stu.chinesescore);
              lr_output_message("数学成绩=%.2f",stu.mathscore);
              lr_output_message("-----------------------------");
       }

      
       return 0;
}
请大家注意黑体字部分,应用“typedef”后,您会发现在定义结构变量的时候,我们省略了“struct student”而用自定义的符号“STU”来声明相应变量即可,非常方便。还有一点,不知道您注意到没有,就是我们在定义的时候书写了这样的语句“STU stu[3]”,如果您在Delphi等语言中书写,它会提示您书写错误的,原因是这些语言是不区分大小写的,而在C语言中是区分大小写的,“STU”和“stu”分别代表两个不同的内容。

这篇关于结构在Loadrunner中的应用的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/912397

相关文章

Redis中Set结构使用过程与原理说明

《Redis中Set结构使用过程与原理说明》本文解析了RedisSet数据结构,涵盖其基本操作(如添加、查找)、集合运算(交并差)、底层实现(intset与hashtable自动切换机制)、典型应用场... 目录开篇:从购物车到Redis Set一、Redis Set的基本操作1.1 编程常用命令1.2 集

利用Python操作Word文档页码的实际应用

《利用Python操作Word文档页码的实际应用》在撰写长篇文档时,经常需要将文档分成多个节,每个节都需要单独的页码,下面:本文主要介绍利用Python操作Word文档页码的相关资料,文中通过代码... 目录需求:文档详情:要求:该程序的功能是:总结需求:一次性处理24个文档的页码。文档详情:1、每个

Java中的分布式系统开发基于 Zookeeper 与 Dubbo 的应用案例解析

《Java中的分布式系统开发基于Zookeeper与Dubbo的应用案例解析》本文将通过实际案例,带你走进基于Zookeeper与Dubbo的分布式系统开发,本文通过实例代码给大家介绍的非常详... 目录Java 中的分布式系统开发基于 Zookeeper 与 Dubbo 的应用案例一、分布式系统中的挑战二

Java 缓存框架 Caffeine 应用场景解析

《Java缓存框架Caffeine应用场景解析》文章介绍Caffeine作为高性能Java本地缓存框架,基于W-TinyLFU算法,支持异步加载、灵活过期策略、内存安全机制及统计监控,重点解析其... 目录一、Caffeine 简介1. 框架概述1.1 Caffeine的核心优势二、Caffeine 基础2

使用Node.js和PostgreSQL构建数据库应用

《使用Node.js和PostgreSQL构建数据库应用》PostgreSQL是一个功能强大的开源关系型数据库,而Node.js是构建高效网络应用的理想平台,结合这两个技术,我们可以创建出色的数据驱动... 目录初始化项目与安装依赖建立数据库连接执行CRUD操作查询数据插入数据更新数据删除数据完整示例与最佳

PHP应用中处理限流和API节流的最佳实践

《PHP应用中处理限流和API节流的最佳实践》限流和API节流对于确保Web应用程序的可靠性、安全性和可扩展性至关重要,本文将详细介绍PHP应用中处理限流和API节流的最佳实践,下面就来和小编一起学习... 目录限流的重要性在 php 中实施限流的最佳实践使用集中式存储进行状态管理(如 Redis)采用滑动

Vite 打包目录结构自定义配置小结

《Vite打包目录结构自定义配置小结》在Vite工程开发中,默认打包后的dist目录资源常集中在asset目录下,不利于资源管理,本文基于Rollup配置原理,本文就来介绍一下通过Vite配置自定义... 目录一、实现原理二、具体配置步骤1. 基础配置文件2. 配置说明(1)js 资源分离(2)非 JS 资

深入浅出Spring中的@Autowired自动注入的工作原理及实践应用

《深入浅出Spring中的@Autowired自动注入的工作原理及实践应用》在Spring框架的学习旅程中,@Autowired无疑是一个高频出现却又让初学者头疼的注解,它看似简单,却蕴含着Sprin... 目录深入浅出Spring中的@Autowired:自动注入的奥秘什么是依赖注入?@Autowired

PostgreSQL简介及实战应用

《PostgreSQL简介及实战应用》PostgreSQL是一种功能强大的开源关系型数据库管理系统,以其稳定性、高性能、扩展性和复杂查询能力在众多项目中得到广泛应用,本文将从基础概念讲起,逐步深入到高... 目录前言1. PostgreSQL基础1.1 PostgreSQL简介1.2 基础语法1.3 数据库

Python中的filter() 函数的工作原理及应用技巧

《Python中的filter()函数的工作原理及应用技巧》Python的filter()函数用于筛选序列元素,返回迭代器,适合函数式编程,相比列表推导式,内存更优,尤其适用于大数据集,结合lamb... 目录前言一、基本概念基本语法二、使用方式1. 使用 lambda 函数2. 使用普通函数3. 使用 N