Java教程

Java-方法

本文主要是介绍Java-方法,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!

一、什么是方法?

  • System.out.println()

    • System > 系统的类文件
    • out > 该类的对象
    • println() 系统类中定义的方法
  • Java方法是语句的集合,它们在一起执行一个功能

    • 方法是解决一类问题的步骤的有序组合
    • 方法包含于类中或对象中
    • 方法在程序中被创建,在其他地方被引用
  • 设计方法的原则:

    • 方法的本意是功能块 > 类似于C语言中的函数

      就是实现某个功能的语句块的集合

    • 我们设计的方法最好保持方法的原子性

      即:一个方法只完成一个功能,这样有利于后期的扩展

  • 方法的命名原则:

    • 首字母小写
    • 驼峰原则

二、方法的定义

  • Java的方法类似于其它语言的函数,是一段用来完成特定功能的代码片段

  • 一般情况下,一个方法包含以下语法:

    • 方法包含一个方法头和一个方法体

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

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

      • 方法名: 方法的实际名称,方法名和参数共同构成方法签名

      • 参数类型: 参数类似一个占位符,当方法被调用时,传递值给参数,这个值被称为实参 / 变量,参数列表是指方法的参数类型、顺序和参数的个数;参数是可选的,一个方法可以步包含任何参数

        • 形式参数(形参):在方法被调用时用于接收外界输入的数据
        • 实参:调用方法时实际传给方法的数据
      • 方法体:方法体包括具体的语句,定义该方法的功能

        // 修饰符  返回值类型 方法名 (参数类型 参数名)
        public static int add(int a, int b){
            // ...
            //  方法体
            // ......
            return a+b;// 返回值
          
        }
        

三、方法重载

  • 重载:在一个类中,有相同的函数名称,但形参不同的函数
  • 方法的重载规则:
    • 方法名称必须不同(个数不同、或类型不同、参数排列顺序不同)
    • 方法的返回类型可以相同,也可以不同
    • 仅仅返回类型不同不足以成为方法的重载
  • 实现理论:
    • 方法名称相同时,编译器会根据调用方法的参数个数、参数类型等去逐个匹配,以选择对应的方法;如果匹配失败,则编译器报错。

四、命令行传参【不常用】

  • 有时候我们希望运行一个程序的时候再传递消息给他

    这要靠传递命令行参数给main()函数来实现

    public class CommandLine {
        public static void main (String args[]) {
            for (int i = 0;i<args.length;i++){
                System.out.println("args[" + i + "]: " + args[i]);
            }
        }
    }
    
  • 编译.java文件 => javac

  • 执行.class文件 => java

    返回上一级目录 回到/src目录才能执行java命令 => **cd ../ **

  • 通过命令行传递参数

五、可变参数 / 不定项参数

  • 从JDK1.5开始,Java支持传递同类型的可变参数给一个方法

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

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

public static void printMax(double... numbers) {
        if (numbers.length == 0){
            System.out.println("没有参数传入!");
            return;
        }

        double result = numbers[0];

        // 排序
        for (int i = 1; i < numbers.length; i++) {
            if (numbers[i] > result) {
                result = numbers[i];
            }
        }
        System.out.println("最大值为:" + result);
    }

六、递归

  • 递归是指:A方法调用A方法 即自己调用自己
  • 利用递归可以用简单的程序来解决一些复杂的问题。
  • 通常把一个大型、复杂的问题层层转化为一个与原问题相似的、规模较小的问题来求解,递归策略只需少量的程序就可描述出解题过程所需要的多次重复计算,大大减少了程序的代码量。
  • 递归的能力在于用有限的语句来定义对象的无限集合
  • 递归结构包括两部分
    • 递归头:什么时候不调用自身方法?【ps: 如果没有头,将陷入死循环】
    • 递归体:什么时候需要调用自身方法
这篇关于Java-方法的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!