方法

Math.sqrt() 取平方  Math.pow(2,3) 2的3次方

方法(Method),就是数学函数(Function)。  业务方面: 是功能,是动作,一般采用动词命名。  数据层面:是利用算法操作数据模型,实现业务功能。  方法就是数据算法。

方法的声明

方法用于封装特定的逻辑功能。方法的主要要素有:方法名、参数列表和返回值。方法在类中定义,不能在方法中定义。

语法结构

修饰符   返回值类型  方法名(参数列表)
{
// 方法体
}

方法要素--返回值

方法调用结束后可以返回一个数据,称之为返回值。方法在声明时必须指定返回值类型。如果方法没有返回值(即方法不需要返回数据),需将返回值类型声明为void,通过return语句返回,return语句的作用在于结束方法并且将数据返回。

return a+b;  return语句返回该表达式的值

return; 对于返回值为void的方法也可以使用return语句,此时该语句的作用在于结束方法调用。

如果方法声明的返回值,必须在方法体使用return 语句返回数据!

方法要素--参数列表

方法的参数是指:在调用时传递给方法,需要被方法处理的数据。在定义方法时,需要声明该方法所需要 参数变量。在方法调用时,会将实际的参数值传递给方法的参数变量。必须保证传递参数的类型和个数符合方法的声明。

方法的调用过程

public static int max(int a, int b){....}

int a=5;  int b=6;

int max=max(5 , 6);

(1)为main方法中的便利a b max 分配空间并赋值

(2)调用方法max,为max方法的参数变量a, b分配空间

(3)将调用值传入参数变量中

(4)max方法运行完返回,参数变量空间释放。

(5)main方法中的max变量得到返回值。

求斐波那契(Fibonacci) 数列(第n项 等于前两项的和)

public static long f(long n) {
long f1 = 1;
long f2 = 1;
long fn = 2;
for(int i = 3; i <= n; i++){
fn = f1 + f2;
f1 = f2;
f2 = fn;
}
return fn;
}

方法的递归调用

1. java 的栈是Java进程启动时候在内存中开辟的存储空间。栈内存的利用方式LIFO(后进先出)。ava所有局部变量都在栈中分配(压入), 方法的参数也是局部变量,局部变量在离开作用域时候回收 就是从栈中弹出(删除)。

2. Java方法调用使用栈实现, 递归调用就是栈实现的

3. 递归时候要按照递归深度分配全部临时变量, 栈开销很大,性能不好,要注意不要超过栈的大小, 并且一定要给出结束条件, 否则会造成栈溢出错误。

递归的优点与缺点

优点:业务问题解决的很优雅 只需要解决一个层次,其他层次问题就递归解决了。

缺点:大量消耗栈内存空间,不能进行过深层次的递归。否则可能出现栈溢出错误。

使用递归的要点

1)不能过深的递归

2)不能发散递归

3)必须有结束条件

案列

递归实现1+2+...+1000=?  fn(n)=f(n-1)+n

public static int f(int n) {
if(n == 1){
return 1;
}
return n + f(n - 1);
}

斐波那契

public static long f1(long n) {
if(n == 1 || n == 2){
return 1;
}
return f1(n - 1) + f1(n - 2);
} public static long f(long n) {
long f1 = 1;
long f2 = 1;
long fn = 1;
for(int i = 3; i <= n; i++){
fn = f1 + f2;
f1 = f2;
f2 = fn;
}
return fn;
}

java基础(7)--方法的更多相关文章

  1. Java基础02 方法与数据成员

    作者:Vamei 出处:http://www.cnblogs.com/vamei 欢迎转载,也请保留这段声明.谢谢! 在Java基础01 从HelloWorld到面向对象,我们初步了解了对象(obje ...

  2. Java基础——clone()方法浅析

    一.clone的概念 clone顾名思义就是复制, 在Java语言中, clone方法被对象调用,所以会复制对象.所谓的复制对象,首先要分配一个和源对象同样大小的空间,在这个空间中创建一个新的对象.那 ...

  3. Java基础02 方法与数据成员(转载)

    对象中的数据成员表示对象的状态.对象可以执行方法,表示特定的动作. 此外,我们还了解了类(class).同一类的对象属于相同的类型(type).我们可以定义类,并使用该定义来产生对象.   调用同一对 ...

  4. java基础(6):方法

    1. 方法 1.1 方法概述 在我们的日常生活中,方法可以理解为要做某件事情,而采取的解决办法. 如:小明同学在路边准备坐车来学校学习.这就面临着一件事情(坐车到学校这件事情)需要解决,解决办法呢?可 ...

  5. Java基础之方法详解

    方法的所属性 在Java的语言中,方法相当于C语言中的函数,但是它与传统的函数也有着明确的不同:在结构化的语言中,函数是一等公民,整个程序是由一个个函数组成的:但是在面向对象的语言里,类是一等公民,整 ...

  6. 关于java基础_方法的简单习题

    package day05; import java.util.Arrays; /** * 方法作业 * @author ASUS * */ public class Demo6 { /* * 1.定 ...

  7. 【java基础】方法2

    让形参可变的方法 jdk1.5之后,java允许定义形参长度可变的参数,允许为方法指定数量不确定的形参. package object; public class VariableParam { // ...

  8. Java基础--继承方法调用顺序

    最近因为面试的原因,回过头来复习基础的知识,都忘光了,准备买本面试书回来啃. 我先把自己测试的结论总结写出来,以后忘记再来看看 如果b类继承自a类,在main方法中new出b的对象(不带参数),那么他 ...

  9. Java基础--finalize()方法

    原理: 一旦垃圾回收器准备好释放对象占用的存储空间,将首先调用其finalize()方法,并在下一次垃圾回收动作发生时,才会真正回收对象占用的内存. 用途: 1)释放通过某种创建对象方式以外的方式为对 ...

  10. [ 转载 ] Java基础13--equals方法

    一.equals方法介绍 1.1.通过下面的例子掌握equals的用法 1 package cn.galc.test; 2 3 public class TestEquals { 4 public s ...

随机推荐

  1. jquery 轮播图实例

    实现效果:1.图片每2秒钟切换1次. 2.当鼠标停留在整个页面上时,图片不进行轮播. 3.当点击右下角的小球时,出现该选项的对应图片,而且切换页选项的背景颜色发生相应的变化. 4.当图片发生轮播切换时 ...

  2. HDU 1875 畅通工程再续(kruskal)

    畅通工程再续 Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others) Total Sub ...

  3. 学习使用turtlebot2——安装ROS Indigo系统

    最近在学习使用turtlebot2,特此做一些学习记录. 安装ROS前要先决定自己电脑的Ubuntu(乌班图)系统.现在学习ROS常使用的Ubuntu系统有Ubuntu 16.04 和Ubuntu14 ...

  4. delphi xe----操作mongoDB驱动,TMongoWire(Delphi MongoDB Driver)

    所有例子来自:https://github.com/stijnsanders/TMongoWire Delphi MongoDB的驱动 一个Delphi的驱动程序来访问mongoDB的服务器.用jso ...

  5. Let's encrypt申请泛域名证书以及报错处理

    申请泛域名证书的步骤请参考该链接地址: https://www.jianshu.com/p/df6d13187578 报错信息: No matching distribution found for ...

  6. AsciiDoc Text based document generation

    AsciiDoc Text based document generation    AsciiDoc Home Page http://asciidoc.org/   AsciiDoc is a t ...

  7. 剑指Offer——用两个栈实现队列

    题目描述: 用两个栈来实现一个队列,完成队列的Push和Pop操作. 队列中的元素为int类型. 分析: 代码: class Solution { public: void push(int node ...

  8. 转!!CSRF攻击与防御(写得非常好)

    CSRF概念:CSRF跨站点请求伪造(Cross—Site Request Forgery),跟XSS攻击一样,存在巨大的危害性,你可以这样来理解:       攻击者盗用了你的身份,以你的名义发送恶 ...

  9. 两款高性能并行计算引擎Storm和Spark比較

    对Spark.Storm以及Spark Streaming引擎的简明扼要.深入浅出的比較,原文发表于踏得网. Spark基于这种理念.当数据庞大时,把计算过程传递给数据要比把数据传递给计算过程要更富效 ...

  10. thinkphp使用阿里云OSS最新SDK,文件部署

    这文章是建立在你已经注册号阿里云的OSS,和创建好Bucket前提下: 其实阿里云的帮助与文档写的很详细,这里只说一下源码方式 1.phpsdk下载地址(摘自阿里云OSS的帮助与文档)(也有我自己下载 ...