java中方法的知识点和递归调用

方法执行原理:(方法不调用不执行,调用才执行)

* 方法在调用的这时候,才会在内存中划分空间

* 方法在调用的时候,是在栈内存中分配的空间(jvm有一块内存是栈内存)

* 函数/方法目的: 还是为了代码重用

* 相同的类型的操作,不容重复的写代码

* 函数/方法:就是一段有名字的代码段

* 方法的定义

* [方法修饰符列表] 方法返回值类型 方法名(参数1,参数2,参数3....){

* 执行语句;

* }

*

* 方法修饰符列表是可选的:权限控制的:public protected private /static

* 返回值类型:11中数据类型中的任意一种类型

* 没有返回值就:void

* 方法名只要是合法的标识符即可

* 方法形参列表,多个逗号隔开,形参也要指明数据类型;

* 形参:是指在函数/方法定义处,那些参数;数据类型 变量名, 数据类型,变量名,

* 实参:是指在函数调用处,传入的那个参数.

* 在方法体内部,如果有返回值(类型),用return语句;且return是结束函数的作用

* 方法的调用:从内存数据结构来讲就是压栈

* 方法的结束:从内存数据结构来讲就是弹栈

* 方法的重载:

* 同一个类中,方法名相同,参数列表不同的方法叫方法的重载;

* 参数列表不同:可以是参数个数不同,可以是参数数据类型不同

* 方法的重载和返回值,和修饰符列表无关.

* :这个十一中数据结构,就像弹夹,薯片盒子,后进去先出来

下面是递归调用的例子:

public class Method_10{

public static void main(String[] args){ //方法main入口

int i=100; //声明数据类型i,赋值为100

m_1(i); //调用m1方法,赋值i为100

System.out.println( "hello world" );//调用m1后完成赋值,输出内容

}

public static void m1(int i){ //声明m_1方法

m_2(i) ; //调用m_2方法,i赋值为100

System.out.println( "方法m_1被调用了" );//运行原理:m_1方法中调用好了m_2,声明m_2方法并调用方法m_3,声明方法m_3,在m_3中输出"m3的方法中i="+i;输出m_3被调用了,i被赋值为100,m_3运行完后返回调用m_3处,在m_2声明中,m_3调用运行完成,输出方法m_2被调用;声名m_2运行完后,返回调用m_2处,在声明m_1中,m_2运行完成,输出"方法m_1被调用",返回调用m_1处,输出"hello word"

}

public static void m_2(int i){

m_3(i);

System.out.println( "方法m_2被调用了" );

}

public static void m_3(int i){

System.out.println( "m_3方法中的i="+ i );

System.out.println( "方法m_3被调用了" );

}

}

这是我刚学习的内容,印象还比较深刻,所以总结一下,记录下来,方便以后查看,本文内容都是我根据自己的理解写下来的,有什么不对的地方还希望和大家多多交流,O(∩_∩)O谢谢!