day.7

day.7,第1张

day.7

1.方法的基础认识

java方法是语句的集合,它们在一起执行一个功能。方法是解决一类问题的步骤的有序组合,包含于类或者对象中,方法在程序中被创建,在其他地方被引用。

#方法的定义

java的方法类似于其他语言的函数,是一段用来完成待定功能的代码片段,一般情况下,定义一个方法含以下语法:

方法含有一个方法头跟一个方法体;下面是一个方法的所以部分:

修饰符:(是可选的)告诉编译器如何调用该方法,定义方法的访问类型

返回值类型:方法可能会返回值。returnValueType是方法返回值的数据类型。有些方法执行所需的 *** 作,但没有返回值。在这种情况下,returnValueType是关键字void。

方法名:是方法的实际名称。方法名和参数表共同构成方法签名。

参数类型:参数像是一个占位符。当方法被调用时,传递值给参数。这个值被称为实参或变量。参数列表是指方法的参数类型、顺序和参数的个数。参数是可选的,方法可以不含任何参数(无参方法)

形式参数:在方法被调用时用于接收外界输入的数据。

实参:调用方法时实际传给方法的数据

方法体:方法体包含具体的语句,定义改方法的功能。

#方法语法

修饰符(可选)  返回值类型  方法名(参数类型 参数名(可选)){

....

方法体

....

return 返回值;

}

#设计原则

方法本意是功能块,就是为了实现某个功能的语句块的集合,我们设计方法的时候,最好保持方法的原子性,就是一个方法只完成一个功能,这样有利于我们后期的扩展。

解析System.out.println();

system是一个类

out是一个对象

println()是一个方法

#方法调用

调用方法:对象名.方法名(实参列表)

java支持两种调用调用方法的方式,根据是否返回值来选择。

当方法返回一个值的时候,方法调用通常当做一个值。例如:

int larger=max(30,40);

如果方法返回值是void,方法调用一定是一条语句。

System.out.println("helloworld");

#值传递

(java只有值传递)是指在调用函数时将实际参数复制一份传递到函数中,这样在函数中如果对参数进行修改,将不会影响到实际参数。如果数据比较多的时候,因为都是复制,会影响效率。

#引用传递

是指在调用函数时将实际参数的地址直接传递到函数中,那么在函数中对参数所进行的修改,将影响到实际参数。速度比较快。

public class Demo01 {
    public static void main(String[] args) {//main方法
        //void是返回值类型,void即是不返回值
        add(3,4);(实参传入)//静态方法直接使用
        Demo01 d1=new Demo01();//非静态方法需要实际化对象
        d1.jifa(2,1);
    }
    //加法
    public static int add(int a,int b)(形参){//加static变静态方法能直接调用
        return a+b;
    }
    public int jifa(int a,int b){//非静态的方法需要先实际化对象才能使用
        return a-b;
    }
}

2.方法的重载

重载就是在一个类中,有相同的函数名称,但形参不同的函数。

#重载规则:

方法名称必须相同

参数列表必须不同(个数不同  或  数据类型不同  或  参数排列顺序不同等)

方法的返回类型可以相同也可以不相同

仅仅返回类型不同不足以成为方法的重载

add(1.0,2.0);l
add(3,4);//类型不同
add(3,4,5);//参数数量不同
public static int add(int a,int b){
    return a+b;
}
public static int add(int a,int b,int c){
    return a+b+c;
}
public static double add(double a,double b){
    return a+b;

#实现理论

方法名称相同的时候,编译器会根据调用方法的参数个数、参数类型等逐个匹配,以选择对应的方法,如果匹配失败,则编译器错误。


3.可变参数

jdk1.5开始,java支持传递同类型的可变参数给一个方法

在方法声明中,在指定参数类型后加一个省略号(...)。

在一个方法中只能指定一个可变参数,它必须是方法的最后一个参数。任何普通的参数必须在它声明之前

public class Demo04 {
    public static void main(String[] args) {
        Demo04 di=new Demo04();
        di.method(1,2);
    }
    public void method(int ...i){
        System.out.println(i[0]);
    }
}

4.递归

递归就是A方法调用A方法!就是自己调用自己。(如果递归多了会影响计算机性能)

利用递归可以用简单的程序来解决一些复杂的问题。它通常把一个大型复杂的问题层层转化为一个与原问题相似的较小规模的问题来解决,递归策略只需少量的程序就可以描述出解题过程所需要的多次重复计算,大大地减少了程序的代码量。递归的能力在于用于有限的语句来定义对象的无限集合。

#递归结构包括两个部分

递归头:什么时候不调用自身方法。如果没有头,将陷入死循环。

递归体:什么时候需要调用自身方法。
 

 main-f(5)...f(1)-f(2)...f(5)-main

public class Demo05 {//求n的阶乘
    public static void main(String[] args) {
        int i=test(5);
        System.out.println(i);
    }
    public static int test(int n){
        if(n==1){
            return 1;
        }else{
            return n*test(n-1);
        }
    }
}

栈机制(后进后出):跟洗碗一样,一个一个先洗一次然后叠起来,然后在拿出来的时候,最上面开始拿,然后一个一个拿出来再洗。

欢迎分享,转载请注明来源:内存溢出

原文地址: https://outofmemory.cn/zaji/5686753.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-12-17
下一篇 2022-12-17

发表评论

登录后才能评论

评论列表(0条)

保存