Java构造方法(与类名相同的方法)、类方法、类变量、实例方法、实例变量

2023-05-16

目录

    • 一、构造方法
      • 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;  // this.x为实例变量x(无static修饰,能够被实例继承), 右侧的x为方法参数中的x
    }                // this的第一种用法:this表示当前实例
    public void setY(int y) {
        this.y = y;
    }
    public Point() {
        this(0, 0);  //this的第2种用法:调用第2个构造方法,并传递参数 "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;
        // 重名 静态绑定: 实例变量、静态变量、静态方法、private方法。
        // 重写:只用作实例方法(没有static修饰的方法, 属于实例对象的方法,实例对象可对其进行重写。)
        // "public VS private"
        System.out.println(b.s);  // static_base
        System.out.println(b.m);  // base
        System.out.println(c.s);  // static_child
        System.out.println(c.m);  // child

        // 实例变量、继承:子类中找不到,就调用父类变量、方法
        System.out.println(b.m_base);  // m_base(静态绑定)
        // System.out.println(b.m_child);      // error: Base 中找不到 m_child,不会到子类中去查找:显然不会到子类中去查找。
        System.out.println(c.m_child); // m_child(静态绑定)
        System.out.println(c.m_base);  // m_base
                                       // 子类中没有这个 实例变量,就到父类中寻找。

        // 静态变量
        System.out.println(b.s_static_base);  // s_static_base(静态绑定)
        // System.out.println(b.s_static_child);   // error: Base 中找不到 s_static_child
        System.out.println(c.s_static_child); // s_static_child(静态绑定)
        System.out.println(c.s_static_base);  // s_static_base
                                              // 子类中没有这个 静态变量,就到父类中寻找。

        // 静态方法
        b.staticTest();  // base static.(静态绑定)
        c.staticTest();  // child static.(静态绑定)

        // private方法: 只能在类中访问,不能在外部访问
        // b.privateTest();  // error
        // c.privateTest();  // error

        // 实例方法(属于实例对象的方法):被重写(子类重写与父类相同参数签名的方法)
        b.notStaticTest();  // child not static.
        c.notStaticTest();  // child not static.

        // 实例方法:继承
        b.notStaticTest_base();
        // b.notStaticTest_child();  // error 找不到
        c.notStaticTest_child();
        c.notStaticTest_base();      // 子类中没有这个 实例方法,就到父类中寻找。

        // 子类继承父类非private的属性和方法(实例变量、实例方法、静态变量、静态方法)
        // 静态绑定执行后,在子类中找不到的属性、方法,就到父类中找;父类不能反过来。

        // 静态变量、静态方法一般通过类名访问、但是也可以通过类的对象访问。
    }
}
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

Java构造方法(与类名相同的方法)、类方法、类变量、实例方法、实例变量 的相关文章

随机推荐

  • # Android中的任务和返回栈总结

    Android中的任务和返回栈 任务栈的基础知识 xff1a 任务是指在执行特定作业时与用户交互的一系列 Activity 这些 Activity 按照各自的打开顺序排列在堆栈 xff08 即 返回栈 xff09 中 为什么要用任务栈 为了
  • 低成本DIY:4G/5G网络遥控无人机-无人车-图传/数传/遥控一体!

    方案概述 无人机 无人车 无人船等机器 通过数据线连接安卓手机 xff0c 手机4G上网于是就可以实现超远程图传 数传和遥控 再在控制端手机上通过 2R酷玩 App远程操控 如果你本来就有一套常规遥控器控制的无人机 无人车的东西 xff0c
  • 你知道底层自旋锁是如何实现的吗

    我们在开发中 xff0c 经常会用到自旋锁 xff0c 对于使用接口来讲 xff0c 仿照例子谁都会用 xff0c 但是你知道其是如何实现自旋的吗 xff1f 今天我们就来讨论一下其实现原理 1 首先 xff0c 我们需要实现一个结构体用于
  • Ardupilot IMU恒温控制代码学习

    目录 文章目录 目录 摘要 第一章原理图学习 第二章恒温代码学习 1 目标温度怎么设置 摘要 本节主要学习ardupilot的IMU恒温控制代码 采用的飞控是pixhawk v5 欢迎一起交流学习 第一章原理图学习
  • Windows10安装或重装ubuntu18.04双系统教程(平民教程)

    一 引言 1 电脑配置 操作系统 xff1a Win10专业版机型 xff1a Dell G3 15 3500显卡 xff1a NVIDIA GeForce GTX 1660Ti内存 xff1a 32G硬盘 xff1a 双硬盘 xff08
  • 不同国家的日期写法

    题目描述 对于年 月 日的写法 xff0c 不同的国家有不同的描述形式 请按年 月 日的顺序读入日期 xff0c 然后分别输出中国式写法 xff08 年 月 日 xff09 xff0c 英国式写法 xff08 日 月 年 xff09 和美国
  • 二维数组最大值及位置

    题目描述 有一个3 4的矩阵 xff0c 要求编程求出其中值最大的那个元素 xff0c 以及其所在的行号和列号 xff08 如果最大数有多个 xff0c 则显示第1个出现的数据的信息 xff09 输入要求 从键盘输入12个数字组成一个3 4
  • 比较两个字符串的大小

    题目描述 设计函数 xff0c 比较两个字符串的大小 每个字符串长度不超过50 输入要求 从键盘分别读入两个字符串 xff0c 每个字符串以换行符结束 输出要求 比较两个串的大小 xff0c 输出相应的结果 输入样例 Hello hi 输出
  • 心形曲线(java)

    心形曲线java简易表示法 span class token keyword import span span class token namespace java span class token punctuation span awt
  • c++运行不输出结果怎么办

    C C 43 43 运行不出结果怎么调试 main函数中可在各个地方插入return 0提前结束程序 xff0c 直到有结果出现 xff0c 问题就出在return 0的下方 如果在自定义函数内部 xff0c 则需要使用exit xff08
  • 如何解决VS2019控制台输出中文乱码问题

    情况一 xff1a 下载插件 xff0c 将VS的输出编码更改为UTF 8 情况二 xff1a 如果已经装了UTF 8插件但是控制台输出的中文仍然是乱码 则按以下步骤进行 xff08 1 xff09 打开电脑的控制面板 xff0c 然后打开
  • 如何解决vs2019 scanf报错问题

    1 在程序最前面加 xff1a define CRT SECURE NO DEPRECATE 2 在程序最前面加 xff1a pragma warning disable 4996 3 将scanf改为scanf s 4 无需在程序前面加那
  • 函数曲线的绘制

    初等函数曲线的简易绘制 span class token macro property span class token directive keyword include span span class token string lt s
  • 花里胡哨的IDEA 2021启动界面

    一 前言 作为一个花里胡哨的男人 xff0c 总是在不停的研究各种花里胡哨的东西 xff0c 每次上机第一件事 xff0c 肯定是打开开发神器 xff1a Intellij IDEA 2021 xff0c 每次打开都是一个图片 xff0c
  • java中常见排序算法

    一 冒泡排序 span class token comment 64 author liyong 64 date 2021年12月02日 23 33 span span class token keyword public span spa
  • linux下栈空间大小(ulimit)

    linux下栈空间大小 第一次写博客 xff0c 很多地方写的不好请多见谅 xff0c 希望这篇文章对大家有帮助 首先说下为什么会写linux下栈空间大小这个内容 在评审同事代码的时候发现代码中有两个函数互相调用 xff0c 且无法退出导致
  • 解决npm WARN config global `--global`, `--local` are deprecated. Use `--location=global` instead.

    解决办法 https github com npm cli issues 4980 issuecomment 1145334203 解决步骤 xff08 1 xff09 找到装 node js 路径下的 npm cmd xff08 2 xf
  • 1. 两数之和【return new int[]{i, j}、hashtable.containsKey()、get、put】

    1 两数之和 给定一个整数数组 nums 和一个整数目标值 target xff0c 请你在该数组中找出 和为目标值 target 的那 两个 整数 xff0c 并返回它们的数组下标 你可以假设每种输入只会对应一个答案 但是 xff0c 数
  • yarn的安装和使用(极其详细)

    一 yarn的简介 xff1a Yarn是facebook发布的一款取代npm的包管理工具 二 yarn的特点 xff1a 速度超快 Yarn 缓存了每个下载过的包 xff0c 所以再次使用时无需重复下载 同时利用并行下载以最大化资源 利用
  • Java构造方法(与类名相同的方法)、类方法、类变量、实例方法、实例变量

    目录 一 构造方法1 构造方法的特点 xff1a 2 构造方法分类3 构造方法的重载4 构造方法中的 this 二 类方法 类变量 实例方法 实例变量三 类方法 xff08 静态方法 xff0c 用static修饰的方法 xff09 四 类