【已解决】Java 中的可变参数应用

简介: 【已解决】Java 中的可变参数应用

🌈场景描述:在实际工作场景中遇到这样一个需求:根据筛选条件对某个模块进行查询,查询结果需要分页在前端页面显示,并将所有页的查询记录导出,生成 Excel 报表。


🌈问题描述:已经查询接口的参数需要包括:模块标识(指定对哪个模块进行查询)、查询字段(对模块的哪个字段进行查询)、查询字段值(用于精确或模糊匹配字段内容) 以及分页信息(Page);导出 Excel 报表接口的参数的主要参数除了查询接口中的分页信息以外,其他与查询接口参数一致。


🎉为了减少冗余代码的产生,这里采用 JDK 1.5 之后新增的可变函数(variable arguments),将查询接口方法中的分页信息参数(Page)设置为可变参数,在调用方法时忽略 Page 参数,直接返回所有记录的结果即可。


🌈下面,简单介绍一下 Java 中的可变参数:


🎉可变参数的应用场景:

🎉可变参数的应用场景

🏷在定义一个方法的时候,参数的类型确定,但是参数的个数不确定,只有在调用的时候才能够确定具体的参数个数,这个时候便考虑使用可变参数。

🎈可变参数的语法形式如下:

void method(DataType... var) {
  //方法体
}

🎉在上面的代码段中,DataType... var 就是在一个方法中将形参 var 定义为可变参数,用 ... 来表示。


🎉使用可变参数的注意事项:


🎈当有多个参数时,可变参数放在最后一个位置

🎈一个方法只能有一个可变参数

🎈每次使用可变参数时,Java 编译器都会创建一个数组来保存给定的参数,因此不可以直接对可变参数进行操作,要像操作数组一样操作可变参数

🎉下面的示例中,在主函数中调用一个求和函数,其中求和函数中的参数 a 就是一个可变参数

public final class Test {
    static void sumNum(int... a) {
        int sum = 0;
        for (int x : a) {
            sum += x;
        }
        System.out.println(sum);
    }
    public static void main(String[] args) {
        sumNum(1,2,3);
    }
}

🎉对程序就行 debug 调试运行,可以发现 a 其实是一个数组,这个数组的内容就是传入的实参值 1,2,3,即 a={1,2,3},下面是调试运行的截图2e718f6de6d94987ae2f2182c528d9c8.png

🎉下面给出在业务场景中将分页参数 Page 设置为可变参数的应用案列:

🎈查询接口方法实现

@Override
public ResponsePage queryModelData(String selectUnique, Object key, String type, 
                    String unique, boolean isMust, Page... page) {
   //此处省略100w行代码
   if (page.length > 0 && page[0] != null) {  //page是一个数组,也获得前端传入的分页信息,应该是获取page[0]
          query_model_field.skip(page[0].getPageNum());
          query_model_field.limit(page[0].getPageSize());
      }
      //此处省略100w行代码
      //根据是否传入分页信息情况,返回对应的结果(page.length>0表示传入了分页信息)
      return page.length > 0 ? ResponsePage.success(resourceVo, count, page[0]):ResponsePage.success(resourceVo, count, new Page());
}

🎈导出报表接口方法实现

public void exportModelExcel(ServletOutputStream outputStream, HttpServletResponse response, 
        String selectUnique, Object key, String keyType, String unique, boolean isMust) {
  //此处省略100w行代码
   ResourceVo resourceVo = (ResourceVo) queryModelData(selectUnique, key, keyType, unique, isMust).getData(); //复用查询接口,不分页返回根据条件筛选的查询结果
     List<Map> mapList = resourceVo.getData(); //获得查询结果列表
     //此处省略100w行代码
}

🎉正是得益于使用可变参数的便利,使得可以直接复用查询接口方法,减少了代码冗余,使方法整体更加简洁!

相关文章
|
16天前
|
安全 Java 调度
解锁Java并发编程高阶技能:深入剖析无锁CAS机制、揭秘魔法类Unsafe、精通原子包Atomic,打造高效并发应用
【8月更文挑战第4天】在Java并发编程中,无锁编程以高性能和低延迟应对高并发挑战。核心在于无锁CAS(Compare-And-Swap)机制,它基于硬件支持,确保原子性更新;Unsafe类提供底层内存操作,实现CAS;原子包java.util.concurrent.atomic封装了CAS操作,简化并发编程。通过`AtomicInteger`示例,展现了线程安全的自增操作,突显了这些技术在构建高效并发程序中的关键作用。
43 1
|
16天前
|
存储 SQL 缓存
揭秘Java并发核心:深度剖析Java内存模型(JMM)与Volatile关键字的魔法底层,让你的多线程应用无懈可击
【8月更文挑战第4天】Java内存模型(JMM)是Java并发的核心,定义了多线程环境中变量的访问规则,确保原子性、可见性和有序性。JMM区分了主内存与工作内存,以提高性能但可能引入可见性问题。Volatile关键字确保变量的可见性和有序性,其作用于读写操作中插入内存屏障,避免缓存一致性问题。例如,在DCL单例模式中使用Volatile确保实例化过程的可见性。Volatile依赖内存屏障和缓存一致性协议,但不保证原子性,需与其他同步机制配合使用以构建安全的并发程序。
49 0
|
12天前
|
机器学习/深度学习 人工智能 算法
AI入门必读:Java实现常见AI算法及实际应用,有两下子!
本文全面介绍了人工智能(AI)的基础知识、操作教程、算法实现及其在实际项目中的应用。首先,从AI的概念出发,解释了AI如何使机器具备学习、思考、决策和交流的能力,并列举了日常生活中的常见应用场景,如手机助手、推荐系统、自动驾驶等。接着,详细介绍了AI在提高效率、增强用户体验、促进技术创新和解决复杂问题等方面的显著作用,同时展望了AI的未来发展趋势,包括自我学习能力的提升、人机协作的增强、伦理法规的完善以及行业垂直化应用的拓展等...
97 3
AI入门必读:Java实现常见AI算法及实际应用,有两下子!
|
1天前
|
安全 前端开发 Java
随着企业应用复杂度提升,Java Spring框架以其强大与灵活特性简化开发流程,成为构建高效、可维护应用的理想选择
随着企业应用复杂度提升,Java Spring框架以其强大与灵活特性简化开发流程,成为构建高效、可维护应用的理想选择。依赖注入使对象管理交由Spring容器处理,实现低耦合高内聚;AOP则分离横切关注点如事务管理,增强代码模块化。Spring还提供MVC、Data、Security等模块满足多样需求,并通过Spring Boot简化配置与部署,加速微服务架构构建。掌握这些核心概念与工具,开发者能更从容应对挑战,打造卓越应用。
7 1
|
1天前
|
安全 Java 测试技术
深入探讨Java安全编程的最佳实践,帮助开发者保障应用的安全性
在网络安全日益重要的今天,确保Java应用的安全性成为了开发者必须面对的课题。本文介绍Java安全编程的最佳实践,包括利用FindBugs等工具进行代码审查、严格验证用户输入以防攻击、运用输出编码避免XSS等漏洞、实施访问控制确保授权访问、采用加密技术保护敏感数据等。此外,还强调了使用最新Java版本、遵循最小权限原则及定期安全测试的重要性。通过这些实践,开发者能有效提升Java应用的安全防护水平。
5 1
|
4天前
|
存储 设计模式 Java
Java中的if-else语句:深入解析与应用实践
Java中的if-else语句:深入解析与应用实践
|
9天前
|
存储 分布式计算 Java
Java在云计算中的应用如何?
Java在云计算中的应用如何?【8月更文挑战第11天】
18 4
|
10天前
|
消息中间件 负载均衡 Java
"Kafka核心机制揭秘:深入探索Producer的高效数据发布策略与Java实战应用"
【8月更文挑战第10天】Apache Kafka作为顶级分布式流处理平台,其Producer组件是数据高效发布的引擎。Producer遵循高吞吐、低延迟等设计原则,采用分批发送、异步处理及数据压缩等技术提升性能。它支持按消息键值分区,确保数据有序并实现负载均衡;提供多种确认机制保证可靠性;具备失败重试功能确保消息最终送达。Java示例展示了基本配置与消息发送流程,体现了Producer的强大与灵活性。
31 3
|
17天前
|
NoSQL Java Redis
Spring Boot集成Redis全攻略:高效数据存取,打造性能飞跃的Java微服务应用!
【8月更文挑战第3天】Spring Boot是备受欢迎的微服务框架,以其快速开发与轻量特性著称。结合高性能键值数据库Redis,可显著增强应用性能。集成步骤包括:添加`spring-boot-starter-data-redis`依赖,配置Redis服务器参数,注入`RedisTemplate`或`StringRedisTemplate`进行数据操作。这种集成方案适用于缓存、高并发等场景,有效提升数据处理效率。
72 2
|
22天前
|
存储 Java Serverless
Java Spring Boot应用如何实现推送代码到指定仓库并自动部署
函数计算产品作为一种事件驱动的全托管计算服务,让用户能够专注于业务逻辑的编写,而无需关心底层服务器的管理与运维。你可以有效地利用函数计算产品来支撑各类应用场景,从简单的数据处理到复杂的业务逻辑,实现快速、高效、低成本的云上部署与运维。以下是一些关于使用函数计算产品的合集和要点,帮助你更好地理解和应用这一服务。