方法属于谁

  • 方法要么属于类,要么属于对象
  • static修饰的方法属于类
  • 没有static修饰的方法属于对象
  • 方法只能定义在类里面,不能独立定义
  • 不能独立的执行方法,要么通过类调用,要么通过方法调用
  • 一个类里,一个方法调用另一个方法,看似没有调用者,实际上对于非static方法使用this调用,static方法使用类名调用
  • 注意:static方法也可以通过对象调用,这符合语法,但不推荐

方法的参数传递

  • Java里,参数的传递方式只有一种:值传递,就是将实际参数的副本传给方法,而参数本身不受影响
  • 示例:对于基本类型的参数
public class SwapTest {
public static void main(String[] args) {
int a=3;
int b=7;
System.out.println("主方法里面,用swap(a,b)交换前:a="+a+" b="+b);
swap(a,b);
System.out.println("主方法里面,用swap(a,b)交换后:a="+a+" b="+b);
}
public static void swap(int a,int b){
System.out.println("swap(a,b)方法内部,交换前:a="+a+" b="+b);
int temp;
temp=a;
a=b;
b=temp;
System.out.println("swap(a,b)方法内部,交换后:a="+a+" b="+b);
} }
  • 上面代码中,用swap()方法并没能对main方法的a和b实现交换,因为在调用swap方法时,栈内存中又开了个swap栈区,里面有两个变量a和b,这个ab跟main方法的ab毫无关系,接下来传递参数的值,也就是将main的3传给swap的a变量,将7传给b变量,然后swap方法内部将二者进行了交换,但这丝毫不影响main方法里的ab。这里的swap就像人睡觉一样,你在梦里中了500万,但这丝毫改变不了你的现实。
  • 再看下面的代码,引用类型的参数:
public class T1 {
public static void main(String[] args) {
DataWrap dw=new DataWrap();
dw.a=3;
dw.b=7;
System.out.println("main方法里,交换前,dw.a="+dw.a+" dw.b="+dw.b);
swap(dw);
System.out.println("main方法里,交换后,dw.a="+dw.a+" dw.b="+dw.b);
}
public static void swap(DataWrap dw){
System.out.println("swap方法里,交换前,dw.a="+dw.a+" dw.b="+dw.b);
int temp;
temp=dw.a;
dw.a=dw.b;
dw.b=temp;
System.out.println("swap方法里,交换后,dw.a="+dw.a+" dw.b="+dw.b);
}
}
class DataWrap{
int a;
int b;
}
  • 对于引用类型的参数而言,依然是采用的值传递方式。但这里容易存在一个假象:调用swap()方法时,传进去的是dw这个对象本身,并没有复制一个dw。实际上传进去的是dw这个对象的引用的复制,而不是复制了一个dw对象,也就是说调用swap()方法后,内存中有两个引用指向dw对象,一个main方法的dw变量,另一个是swap方法的dw变量。

形参个数可变的方法

  • 如果要传入某类型的参数个数不能确定,那可以用下面这种方式

    methodName(int a,float b,String...strings);
  • 规则:
    • 个数可变的形参只能放在参数列表的最后
    • 一个方法只能有一个个数可变的形参
    • 调用这种方法时,可以传入一个对应类型的数组
  • 参数数组
    • 个数可变的形参实际上就是个数组,下面的定义与上面的相同

      methodName(int a,float b,String[] strings);

方法的重载

  • 方法名+形参列表构成了方法签名
  • Java里,即使方法名相同,只要形参列表不想同,就是不同的方法
  • 同一个类中,方法名相同,形参列表不同,这就叫做方法的重载,overload
  • 在调用方法的时候,JVM会根据方法名和传入的参数的类型自动匹配对应的方法
  • 重载方法中包含个数可变的形参,看示例代码:
public class Test {
public static void main(String[] args) {
test("A"); //输出:有一个String参数
test("B","C"); //输出:有两个String参数
test("D","E","F"); //输出:有三个String参数
test("G","H","I","J","K"); //输出:有很多个String参数
String[] str={"A"};
test(str); //输出:有很多个String参数
}
public static void test(String str){
System.out.println("有一个String参数");
}
public static void test(String str1,String str2){
System.out.println("有两个String参数");
}
public static void test(String str1,String str2,String str3){
System.out.println("有三个String参数");
}
public static void test(String...strs){
System.out.println("有很多个String参数");
}
}
  • 从上面的代码可以看出,总是先匹配精确的个数,匹配不到再匹配个数可变的;
  • 如果传入的是数组,直接匹配个数可变的
  • 一般不推荐用个数可变的形参,意义不大,可读性差

递归方法

  • 简单的说,递归方法就是在方法里面调用自身,然后可能产生循环调用,最后在某种条件下退出
  • 使用原则:
    • 向已知的方向递归
    • 要设置某种条件能让递归调用退出来,
  • 看下面的示例代码
public class T1 {
public static void main(String[] args) {
System.out.println("0~-50的和= "+sum(-50));
}
public static int sum(int num){
if (num==0){
return 0;
}else if(num>0){
return num+sum(num-1);
}else{
return num+sum(num+1);
}
}
}

0019 Java学习笔记-面向对象-方法的更多相关文章

  1. 0030 Java学习笔记-面向对象-垃圾回收、(强、软、弱、虚)引用

    垃圾回收特点 垃圾:程序运行过程中,会为对象.数组等分配内存,运行过程中或结束后,这些对象可能就没用了,没有变量再指向它们,这时候,它们就成了垃圾,等着垃圾回收程序的回收再利用 Java的垃圾回收机制 ...

  2. 0028 Java学习笔记-面向对象-Lambda表达式

    匿名内部类与Lambda表达式示例 下面代码来源于:0027 Java学习笔记-面向对象-(非静态.静态.局部.匿名)内部类 package testpack; public class Test1{ ...

  3. 0025 Java学习笔记-面向对象-final修饰符、不可变类

    final关键字可以用于何处 修饰类:该类不可被继承 修饰变量:该变量一经初始化就不能被重新赋值,即使该值跟初始化的值相同或者指向同一个对象,也不可以 类变量: 实例变量: 形参: 注意可以修饰形参 ...

  4. 0013 Java学习笔记-面向对象-static、静态变量、静态方法、静态块、单例类

    static可以修饰哪些成员 成员变量---可以修饰 构造方法---不可以 方法---可以修饰 初始化块---可以修饰 内部类(包括接口.枚举)---可以修饰 总的来说:静态成员不能访问非静态成员 静 ...

  5. Java学习笔记之---方法和数组

    Java学习笔记之---方法与数组 (一)方法 (1)什么是方法? 方法是解决一类问题的步骤的有序组合 方法包含于类或对象中 方法在程序中被创建,在其他地方被引用 (2)方法的优点 使程序变得更简短而 ...

  6. 程序设计基础·Java学习笔记·面向对象(上)

    Java程序设计基础之面向对象(上) (自适应学习进度而进行记录的笔记,希望有一些小小的用处吧(^∀^●)ノシ) (新人上路,望多指教,如有错误,望指正,万分感谢(o゚v゚)ノ) 目录 一.面向对象 ...

  7. 程序设计基础·Java学习笔记·面向对象(下)

    Java程序设计基础之面向对象(下) (补充了上的一些遗漏的知识,同时加入了自己的笔记的ヾ(•ω•`)o) (至于为什么分P,啊大概是为了自己查笔记方便(?)应该是("` 3′") ...

  8. 0021 Java学习笔记-面向对象-包、构造器

    封装 面向对象的三大特征: 封装 继承 多态 封装: 将对象的状态信息隐藏,不允许外部程序直接访问 通过该类提供的方法来访问和操作 有啥用: 隐藏类的实现细节 在方法中加入控制逻辑,限制对成员变量的不 ...

  9. 0029 Java学习笔记-面向对象-枚举类

    可以创建几个对象? n多个:大部分的类,都可以随意创建对象,只要内存不爆掉 1个:比如单例类 有限的几个:采用单例类的设计思路,可以只允许创建少数的几个特定的对象:还有就是枚举类. 创建少数几个对象, ...

随机推荐

  1. [测试] Firemonkey Android 照相自订分辨率测试

    在 Delphi 10 Seattle 提供了照相及相册自订分辨率的功能,请见官方网站教学: http://docwiki.embarcadero.com/RADStudio/Seattle/en/T ...

  2. themepark模板中奇特的编码

    编码问题虽然经常碰到,但通过编码来实现源代码加密的是第一次碰到.只能用神奇来形容. 而且研究了几个小时,没有想到解决办法.代码基本可以通过不断执行输出,但无法判断是何种编码.

  3. web项目 验证码 *** 最爱那水货

    1. jsp代码 : <Script> function changeImg(){ document.getElementById("certImg").src =&q ...

  4. python读取文件的前几行

    文件内容rolling.txt: There's a fire starting in my heart 我怒火中烧 Reaching a fever pitch and it's bringing ...

  5. GJM : Lua 语言学习笔记

    Lua笔记 容易与C/C++整合 Lua所提供的机制是C所不善于的:高级语言,动态结构,简洁,易于测试和调试. Lua特有的特征: `1:可扩展性.卓越的扩展性导致了很多人将Lua用作搭建领域语言的工 ...

  6. java 编译时的初始化顺序

    有的时候,java的初始化会对我的工作照成很大影响,所以简单介绍一下, 首先介绍简单的变量的初始化:在类的内部,变量定义的先后顺序决定了初始化的顺序,即使变量定义散布于方法定义之间,它也会先于构造器和 ...

  7. Permit.js – 用于构建多状态原型的 jQuery 插件

    Permit.js 是一个 jQuery 插件,用于构建交互的,多态的网站原型和应用程序原型.也许你的网站有的功能仅适用于登录的成员,只有管理员才能使用或者你的应用程序会根据线上或离线有不同的功能,这 ...

  8. Dynatable – 基于 HTML5 & jQuery 的交互表格插件

    Dynatable 一款有趣的,语义化,交互式的表格插件,使用 jQuery,HTML5 和 JSON 实现.Dynatable 的目的是提供一种简单的.可扩展的 API,能够轻松的浏览和操作大规模的 ...

  9. 移动端事件touchstart、touchmove、touchend

    关于这三个移动端的事件,详细的资料网上一搜一大片,我就不浪费时间了 1.移动端长按事件 var timer = null; $(ele).on('touchstart',function(){ tim ...

  10. JavaScript学习笔记-函数

    函数的两种创建方式:函数定义表达式.函数声明语句 编译时,函数声明语句创建的函数会‘被提前’至外部函数的作用域顶部,在该作用域内可以被随意调用: 而函数表达式创建的函数,要调用它必须赋值给一个变量,编 ...