一、前言
记录时间 [2024-05-01]
系列文章简摘:
Java 笔记 01:Java 概述,MarkDown 常用语法整理
Java 笔记 02:Java 开发环境的搭建,IDEA / Notepad++ / JDK 安装及环境配置,编写第一个 Java 程序
Java 笔记 03:Java 基础知识,使用 IDEA 创建 Java 项目、设置注释颜色,以及自动生成 JavaDoc
Java 笔记 09:Java 流程控制相关,常见的三种控制结构(顺序、选择、循环)
更多 Java 相关文章,请参考上面专栏哦。
本文对 Java 方法进行简单介绍。(未完结)
二、方法概述
1. 思考引入
在之前的学习中,我们接触过 System.out.println();
这个 Java 语句,它是用来在控制台输出信息的命令。
在 Java 中,System.out
是一个代表标准输出流的对象,而 println()
是一个方法,它会在控制台输出括号内的内容,并在最后自动换行。如果括号内没有任何内容,它将输出一个空行。
System
:这是 Java 中的一个类,位于java.lang
包中。它提供了与系统相关的方法和属性,包括标准输入、标准输出等。out
:这是System
类的一个静态属性,类型为PrintStream
,PrintStream
是 Java 中用于打印输出的类。println()
:这是一个方法,它会在控制台输出括号内的内容,并在最后自动换行。
2. 何谓方法
在 Java 中,方法是用来执行特定任务的一组语句的集合,它们在一起执行一个功能。方法可以接受参数,执行操作,并返回一个值。
- 方法是解决一类问题的步骤的有序组合;
- 方法包含于类或对象中;
- 方法在程序中被创建,在其他地方被引用。
3. 方法设计原则
方法的本意是功能块,就是实现某个功能的语句块的集合。设计方法时,应遵循一些原则,以确保方法的可读性、可维护性和可重用性。
- 单一职责原则 :一个方法应该只有一个明确的功能或职责(原子性)。使方法更加清晰和易于理解,降低方法的复杂性。
- 开放封闭原则:方法应该对扩展开放,对修改封闭。当需要修改方法时,应该通过扩展,而不是修改现有方法来实现。
- 参数数量原则:尽量避免方法接受过多的参数。参数数量过多会增加方法的复杂性和理解难度。如果方法需要大量参数,可以考虑将这些参数封装成对象或者使用构建器模式。
- 清晰明确的命名原则:方法的名称应该清晰、明确地描述方法的功能。
- 提高可见性原则 :在设计方法时,应该尽量将方法的可见性设置为最小化。如果可能,应该将方法设置为私有
private
,只有在需要在类的外部调用时,才将方法设置为公共public
或受保护protected
。 - 避免副作用原则:方法应该尽量避免对外部状态的修改,即所谓的副作用。副作用会增加方法的复杂性,降低方法的可预测性和可维护性。
- 一致性原则:方法的设计应该保持一致性,即相似的功能应该采用相似的方法设计。这样做可以提高代码的可读性和可维护性。
- 错误处理原则:方法应该提供良好的错误处理机制,包括抛出异常、返回错误码等。良好的错误处理可以增强方法的健壮性和可靠性。
4. 方法命名原则
在 Java 中,方法的命名应该遵循一定的规则和约定,以提高代码的可读性和可维护性。
以下是一些常用的方法命名规则:
- 使用动词或动词短语 :方法名称应该能够清楚地描述方法执行的操作。通常使用动词或动词短语来命名方法。例如:
calculateTotal()
、getUserInfo()
。 - 采用驼峰命名法 :首字母小写,后续单词的首字母大写,没有下划线或其他分隔符。例如:
calculateTotalAmount()
。 - 清晰明确:方法名应该尽可能清晰和明确,避免使用缩写或简写,以确保其他开发者能够准确理解方法的作用。
- 使用一致的命名风格:在整个代码库中,应该保持一致的命名风格。以提高代码的可读性,降低沟通成本。
- 避免使用保留字:方法名不应该与 Java 中的保留字相同,以免引起歧义或编译错误。
- 根据约定命名特殊方法 :一些特殊用途的方法,例如构造方法、getter 和 setter 方法,有一定的命名约定。例如,构造方法应该与类名相同,getter 方法应该以
get
开头,setter 方法应该以set
开头。 - 反映方法的功能:方法名应该反映方法的功能,而不是具体的实现细节或内部实现。
- 具有一定的描述性:避免使用过于简单或过于通用的名称,以免造成混淆或命名冲突。
三、方法定义及调用
1. 定义语法
以下是定义方法的一般语法:
java
<访问修饰符> <返回类型> <方法名>(<参数列表>) {
// 方法体
<语句>;
// 可选的返回语句
return <返回值>;
}
<访问修饰符>
:指定了谁可以调用这个方法以及在什么情况下可以调用。常见的访问修饰符包括:public
(公共的,任何类都可以访问)private
(私有的,只有同一个类中的其他方法可以访问)protected
(受保护的,只有同一个包内的类和子类可以访问)- 默认(没有修饰符,只有同一个包内的类可以访问)
<返回类型>
:指定了方法返回的数据类型:- 如果方法不返回任何值,则返回类型应为
void
; - 如果方法返回一个值,则返回类型应该是具体的数据类型,如
int
、double
、String
等。
- 如果方法不返回任何值,则返回类型应为
<方法名>
:方法的名称,用来唯一标识方法。<参数列表>
:方法可以接受零个或多个参数,参数是方法执行时需要的输入值。参数列表是用括号括起来的,多个参数之间用逗号分隔。// 方法体
:方法体包含了方法执行的实际操作。这里是方法中的语句集合。return <返回值>;
:可选的返回语句,用于将结果返回给调用者。return
语句会结束方法的执行并返回一个值给调用者。如果方法的返回类型是void
,则不需要返回语句。
2. 简单示例
以下是一个简单的 Java 方法示例:
java
public class MyClass {
public static void main(String[] args) {
int sum = addNumbers(5, 3);
System.out.println("Sum: " + sum);
}
public static int addNumbers(int a, int b) {
return a + b;
}
}
在这个例子中,addNumbers
方法接受两个整数作为参数,并返回它们的和。main
方法调用了 addNumbers
方法,并将返回的结果打印到控制台。
四、总结
本文对 Java 方法进行简单介绍。(未完结)
剩余部分:方法重载、命令行传参、可变参数、递归
一些参考资料
狂神说 Java 零基础:https://www.bilibili.com/video/BV12J41137hu/
TIOBE 编程语言走势: https://www.tiobe.com/tiobe-index/
Typora 官网:https://www.typoraio.cn/
Oracle 官网:https://www.oracle.com/
Notepad++ 下载地址:https://notepad-plus.en.softonic.com/
IDEA 官网:https://www.jetbrains.com.cn/idea/
Java 开发手册:https://developer.aliyun.com/ebook/394
Java 8 帮助文档:https://docs.oracle.com/javase/8/docs/api/