Java - 方法

什么是java中的方法?

  - 方法就是一段代码片段,并且这段代码可以完成某个特定的功能、动作、是可以被重复的使用。

  - 方法就是类的一个动作。

  - 方法在C语言中也叫做函数 或 function。

  - 方法定义在类体当中,在一个类中可以定义多个方法,方法的编写位置没有先后顺序,可以随意。

  - 方法体当中不能再定义方法。

方法的语法结构

-[修饰符列表]  返回值类型  方法名 (形式参数列表){

            方法体;
}
  public  int  sumInt (int a,int b) {

 	int c=a+b;

 	return c;
} ## 调用方法 - 静态方法(static修饰) 类名.方法名(实参列表1,2); - sum = sumInt (a , b); - 当两个方法在同一个类体中时, “类体.” 可以省略不写。 - return 出现在返回值为void 的方法当中,主要是为了用来结束当前方法。 - 非静态方法必须new对象之后才能调用 ## 实例 class MethodTest {
public static void main(String[] args){ // 调用静态方法
int a=3,b=10,c,d;
c=ScannerTest.minus(a,b); //调用非静态方法
ScannerTest st=new ScannerTest();
d=st.sumInt(a,b); //输出调用结果
System.out.println("静态方法调用结果:"+c);
System.out.println("非静态方法调用结果:"+d);
} //静态方法
public static int minus(int a,int b){
int c;
c=a-b;
return c;
} //非静态方法
public int sumInt(int a,int b){
int c;
c=a+b;
return c;
}
} ## 方法在执行过程中,在JVM中的内存是如何分配的? 1. 当方法只定义不调用,是不会执行的,并且在jvm中也不会给该方法分配运行所属的内存空间。 2. jvm在内存划分上分成这样三块主要的内存空间 * 方法区内存 * 堆内存 * 栈内存 ## 关于栈的数据结构 * 栈:stack,是一种数据结构 * 数据结构反应的是数据的存储形态 * 栈帧永远指向栈顶元素,栈顶元素处于活跃状态,其他元素静止。 * 压栈/入栈/push, 弹栈/出栈/pop * 压栈:给方法分配内存空间, 弹栈:释放该方法的内存空间。 * 栈数据结构存储数据的特点是,先进后出,后进先出。 ## 方法代码片段存在哪里?方法执行的时候执行过程的内存在哪里分配? * 方法代码片段属于class字节码文件的一部分,方法代码片段在类加载的时候,将其存储在方法区内存中,所以JVM中的三块主要内存空间,方法区内存最先有数据,存放了代码片段。 * 方法区内存中只有一份代码片段,但是可以被重复调用,但是每一次调用这个方法的时候,都需要重新分配独立的运行空间此空间需要在栈内存中分配,栈内存中分配方法运行所属的内存空间。 * 方法在调用的时候会给该方法分配独立的内存空间,在栈中分配,此时会发生压栈动作,方法执行结束之后,给该方法分配的内存空间全部释放,此时发生弹栈动作。 * 局部变量在方法体中声明,代码片段存储在方法区内存中,在栈中分配内存空间。

Day01_11_Java方法的更多相关文章

  1. javaSE27天复习总结

    JAVA学习总结    2 第一天    2 1:计算机概述(了解)    2 (1)计算机    2 (2)计算机硬件    2 (3)计算机软件    2 (4)软件开发(理解)    2 (5) ...

  2. mapreduce多文件输出的两方法

    mapreduce多文件输出的两方法   package duogemap;   import java.io.IOException;   import org.apache.hadoop.conf ...

  3. 【.net 深呼吸】细说CodeDom(6):方法参数

    本文老周就给大伙伴们介绍一下方法参数代码的生成. 在开始之前,先补充一下上一篇烂文的内容.在上一篇文章中,老周检讨了 MemberAttributes 枚举的用法,老周此前误以为该枚举不能进行按位操作 ...

  4. IE6、7下html标签间存在空白符,导致渲染后占用多余空白位置的原因及解决方法

    直接上图:原因:该div包含的内容是靠后台进行print操作,输出的.如果没有输出任何内容,浏览器会默认给该空白区域添加空白符.在IE6.7下,浏览器解析渲染时,会认为空白符也是占位置的,默认其具有字 ...

  5. 多线程爬坑之路-Thread和Runable源码解析之基本方法的运用实例

    前面的文章:多线程爬坑之路-学习多线程需要来了解哪些东西?(concurrent并发包的数据结构和线程池,Locks锁,Atomic原子类) 多线程爬坑之路-Thread和Runable源码解析 前面 ...

  6. [C#] C# 基础回顾 - 匿名方法

    C# 基础回顾 - 匿名方法 目录 简介 匿名方法的参数使用范围 委托示例 简介 在 C# 2.0 之前的版本中,我们创建委托的唯一形式 -- 命名方法. 而 C# 2.0 -- 引进了匿名方法,在 ...

  7. ArcGIS 10.0紧凑型切片读写方法

    首先介绍一下ArcGIS10.0的缓存机制: 切片方案 切片方案包括缓存的比例级别.切片尺寸和切片原点.这些属性定义缓存边界的存在位置,在某些客户端中叠加缓存时匹配这些属性十分重要.图像格式和抗锯齿等 ...

  8. [BOT] 一种android中实现“圆角矩形”的方法

    内容简介 文章介绍ImageView(方法也可以应用到其它View)圆角矩形(包括圆形)的一种实现方式,四个角可以分别指定为圆角.思路是利用"Xfermode + Path"来进行 ...

  9. JS 判断数据类型的三种方法

    说到数据类型,我们先理一下JavaScript中常见的几种数据类型: 基本类型:string,number,boolean 特殊类型:undefined,null 引用类型:Object,Functi ...

随机推荐

  1. short i=1;i=i+1;为什么报错?

    先测试,看结果: 提示我们说不能将short类型的转化为int类型! 先不急着下结论,我们继续测试,用i+=1; 我们发现并没有报错,为什么同样是加1,会出现这样两种不同的结果呢? 查阅了一些资料,大 ...

  2. eclipse中将项目加载到tocat报错:Tomcat version 6.0 only supports J2EE 1.2, 1.3, 1.4, and Java EE 5 Web modules

    第一种解决方法:只需要找到导入项目的配置文件即可,举个栗子:D:\公司\iptv_gx\iptv_gx\.settings\org.eclipse.wst.common.project.facet.c ...

  3. 【Notes_1】现代图形学入门——计算机图形学概述

    跟着闫令琪老师的课程学习,总结自己学习到的知识点 课程网址GAMES101 B站课程地址GAMES101 课程资料百度网盘[提取码:0000] 计算机图形学概述 计算机图形学是一门将模型转化到屏幕上图 ...

  4. [计算机图形学]Blinn-Phong光照模型

    目录 一.前言 二.原理 三.代码 一.前言 Blinn-Phong光照模型以Phong模型为基础的,提供比Phong更柔和.更平滑的高光,而且由于Blinn-Phong的光照模型省去了计算反射光线的 ...

  5. 7.vue组件(二)--双向绑定,父子组件访问

    本文主要说两件事 1. 如何实现父子组件之间的双向绑定 2. 父组件如何访问子组件的data,method, 子组件如何访问父组件的data,method等 一. 如何实现父子组件之间的双向绑定 案例 ...

  6. POJ-1321棋盘问题(简单深搜)

    简单搜索step1 POJ-1321 这是第一次博客,题目也很简单,主要是注意格式书写以及常见的快速输入输出和文件输入输出的格式. 递归的时候注意起始是从(-1,-1)开始,然后每次从下一行开始递归. ...

  7. FreeBSD安装xorg + xfce 4

    FreeBSD安装xorg,以及xfce 安装xorg 可选包 -xorg 完整xorg环境包 -xorg-minimal xorg最小化包 ports安装 cd /usr/ports/x11/xor ...

  8. FreeBSD jail 折腾记(二)

    FreeBSD jail 折腾记(二) 创建jail目录 创建4个 分别是模板 骨架 数据 项目 创建模板目录 mkdir -p /jail/j1 # 然后放入基本目录,上篇说过不再写 创建骨架目录 ...

  9. FreeBSD 乃至开源界中的孔乙己 再论苦难哲学之一

    在许多狂热的FreeBSD 粉丝里,他们甚至不允许别人把FreeBSD写作freebsd,要和你强调,F和BSD都是大写的.还说这是什么尊重之类的东西.大抵和孔乙己的茴香豆的茴的有四种写法一样吧:&q ...

  10. Codeforces Round #574 (Div. 2) E. OpenStreetMap 【单调队列】

    一.题目 OpenStreetMap 二.分析 对于二维空间找区间最小值,那么一维的很多好用的都无法用了,这里可以用单调队列进行查找. 先固定一个坐标,然后进行一维的单调队列操作,维护一个区间长度为$ ...