初识“方法”,步入编程领域 | 带你学《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入门编程文章查看此处

相关文章
|
1月前
|
Java 程序员
Java编程中的异常处理:从基础到高级
在Java的世界中,异常处理是代码健壮性的守护神。本文将带你从异常的基本概念出发,逐步深入到高级用法,探索如何优雅地处理程序中的错误和异常情况。通过实际案例,我们将一起学习如何编写更可靠、更易于维护的Java代码。准备好了吗?让我们一起踏上这段旅程,解锁Java异常处理的秘密!
|
8天前
|
自然语言处理 Java
Java中的字符集编码入门-增补字符(转载)
本文探讨Java对Unicode的支持及其发展历程。文章详细解析了Unicode字符集的结构,包括基本多语言面(BMP)和增补字符的表示方法,以及UTF-16编码中surrogate pair的使用。同时介绍了代码点和代码单元的概念,并解释了UTF-8的编码规则及其兼容性。
81 60
|
17天前
|
存储 缓存 Java
Java 并发编程——volatile 关键字解析
本文介绍了Java线程中的`volatile`关键字及其与`synchronized`锁的区别。`volatile`保证了变量的可见性和一定的有序性,但不能保证原子性。它通过内存屏障实现,避免指令重排序,确保线程间数据一致。相比`synchronized`,`volatile`性能更优,适用于简单状态标记和某些特定场景,如单例模式中的双重检查锁定。文中还解释了Java内存模型的基本概念,包括主内存、工作内存及并发编程中的原子性、可见性和有序性。
Java 并发编程——volatile 关键字解析
|
21天前
|
算法 Java 调度
java并发编程中Monitor里的waitSet和EntryList都是做什么的
在Java并发编程中,Monitor内部包含两个重要队列:等待集(Wait Set)和入口列表(Entry List)。Wait Set用于线程的条件等待和协作,线程调用`wait()`后进入此集合,通过`notify()`或`notifyAll()`唤醒。Entry List则管理锁的竞争,未能获取锁的线程在此排队,等待锁释放后重新竞争。理解两者区别有助于设计高效的多线程程序。 - **Wait Set**:线程调用`wait()`后进入,等待条件满足被唤醒,需重新竞争锁。 - **Entry List**:多个线程竞争锁时,未获锁的线程在此排队,等待锁释放后获取锁继续执行。
59 12
|
1月前
|
Java 开发者 微服务
Spring Boot 入门:简化 Java Web 开发的强大工具
Spring Boot 是一个开源的 Java 基础框架,用于创建独立、生产级别的基于Spring框架的应用程序。它旨在简化Spring应用的初始搭建以及开发过程。
67 6
Spring Boot 入门:简化 Java Web 开发的强大工具
|
17天前
|
存储 安全 Java
Java多线程编程秘籍:各种方案一网打尽,不要错过!
Java 中实现多线程的方式主要有四种:继承 Thread 类、实现 Runnable 接口、实现 Callable 接口和使用线程池。每种方式各有优缺点,适用于不同的场景。继承 Thread 类最简单,实现 Runnable 接口更灵活,Callable 接口支持返回结果,线程池则便于管理和复用线程。实际应用中可根据需求选择合适的方式。此外,还介绍了多线程相关的常见面试问题及答案,涵盖线程概念、线程安全、线程池等知识点。
101 2
|
1月前
|
监控 架构师 Java
Java虚拟机调优的艺术:从入门到精通####
本文作为一篇深入浅出的技术指南,旨在为Java开发者揭示JVM调优的神秘面纱,通过剖析其背后的原理、分享实战经验与最佳实践,引领读者踏上从调优新手到高手的进阶之路。不同于传统的摘要概述,本文将以一场虚拟的对话形式,模拟一位经验丰富的架构师向初学者传授JVM调优的心法,激发学习兴趣,同时概括性地介绍文章将探讨的核心议题——性能监控、垃圾回收优化、内存管理及常见问题解决策略。 ####
|
2月前
|
缓存 Java 开发者
Java多线程编程的陷阱与最佳实践####
本文深入探讨了Java多线程编程中常见的陷阱,如竞态条件、死锁和内存一致性错误,并提供了实用的避免策略。通过分析典型错误案例,本文旨在帮助开发者更好地理解和掌握多线程环境下的编程技巧,从而提升并发程序的稳定性和性能。 ####
|
1月前
|
安全 算法 Java
Java多线程编程中的陷阱与最佳实践####
本文探讨了Java多线程编程中常见的陷阱,并介绍了如何通过最佳实践来避免这些问题。我们将从基础概念入手,逐步深入到具体的代码示例,帮助开发者更好地理解和应用多线程技术。无论是初学者还是有经验的开发者,都能从中获得有价值的见解和建议。 ####
|
1月前
|
Java 调度
Java中的多线程编程与并发控制
本文深入探讨了Java编程语言中多线程编程的基础知识和并发控制机制。文章首先介绍了多线程的基本概念,包括线程的定义、生命周期以及在Java中创建和管理线程的方法。接着,详细讲解了Java提供的同步机制,如synchronized关键字、wait()和notify()方法等,以及如何通过这些机制实现线程间的协调与通信。最后,本文还讨论了一些常见的并发问题,例如死锁、竞态条件等,并提供了相应的解决策略。
53 3
下一篇
开通oss服务