本次内容大纲
方法 其实就是把一个重复的东西进行封装,把他封装成一个功能了。
类似于 C语言的函数,但是又不完全相同。
方法存在的意义(不要背, 重在体会):
- 是能够模块化的组织代码(当代码规模比较复杂的时候).
- 做到代码被重复使用, 一份代码可以在多个位置使用.
- 让代码更好理解更简单.
- 直接调用现有方法开发, 不必重复造轮子.
代码示例:
求 1-100 之间的和
编译结果:
??我们看到,成功的调用了方法的内容,同时接收了方法的返回值。
??在这个代码练习中,我们知道了方法的基本语法及其调用。
??我们对方法的调用,是依赖于栈的
??每次调用一个方法,都会在栈上为这个方法开辟一个内存。把这个内存叫做:栈帧.
??以上面的代码为例,介绍一下方法在内存中的存放.
??首先调用的方法是main方法,那么此时在内存中会开辟一块main的栈帧,此时在main里创建了一个ret变量,在main的内存中就存放了ret的空间.
??此时再调用add方法,再次开辟一个栈帧,形参为n,存放n的空间,往下走 创建了一个sum 的变量,在存放一个sum的空间,进入循环有创建了一个 i 的变量.
??此时栈空间的存放情况:
??add方法return结束语句,调用完毕后,出栈.
??main方法语句执行完毕,出栈.
??这就是一个完整的方法调用过程.
基本规则
1.定义方法的时候, 不会执行方法的代码. 只有调用的时候才会执行.
2.当方法被调用的时候, 会将实参赋值给形参.
3.参数传递完毕后, 就会执行到方法体代码.
4.当方法执行完毕之后(遇到 return 语句),回到方法调用位置继续往下执行.
5.一个方法可以被多次调用.
??什么实参?什么是形参?
??让我们通过下面的代码示例来认识
我们通过一个练习来知道传参的使用.
题目要求:用方法来交换两个整形.
我们看一下下面的代码是否正确.
看似过程是正确的,我们看一下编译结果.
并没有进行交换,那是为什么呢?
??我们知道,我们传的是实参的值,但是形参只是实参的一份拷贝,所以在swap方法中,我们只是交换的是 x,y 这两个形参的值,swap方法调用完毕后两个形参的值自动被销毁,所以实参的值不变.
??在C语言中,我们要想通过函数来交换两个整形的值,需要进行&其地址操作
??但是我们明确说明:
1.Java中 没有&取地址符号
2.Java当中 栈上的内存地址是无法取到的
3.Java中方法传参只能进行值传参,不能像C语言进行址传参.
??那么在Java中如何实现传地址操作呢?
??答案是传引用,只要是引用类型就可以,类、接口、抽象类、枚举、String、数组等…
??具体使用我们会在之后更新的博客中继续提到.
传参时实参与形参的注意事项:
如上图所示:
1.参数的个数、类型、顺序都要一 一匹配.
2.方法的返回值类型与接受类型也要一 一对应.
??有些时候我们需要用一个函数同时兼容多种参数的情况, 我们就可以使用到方法重载.
??我们希望在向add方法传入两个double 类型的变量,实现浮点数的加法.
??但是编译结果:
??我们只能将代码修改为
??这两个方法实现的都是同一种功能,将两个数据进行加法运算.我们对不同的数据还得创建不同类型的函数,这样是不是过于麻烦,所以在Java中就有了方法重载的概念:用一个函数同时兼容多种参数.
??还是对于上面的代码进行修改:
??方法的名字都叫 add. 但是有的 add 是计算 int 相加, 有的是 double 相加; 甚至有的计算两个数字相加, 有的还可以是计算三个数字相加.
??同一个方法名字, 提供不同版本的实现, 称为 方法重载
看下面两个代码:
??通过这两个代码的例子,我们可以知道在Java编辑器看来,sum 的两个方法仍然是两个相同的方法,因为其参数列表相同.所以会进行报错,所以返回值对方法的重载没有影响.
??一个方法在执行过程中调用自身, 就称为 “递归”.
??递归相当于数学上的 “数学归纳法”, 有一个起始条件, 然后有一个递推公式.
??递归的注意点:
1.程序调用自己
2.这个递归程序一定要有一个趋近于中止的条件.
3.核心:写递归程序的时候,需要自己来推导一个递推公式.
例:
我们求 N!
起始条件: N = 1 的时候, N! 为 1. 这个起始条件相当于递归的结束条件.
递归公式: 求 N! , 直接不好求, 可以把问题转换成 N! => N * (N-1)!
代码实现:
import java.util.Scanner;
public static int fac(int n){
if(n==1){
return 1;
}
return n*fac(n-1);
}
public static void main5(String[] args){
Scanner scanner = new Scanner(System.in);
int N = scanner.nextInt();
int ret = fac(N);
System.out.println(ret);
}
??递归的程序的执行过程不太容易理解, 要想理解清楚递归, 必须先理解清楚 “方法的执行过程”, 尤其是 “方法执行结束之后, 回到调用位置继续往下执行”.
??见博客——Java 方法 递归使用及练习
??好了,这次Java基础语法——方法使用的知识就分享到这里结束了,希望大家能够多多练习,熟悉知识,提升自己.最后感谢大家的欣赏与关注!!!
谢谢欣赏!!!
本文实例讲述了Laravel框架源码解析之反射的使用。分享给大家供大家参考,具体如...
4月11日20:30~22:00通过腾讯会议进行了第二次在线学习讨论我把学习笔记整理一下...
Elasticsearch 是通过 Lucene 的倒排索引技术实现比关系型数据库更快的过滤。特...
正则忽略大小写 – RegexOptions.IgnoreCase 例如: 复制代码 代码如下: Str = R...
工具:Eclipse,Oracle,smartupload.jar;语言:jsp,Java;数据存储:Oracle。...
上篇文章给大家介绍了 Java正则表达式匹配,替换,查找,切割的方法 ,接下来,...
项目中用到的一些特殊字符和图标 html代码 XML/HTML Code 复制内容到剪贴板 div ...
错误描述: 在开发.net项目中,通过microsoft.ACE.oledb读取excel文件信息时,报...
DELETEFROMTablesWHEREIDNOTIN(SELECTMin(ID)FROMTablesGROUPBYName) Min的话保...
复制代码 代码如下: % URL="http://news.163.com/special/00011K6L/rss_newstop....