初识“方法”,步入编程领域 | 带你学《Java编程入门》之六

简介: 在程序之中很多情况下是有可能需要重复执行一些代码的。在有一些书上也会把方法(method)称为函数(function)。需要注意一点,本次进行方法定义的时候有一个前提:方法在主类中定义,并且由主方法直接调用。

上一篇:带你学《Java编程入门》之五:“直线、分叉、圆圈”--程序逻辑之争
【本节目标】
本章主要讲的是方法的定义与使用,要求学完之后掌握方法的名称与变量的定义命名要求,学会方法的重载,知道并了解方法的递归调用。

6.1 方法的基本定义

方法是定义在主类之中并且由主方法直接调用的,所以方法的定义语法形式如下:

public static 返回值类型 方法名称([参数类型 变量,....]) {
    // 该方法要执行的代码
    [return [返回值] ;]
}

对于返回值而言就可以使用Java中定义的数据类型了(基本数据类型、引用数据类型)。在方法之中可以进行返回数据的处理,如果要返回数据则可以使用我们的return来描述,return所返回的数据类型与方法的返回值类型相同,如果不返回数据,则该方法上可以使用void进行声明。
关于方法名称与变量的定义命名要求:

  • 在进行方法名称定义的时候要求第一个单词的字母小写,而后每个单词的首字母大写。
  • 在进行变量名称定义的时候要求第一个单词的字母小写,而后每个单词的首字母大写。

范例:定义一个无参无返回值的方法

public class JavaDemo {
    public static void main(String args[]) {
        printMessage() ;    // 执行方法调用
        printMessage() ;    // 执行方法调用
    }
    public static void printMessage() {    // 该方法包含了三行代码
        System.out.println("**************************") ;
        System.out.println("*     www.mldn.cn        *") ;
        System.out.println("**************************") ;
    }
}

image.png
图一 运行结果一

方法的本质就是方便使用者进行重复的调用,并且所有程序一定是通过主方法开始执行的。
范例:定义一个有参有返回值的方法

public class JavaDemo {
    public static void main(String args[]) {
        String result = get(20.0) ;
        System.out.println(result) ;
        System.out.println(get(1.0)) ;    // 返回值可以直接输出
    }
    public static String get(double money) {
        if (money >= 10.0) {
            return "给你带一份快餐,找零:" + (money - 10.0) ;
        } else {
            return "对不起,您的余额不足,请先充值,或者捡漏。" ;
        }
    }
}

image.png
图二 运行结果二

在我们进行方法定义的时候,如果方法的返回值类型为void,那么可以利用return来结束调用。
范例:使用return结束方法调用

public class JavaDemo {
    public static void main(String args[]) {
        sale(3) ;
        sale(-3) ;
    }
    public static void sale(int money) {
        if (money <= 0) {    // 余额不足
            return ;    // 后续代码不执行了
        }
        for (int x = 1 ; x <= money ; x ++) {
            System.out.println("王健开笑,第" + x + "次") ;
        }
    }
}

image.png
图三 运行结果三

如果从定义的语法来讲,方法并不是一个难以理解的概念,就是一段可以被重复调用的一块代码而已。但是我们良好的方法设计是需要根据实际开发经验慢慢累积的,但是请千万记住一点:在Java定义方法的时候一般都不会太长。

6.2 方法的重载

方法重载的定义:当方法名称相同,参数类型或个数不同的时候就称为方法重载。
那么先通过程序来做一个简单的分析,现在定义一个加法处理方法,该方法可以接收两个int变量、三个int变量、两个double变量的加法处理。
范例:采用方法重载进行定义

public class JavaDemo {
    public static void main(String args[]) {
        int resultA = sum(10,20) ;     // 调用两个int参数的方法
        int resultB = sum(10,20,30);    // 调用三个int参数的方法
        double resultC = sum(10.2,20.3) ;
        System.out.println("加法执行结果:" + resultA) ;
        System.out.println("加法执行结果:" + resultB) ;
        System.out.println("加法执行结果:" + resultC) ;
    }
    public static int sum(int x,int y) {
        return x + y ;
    }
    public static int sum(int x,int y,int z) {
        return x + y + z ;
    }
    public static double sum(double x,double y) {
        return x + y ;
    }
}

image.png
图四 运行结果四

这个时候可以发现同一个方法名称但是可以根据调用时传递的不同参数的类型或个数实现不同方法体的调用,这样就实现了方法重载的定义。
注意:方法的重载与方法的返回值类型没有任何关系,它只跟参数有关系,但是在实际的开发中要把握一个基本的开发原则:只要是方法重载,强烈建议其返回值类型相同。
范例:观察一个程序代码

public class JavaDemo {
    public static void main(String args[]) {
System.out.println(1) ;
      System.out.println(1.1) ;
      System.out.println(true) ;
      System.out.println(‘A’) ;
      System.out.println("Hello World !") ;
}
}

可以发现,所有的输出操作支持有各种数据类型,所以System.out.println();本身就属于一个方法重载。

6.3 方法递归调用

方法的递归调用指的是一个方法自己调用自己的情况,利用递归调用可以解决一些重复且麻烦的问题。在进行方法递归调用的时候一般需要考虑如下几点问题:

  • 一定要设置方法递归调用的结束条件;
  • 每一次调用的过程之中一定要修改传递的参数条件。

范例:实现一个1~100的累加
使用while循环实现:

public class JavaDemo {
    public static void main(String args[]) {
        int sum = 0 ;
        int x = 1 ;
        while (x <= 100) {    // 循环的结束条件
            sum += x ;
            x ++ ;        // 修改每一次循环的变量
        }
        System.out.println(sum) ;  //执行结果:5050
    }
}

使用递归:

public class JavaDemo {
    public static void main(String args[]) {
        System.out.println(sum(100)) ;
    }
    public static int sum(int num) {    // 执行累加
        if (num == 1) {    // 不累加了
            return 1 ;
        }
        return num + sum(num - 1) ;    // 递归调用
    }
}

下面对此代码进行简单分析处理:

 【第1次执行sum()、主方法执行】return 100+sum(99);
 【第2次执行sum()、sum()递归调用】return 99+sum(98);
  …………
 【第99次执行sum()、sum()递归调用】return 2+sum(1);
 【第100次执行sum()、sum()递归调用】return 1;

整体形式:return 100+99+98……+2+1;递归操作虽然可以简化调用,但是在实际的开发中,目前所编写的代码很少出现有递归的情况。大部分情况下考虑的都只是简单的处理逻辑。递归少去使用的另外一个原因:如果处理不当,则会造成内存溢出。
范例:计算“1!+2!+3!+4!+5!+……90!”

public class JavaDemo {
    public static void main(String args[]) {
        System.out.println(sum (90)) ;     
    }
    public static double sum(int num) {
        if (num == 1) {
            return 1 ;
        }
        return fan(num) + sum(num - 1) ;
    }
    public static double fan(int num) {    // 执行累加
        if (num == 1) {    // 不累加了
            return 1 ;
        }
        return num * fan(num - 1) ;    // 递归调用
    }
}

image.png
图五 运行结果五

在进行阶乘计算的时候必须要考虑选择的数据类型,肯定不能够使用int,只能够使用double。
实际上有一部分递归是可以通过循环来完成的,但是如果使用递归要比使用循环结构看起来更加清晰一些。
想学习更多的Java的课程吗?从小白到大神,从入门到精通,更多精彩不容错过!免费为您提供更多的学习资源。
本内容视频来源于阿里云大学
更多Java入门编程文章查看此处

相关文章
|
13天前
|
Java
Java中ReentrantLock中tryLock()方法加锁分析
Java中ReentrantLock中tryLock()方法加锁分析
12 0
|
2天前
|
Java 关系型数据库 MySQL
Elasticsearch【问题记录 01】启动服务&停止服务的2类方法【及 java.nio.file.AccessDeniedException: xx/pid 问题解决】(含shell脚本文件)
【4月更文挑战第12天】Elasticsearch【问题记录 01】启动服务&停止服务的2类方法【及 java.nio.file.AccessDeniedException: xx/pid 问题解决】(含shell脚本文件)
23 3
|
12天前
|
安全 算法 Java
深入理解Java并发编程:线程安全与性能优化
【4月更文挑战第11天】 在Java中,高效的并发编程是提升应用性能和响应能力的关键。本文将探讨Java并发的核心概念,包括线程安全、锁机制、线程池以及并发集合等,同时提供实用的编程技巧和最佳实践,帮助开发者在保证线程安全的前提下,优化程序性能。我们将通过分析常见的并发问题,如竞态条件、死锁,以及如何利用现代Java并发工具来避免这些问题,从而构建更加健壮和高效的多线程应用程序。
|
4天前
|
存储 Java
Java动态转发代理IP的实现方法
Java动态转发代理IP的实现方法
20 11
|
4天前
|
IDE Java 物联网
《Java 简易速速上手小册》第1章:Java 编程基础(2024 最新版)
《Java 简易速速上手小册》第1章:Java 编程基础(2024 最新版)
11 0
|
5天前
|
安全 Java 开发者
Java并发编程:深入理解Synchronized关键字
【4月更文挑战第19天】 在Java多线程编程中,为了确保数据的一致性和线程安全,我们经常需要使用到同步机制。其中,`synchronized`关键字是最为常见的一种方式,它能够保证在同一时刻只有一个线程可以访问某个对象的特定代码段。本文将深入探讨`synchronized`关键字的原理、用法以及性能影响,并通过具体示例来展示如何在Java程序中有效地应用这一技术。
|
5天前
|
Java
Java接口中可以定义哪些方法?
【4月更文挑战第13天】
7 0
Java接口中可以定义哪些方法?
|
5天前
|
安全 Java 调度
Java并发编程:深入理解线程与锁
【4月更文挑战第18天】本文探讨了Java中的线程和锁机制,包括线程的创建(通过Thread类、Runnable接口或Callable/Future)及其生命周期。Java提供多种锁机制,如`synchronized`关键字、ReentrantLock和ReadWriteLock,以确保并发访问共享资源的安全。此外,文章还介绍了高级并发工具,如Semaphore(控制并发线程数)、CountDownLatch(线程间等待)和CyclicBarrier(同步多个线程)。掌握这些知识对于编写高效、正确的并发程序至关重要。
|
6天前
|
缓存 分布式计算 监控
Java并发编程:深入理解线程池
【4月更文挑战第17天】在Java并发编程中,线程池是一种非常重要的技术,它可以有效地管理和控制线程的执行,提高系统的性能和稳定性。本文将深入探讨Java线程池的工作原理,使用方法以及在实际开发中的应用场景,帮助读者更好地理解和使用Java线程池。
|
6天前
|
Java API 数据库
深研Java异步编程:CompletableFuture与反应式编程范式的融合实践
【4月更文挑战第17天】本文探讨了Java中的CompletableFuture和反应式编程在提升异步编程体验上的作用。CompletableFuture作为Java 8引入的Future扩展,提供了一套流畅的链式API,简化异步操作,如示例所示的非阻塞数据库查询。反应式编程则关注数据流和变化传播,通过Reactor等框架实现高度响应的异步处理。两者结合,如将CompletableFuture转换为Mono或Flux,可以兼顾灵活性和资源管理,适应现代高并发环境的需求。开发者可按需选择和整合这两种技术,优化系统性能和响应能力。