Java中不同对象调用该实例方法返回值是同一个地址空间吗?
Posted 武帅祺的官方网站
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Java中不同对象调用该实例方法返回值是同一个地址空间吗?相关的知识,希望对你有一定的参考价值。
结论
- 不一定。
- 基本类型返回的是值要 引用数据类型返回的是引用地址(是否用到常量池)
- \'==\' 基本类型比较的是两者的值是否相同 而引用类型比较两者的是引用地址是否相同
基本类型
返回的值相同 \'==\'就为true
public int m1()
return -1;//obj.m1()==obj.m2() true
public double m2()
return 2.2;//obj.m2()==obj.m2() true
引用类型
返回的引用地址相同 \'==\'就是true
public String m3()
return "m3";//obj.m3()==obj.m3() true
//"m3"在常量池中 所以返回的引用地址相同(指向常量池中的地址)
public String m4()
return new String("m4");//odj.m4()==obj.m4() false
//new实例会在堆内存中开辟内存空间 即返回的引用地址不同(返回堆中的地址) 所以false
java中构造方法和方法有啥区别
我不知道怎么和你解释,所以在网上找了点资料,希望可以帮助你。构造方法要与类名相同,无返回类型,在类初始化的时候调用。
方法最好与类名不同,对象调用,静态方法可用类名.方法().
功能和作用的不同
构造器是为了创建一个类的实例。这个过程也可以在创建一个对象的时候用到:Platypus p1 = new Platypus();
相反,方法的作用是为了执行java代码。
修饰符,返回值和命名的不同
构造器和方法在下面三个方便的区别:修饰符,返回值,命名。和方法一样,构造器可以有任何访问的修饰: public, protected, private或者没有修饰(通常被package 和 friendly调用). 不同于方法的是,构造器不能有以下非访问性质的修饰: abstract, final, native, static, 或者 synchronized。
返回类型也是非常重要的。方法能返回任何类型的值或者无返回值(void),构造器没有返回值,也不需要void。
最后,谈谈两者的命名。构造器使用和类相同的名字,而方法则不同。按照习惯,方法通常用小写字母开始,而构造器通常用大写字母开始。构造器通常是一个名词,因为它和类名相同;而方法通常更接近动词,因为它说明一个操作。
"this"的用法
构造器和方法使用关键字this有很大的区别。方法引用this指向正在执行方法的类的实例。静态方法不能使用this关键字,因为静态方法不属于类的实例,所以this也就没有什么东西去指向。构造器的this指向同一个类中,不同参数列表的另外一个构造器,我们看看下面的代码:
public class Platypus
String name;
Platypus(String input)
name = input;
Platypus()
this("John/Mary Doe");
public static void main(String args[])
Platypus p1 = new Platypus("digger");
Platypus p2 = new Platypus();
在上面的代码中,有2个不同参数列表的构造器。第一个构造器,给类的成员name赋值,第二个构造器,调用第一个构造器,给成员变量name一个初始值 "John/Mary Doe".
在构造器中,如果要使用关键字this,那么,必须放在第一行,如果不这样,将导致一个编译错误。
"super"的用法
构造器和方法,都用关键字super指向超类,但是用的方法不一样。方法用这个关键字去执行被重载的超类中的方法。看下面的例子:
class Mammal
void getBirthInfo()
System.out.println("born alive.");
class Platypus extends Mammal
void getBirthInfo()
System.out.println("hatch from eggs");
System.out.print("a mammal normally is ");
super.getBirthInfo();
在上面的例子中,使用super.getBirthInfo()去调用超类Mammal中被重载的方法。
构造器使用super去调用超类中的构造器。而且这行代码必须放在第一行,否则编译将出错。看下面的例子:
public class SuperClassDemo
SuperClassDemo()
class Child extends SuperClassDemo
Child()
super();
在上面这个没有什么实际意义的例子中,构造器 Child()包含了 super,它的作用就是将超类中的构造器SuperClassDemo实例化,并加到 Child类中。
编译器自动加入代码
编译器自动加入代码到构造器,对于这个,java程序员新手可能比较混淆。当我们写一个没有构造器的类,编译的时候,编译器会自动加上一个不带参数的构造器,例如:public class Example
编译后将如下代码:
public class Example
Example()
在构造器的第一行,没有使用super,那么编译器也会自动加上,例如:
public class TestConstructors
TestConstructors()
编译器会加上代码,如下:
public class TestConstructors
TestConstructors()
super;
仔细想一下,就知道下面的代码
public class Example
经过会被编译器加代码形如:
public class Example
Example()
super;
继承
构造器是不能被继承的。子类可以继承超类的任何方法。看看下面的代码:
public class Example
public void sayHi
system.out.println("Hi");
Example()
public class SubClass extends Example
类 SubClass 自动继承了父类中的sayHi方法,但是,父类中的构造器 Example()却不能被继承。
总结
主题
构造器
方法
功能
建立一个类的实例
java功能语句
修饰
不能用bstract, final, native, static,
or synchronized
能
返回类型
没有返回值,没有void
有返回值,或者void
命名
和类名相同;通常为名词,大写开头
通常代表一个动词的意思,小写开头
this
指向同一个类中另外一个构造器,在第一行
指向当前类的一个实例,不能用于静态方法
super
调用父类的构造器,在第一行
调用父类中一个重载的方法
继承
构造器不能被继承
方法可以被继承
编译器自动加入一个缺省的构造器
自动加入(如果没有)
不支持
编译器自动加入一个缺省的调用到超类的构造器
自动加入(如果没有)
不支持
构造方法,可以理解为在对象使用之前必须调用的方法,而该类当中的其他方法则没这个必要
所以在创建对象的时候,不但要分配内存,还要调用构造方法
细微的差别
构造方法必须没有返回值,其他方法必须有返回值
构造方法有默认构造方法,而其他方法没有
java 类当中方法有返回值,并且习惯方法名开头小写!
构造方法没有返回值,而其写法特殊是
public/private + 类名 +()+。是固定的
例如
class A
private int id;
private String name;
public A()
public A(int id,String name)
this.id = id;
this.name = name;
第一个 public A()是缺省的构造方法,第二是重载Full的构造方法。 参考技术A 区别如下:
1.返回值的区别
构造方法:没有返回值。
方法:有返回值。
2.命名方式的区别
构造方法:构造方法名称要与类名相同。
方法:只要符合java命名规范即可。
以上是关于Java中不同对象调用该实例方法返回值是同一个地址空间吗?的主要内容,如果未能解决你的问题,请参考以下文章