目录
- 一、构造方法
- 1、构造方法的特点:
- 2、构造方法分类
- 3、构造方法的重载
- 4、构造方法中的 this
- 二、类方法、类变量、实例方法、实例变量
- 三、类方法(静态方法,用static修饰的方法)
-
一、构造方法
跟类名相同的方法名
被称作构造方法
,其作用是用于当一个类被new成对象时,对象需要声明的一些变量的构造声明。
1、构造方法的特点:
(1)构造方法的名字必须与定义他的类名完全相同(甚至连void也没有),且没有返回类型;
(2)构造方法的调用是在创建一个对象时使用new操作进行的。构造方法的作用是初始化对象
。
Person p = new Person(); : person() 调用的就是Person的构造方法。
(3)每个类可以有零个或多个构造方法;
(4)不能被static、final、synchronized、abstract和native修饰。且构造方法不能被子类继承。
(5)构造方法在创建对象时自动执行
,一般不能显式地直接调用。
2、构造方法分类
(1)默认构造方法 ----老马 p59
class Banana{
public Banana() { System.out.println("无参的构造方法被调用,这里是香蕉"); }
}
public class text3 {
public static void main(String[] args) {
Banana s = new Banana();
}
}
从代码和结果可以看出,“new Banana()” 除了实例化对象,还调用了构造方法Banana();
一旦定义了构造方法,Java就不会再自动生成默认构造方法。
如果只定义了第二个构造方法(带参数的),则下面语句:
Point p = new Point();
就会报错,因为找不到不带参数的构造方法。
(2)带参数的构造方法
class Apple{
int size;
public Apple(int a) {
System.out.println("有参的构造方法被调用,这里是苹果");
size = a;
}
public void shuchu() { System.out.println("这个苹果有" + size + "这么大"); }
}
public class text3 {
public static void main(String[] args) {
Apple apple = new Apple(18);
apple.shuchu();
}
}
- 从代码和结果可以看到
Apple(int a)
这是一个有参的构造方法,在new Apple(18)
实例化对象的同时,把参数传给a赋值给size并调用了shuchu()这个构造方法。
(3)私有构造方法:修饰符为 private
场景:
1)不能创建类的实例,类只能被静态访问,如Math、Arrays类,它们的构造方法就是私有的。
2)能创建类的实例,但只能被类的静态方法调用。单例场景。
3)只是用来被其他多个构造函数调用,用来减少重复代码。
3、构造方法的重载
class Food{
String name;
int size;
public Food(String b , int a) {
name = b;
size = a;
}
public Food(String b) {
name = b;
}
public Food(int a) {
size = a;
}
public void shuchu() {
System.out.println("这个" + name +"有" + size + "这么大");
}
}
public class text4 {
public static void main(String[] args) {
Food s = new Food("苹果");
Food x = new Food("草莓",18);
Food z = new Food(20);
s.shuchu();
x.shuchu();
z.shuchu();
}
}
4、构造方法中的 this
this的第1种用法:this 表示当前实例;
this的第2种用法:调用第2个构造方法;
new Point() 的时候:
(1)分配存放实际数据的内存;
(2)给实例变量设置默认值,new Point() 设置的默认值为0;
(3)调用构造方法(构造函数);
public class Point() {
private int x;
private int y;
public void setX(int x) {
this.x = x;
}
public void setY(int y) {
this.y = y;
}
public Point() {
this(0, 0);
}
public Point(int x, int y) {
this.x = x;
this.y = y;
}
}
----《Java编程的逻辑》马俊昌 p59
二、类方法、类变量、实例方法、实例变量
(1)类方法:static修饰,静态方法,静态方法是没有this的方法。
(2)类变量:static修饰,静态变量。
(3)实例方法
(4)实例变量
与static相对应的是【实例变量】【实例方法】,没有static修饰符。
Arrays类就只有类方法。 ----《Java编程的逻辑》p54
三、类方法(静态方法,用static修饰的方法)
静态方法
是属于整个类的,所以静态方法
的方法体中,不能有 与类的对象有关的内容(实例对象、实例方法
是属于类的对象)。即类方法体有如下限制:
静态方法
只能访问静态变量
,不能访问实例变量
,可以调用其他的静态方法
,不能调用实例方法
。
注释:IDEA中调代码时,main方法就是静态方法,也只能访问静态方法、静态变量。
实例方法
既能访问实例变量
,也能访问静态变量
,既可以调用实例方法
,也可以调用静态方法
。 ----《Java编程的逻辑》p55
规定:使用类名来调用静态方法,而不要使用实例或表达式来调用。 ----《Java核心技术 卷I》p117、Java语言编程规范
静态方法
不能被覆盖(重写)
;静态方法
中不能使用super,this
关键字;实例方法
中可以调用静态方法
;实例方法
中可以使用super,this
关键字;
四、类方法与实例方法的区别
静态方法
在加载类时就被分配了内存地址,因此加载后即可被任意对象调用,并且可以通过类名直接调用(类名.方法名)。实例方法
需要在创建对象后才会被分配内存地址,所以实例方法不能通过类名调用。
五、继承和多态
(1)每一个类有且只有一个父类
,没有声明父类的,其父类为Object。
(2)子类继承了父类非private
的属性和方法,可以增加自己的属性和方法,以及重写父类的方法实现。
(3)在 new
的过程中,父类先进行初始化。
(4)
public class Base {
public static String s = "static_base";
public String m = "base";
public static String s_static_base = "s_static_base";
public String m_base = "m_base";
public static void staticTest() {
System.out.println("base static.");
}
public void notStaticTest() {
System.out.println("base not static.");
}
public void notStaticTest_base() {
System.out.println("base_not_static_base.");
}
private void privateTest() {
System.out.println("base private.");
}
}
package org.example;
public class Child extends Base{
public static String s = "static_child";
public String m = "child";
public static String s_static_child = "s_static_child";
public String m_child = "m_child";
public static void staticTest() {
System.out.println("child static.");
}
public void notStaticTest() {
System.out.println("child not static.");
}
public void notStaticTest_child() {
System.out.println("base_not_static_child.");
String s = m_base;
}
private void privateTest() {
System.out.println("child private.");
}
}
public class Test {
public static void main(String[] args) {
Child c = new Child();
Base b = c;
System.out.println(b.s);
System.out.println(b.m);
System.out.println(c.s);
System.out.println(c.m);
System.out.println(b.m_base);
System.out.println(c.m_child);
System.out.println(c.m_base);
System.out.println(b.s_static_base);
System.out.println(c.s_static_child);
System.out.println(c.s_static_base);
b.staticTest();
c.staticTest();
b.notStaticTest();
c.notStaticTest();
b.notStaticTest_base();
c.notStaticTest_child();
c.notStaticTest_base();
}
}
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)