知识改变命运:Java 语言 【可变参数】

可变参数

概念:Java允许一个类中多个同名同功能但是参数不同的方法,封装为一个方法。

java 复制代码
基本语法:
访问修饰符 返回值 方法名 (数据类型...参数名) {
......
}

案例:写一个类名DyMethod 方法名sum 计算两个整数和,三个整数和,四个整数和。

java 复制代码
public class DyMethod {
    public static void main(String[] args) {
        DyMethod s1=new DyMethod();
        s1.sum(1,2);
        s1.sum(1,2,3);
        s1.sum(1,2,3,4);
    }
    public int sum(int a,int b) {
        return  a+b;
    }
     public int sum(int a,int b,int c) {
        return  a+b+c;
    }
     public int sum(int a,int b,int c,int d) {
        return  a+b+c+d;
    }

}

我们上面代码可以使用重载的方法来实现,但是这样的代码特别无聊,他们完成的功能都是大同小异,如果我们要求5个,6个,甚至更多呢,接下来我们用可变参数优化下。

java 复制代码
public class DyMethod {
    public static void main(String[] args) {
        DyMethod s1 = new DyMethod();
        s1.sum(1, 2);
        s1.sum(1, 2, 3);
        s1.sum(1, 2, 3, 4);
    }

    public int sum(int... x) {
        int sum=0;
        for (int i = 0; i < x.length; i++) {
            sum+=x[i];
        }
        return sum;
    }
}
//int...表示可接受可变参数,类型是int,可接受(0到n个int值)
//可变参数x可以当作数组来使用,即x当作数组

这样我们就利用参编参数简化了代码

可变参数注意到事项和细节

1.可变参数的实参可以是0到多个

2.可变参数可以传参数组

java 复制代码
		int [] arr={1,2,3,4,5};
        System.out.println(s1.sum(arr));
 public int sum(int... x) {
        int sum=0;
        for (int i = 0; i < x.length; i++) {
            sum+=x[i];
        }
        return sum;
    }

3.可变参数实质是数组

4.可变参数可以跟其他普通类型参数一起出现,但是可变参数必须在参数最后

java 复制代码
public int sum(int a,Stuent... x)

5.一个方法里面只能有一个可变参数

java 复制代码
public int sum(int...a,Stuent... x)//报错

练习:有三个方法,返回姓名+2门成绩和,返回姓名+3门成绩和,返回姓名+4门成绩和,封装成一个方法。

java 复制代码
public String sum(String name,int...score) {
        int sum=0;
        for (int i = 0; i < score.length; i++) {
            sum+=score[i];
        }
        return "姓名"+name+"成绩"+sum;
    }
相关推荐
LuckyLay15 分钟前
1.1.2 运算符与表达式——AI教你学Django
python·django
学不会就看16 分钟前
Django--01基本请求与响应流程
后端·python·django
AI+程序员在路上19 分钟前
Qt6中模态与非模态对话框区别
开发语言·c++·qt
胚芽鞘6814 小时前
关于java项目中maven的理解
java·数据库·maven
nbsaas-boot5 小时前
Java 正则表达式白皮书:语法详解、工程实践与常用表达式库
开发语言·python·mysql
岁忧5 小时前
(LeetCode 面试经典 150 题 ) 11. 盛最多水的容器 (贪心+双指针)
java·c++·算法·leetcode·面试·go
仗剑_走天涯5 小时前
基于pytorch.nn模块实现线性模型
人工智能·pytorch·python·深度学习
chao_7895 小时前
二分查找篇——搜索旋转排序数组【LeetCode】两次二分查找
开发语言·数据结构·python·算法·leetcode
CJi0NG5 小时前
【自用】JavaSE--算法、正则表达式、异常
java
风无雨6 小时前
GO 启动 简单服务
开发语言·后端·golang