【0基础学Java第七课】-- 类和对象02

news2024/11/25 6:54:57

7.类和对象02

  • 7.6 封装
    • 7.6.1 封装的概念
    • 7.6.2 访问限定符
    • 7.6.3封装扩展之包
      • a.包的概念
      • b. 导入包中的类
      • c. 自定义包
      • d 常见的包
  • 7.7 static 成员
    • 7.7.2 静态修饰成员变量
    • 7.7.4 static修饰成员方法
    • 7.7.5 static成员变量初始化
  • 7.8 代码块
    • 7.8.1 代码块概念以及分类
    • 7.8.2 普通代码块
    • 7.8.3 构造代码块
    • 7.8.4 静态代码块
  • 7.10 对象的打印

7.6 封装

7.6.1 封装的概念

面向对象程序三大特性:封装、继承、多态。而类和对象阶段,主要研究的就是封装特性,何为封装呢?简单来说就是套壳屏蔽细节。
比如:对于电脑这样一个复杂的设备,提供给用户的就只是:开关机、通过键盘输入,显示器,USB插孔等,让用户来和计算机进行交互,完成日常事务。但实际上:电脑真正工作的却是CPU、显卡、内存等一些硬件元件。
对于计算机使用者而言,不用关心内部核心部件,比如主板上线路是如何布局的,CPU内部是如何设计的等,用户只需要知道,怎么开机、怎么通过键盘和鼠标与计算机进行交互即可。因此计算机厂商在出厂时,在外部套上壳子,将内部实现细节隐藏起来,仅仅对外提供开关机、鼠标以及键盘插孔等,让用户可以与计算机进行交互即可。
封装:将数据和操作数据的方法进行有机结合,隐藏对象的属性和实现细节,仅对外公开接口来和对象进行 交互

class Student {
    //构造方法也是可以被封装的  只能在当前类当中使用
    private String name;  //private  当前成员变量只能在当前类中使用
    public int age;
    
    public Student(String name, int age) {
        this.name = name;
        this.age = age;
    }

    public void setName(String name) {
        this.name = name;
    }
    public void eat() {
        System.out.println(this.name+" 正在吃饭!");
        //Student student = new Student("张三",10);
    }
    public String getName() {
        return this.name;
    }
}

public class Test {
    public static void main(String[] args) {
        Student student = new Student("张三",10);
        //student.name = "xiao";  实现封装后 类外就无法 拿到这个name字段了
        student.setName("小王");
        System.out.println(student.getName());
        student.eat();
    }
}

注意:

  • 实现封装后 类外就无法拿到封装里的字段
  • 构造方法也是可以被封装的 只能在当前类当中使用

7.6.2 访问限定符

Java中主要通过类和访问权限来实现封装:类可以将数据以及封装数据的方法结合在一起,更符合人类对事物的认知,而访问权限用来控制方法或者字段能否直接在类外使用。Java中提供了四种访问限定符:

在这里插入图片描述说明:

  • protected主要是用在继承中,继承部分详细介绍
  • default权限指:什么都不写时的默认权限
  • 访问权限除了可以限定类中成员的可见性,也可以控制类的可见性

一般情况下成员变量设置为private,成员方法设置为public。

7.6.3封装扩展之包

a.包的概念

在面向对象体系中,提出了一个软件包的概念,即:为了更好的管理类,把多个类收集在一起成为一组,称为软件包。有点类似于目录。比如:为了更好的管理电脑中的歌曲,一种好的方式就是将相同属性的歌曲放在相同文件下,也可以对某个文件夹下的音乐进行更详细的分类。
在这里插入图片描述
在Java中也引入了包,包是对类、接口等的封装机制的体现,是一种对类或者接口等的很好的组织方式,比如:一个包中的类不想被其他包中的类使用。包还有一个重要的作用:在同一个工程中允许存在相同名称的类,只要处在不同的包中即可

b. 导入包中的类

Java 中已经提供了很多现成的类供我们使用. 例如Date类:可以使用 java.util.Date 导入 java.util 这个包中的 Date类.

public class Test {
	public static void main(String[] args) {
		java.util.Date date = new java.util.Date();
		// 得到一个毫秒级别的时间戳
		System.out.println(date.getTime());
	}
}

但是这种写法比较麻烦一些, 可以使用 import语句导入包.

import java.util.Date;
public class Test {
	public static void main(String[] args) {
		Date date = new Date();
		// 得到一个毫秒级别的时间戳
		System.out.println(date.getTime());
	}
}

如果需要使用 java.util 中的其他类, 可以使用 import java.util.*

mport java.util.*;
public class Test {
	public static void main(String[] args) {
		Date date = new Date();
		// 得到一个毫秒级别的时间戳
		System.out.println(date.getTime());
	}
}

但是我们更建议显式的指定要导入的类名. 否则还是容易出现冲突的情况.

import java.util.*;
import java.sql.*;
public class Test {
	public static void main(String[] args) {
		// util 和 sql 中都存在一个 Date 这样的类, 此时就会出现歧义, 编译出错
		Date date = new Date();
		System.out.println(date.getTime());
	}
}
// 编译出错Error:(5, 9) java: 对Date的引用不明确
//java.sql 中的类 java.sql.Date 和 java.util 中的类 java.util.Date 都匹配

在这种情况下需要使用完整的类名

import java.util.*;
import java.sql.*;
public class Test {
	public static void main(String[] args) {
		java.util.Date date = new java.util.Date();
		System.out.println(date.getTime());
	}
}

可以使用import static导入包中静态的方法和字段。

import static java.lang.Math.*;
public class Test {
	public static void main(String[] args) {
		double x = 30;
		double y = 40;
		// 静态导入的方式写起来更方便一些.
		// double result = Math.sqrt(Math.pow(x, 2) + Math.pow(y, 2));
		double result = sqrt(pow(x, 2) + pow(y, 2));
		System.out.println(result);
	}
}

c. 自定义包

基本规则

  • 在文件的最上方加上一个 package 语句指定该代码在哪个包中.
  • 包名需要尽量指定成唯一的名字, 通常会用公司的域名的颠倒形式(例如 com.bit.demo1 ).
  • 包名要和代码路径相匹配. 例如创建 com.bit.demo1 的包, 那么会存在一个对应的路径 com/bit/demo1 来存储代码.
  • 如果一个类没有 package 语句, 则该类被放到一个默认包中.

操作步骤

  1. 在 IDEA 中先新建一个包: 右键 src -> 新建 -> 包

在这里插入图片描述
2. 在弹出的对话框中输入包名, 例如 com.bit.demo1

在这里插入图片描述

  1. 在包中创建类, 右键包名 -> 新建 -> 类, 然后输入类名即可.

在这里插入图片描述

  1. 此时可以看到我们的磁盘上的目录结构已经被 IDEA 自动创建出来了
    在这里插入图片描述

  2. 同时我们也看到了, 在新创建的 Test.java 文件的最上方, 就出现了一个 package 语句
    在这里插入图片描述

d 常见的包

  1. java.lang:系统常用基础类(String、Object),此包从JDK1.1后自动导入。
  2. java.lang.reflect:java 反射编程包;
  3. java.net:进行网络编程开发包。
  4. java.sql:进行数据库开发的支持包。
  5. java.util:是java提供的工具程序包。(集合类等) 非常重要
  6. java.io:I/O编程开发包。

7.7 static 成员

不加static和使用static区别:
在这里插入图片描述在这里插入代码片
在这里插入图片描述

7.7.2 静态修饰成员变量

import java.util.Arrays;
import java.util.*; // 通配符的意思,要哪一个就匹配哪一个
import java.util.Date;
class Student {
    //构造方法也是可以被封装的  只能在当前类当中使用
    private String name;  //private  当前成员变量只能在当前类中使用
    public int age;
    public static String classRoom;

    public String getClassRoom() {
        return classRoom;
    }

    public void setClassRoom(String classRoom) {
        this.classRoom = classRoom;
    }

    public Student(String name, int age) {
        this.name = name;
        this.age = age;
    }
}
public class Test {
    public static void main(String[] args) {
        Student.classRoom = "2-201"; // 静态成员变量。类名.访问
    }
    public static void main5(String[] args) {
        Student student1 = new Student("x",10);
        student1.classRoom="2-201"; // 非静态成员变量。对应的引用.访问
        Student student2 = new Student("j",11);
        Student student3 = new Student("h",12);
    }
}

总结:类的成员变量

  1. 静态成员变量
  • 属于类的,不属于对象的,只有1份
  • 类名+点号来访问静态成员变量【类名访问合理,而 对象来访问不合理】
  1. 非静态成员变量/普通成员变量
  • 属于对象的,每次实例化一个对象,都会有一个对应的非静态成员变量,每个对象都有。
  • 对应的引用+点好来访问

注意:静态的成员变量 ,随着类被加载而创建,类被销毁而销毁

7.7.4 static修饰成员方法

    public static void sleep() {
        //System.out.println(this.name+" 正在睡觉!");//报错,在静态方法的内部
        // 不能使用非静态的数据成员   this不能出现在静态方法当中
        System.out.println(" 正在睡觉!");
    }
    
    public static void main(String[] args) {
        Student.classRoom = "2-201"; // 静态成员变量。类名.访问
        /*Student student1 = new Student("zhansan",10);  //非静态
        student1.sleep();*/
        Student.sleep();  //静态
    }

注意:
在静态方法内部,不能使用非静态的数据成员,this不能出现在静态方法中,反之非静态方法当中可以调用静态方法
而一个依赖对象的方法,当中 可以有不依赖对象的

在这里插入图片描述

7.7.5 static成员变量初始化

静态成员变量一般不会放在构造方法中来初始化,构造方法中初始化的是与对象相关的实列属性。
静态成员变量的初始化分为两种:就地初始化和静态代码块初始化。

  1. 就地初始化:在定义时直接给出初始值
public class Student{
	private String name;
	private String gender;
	private int age;
	private double score;
	private static String classRoom = "306";
}
  1. 静态代码块初始化如下:

7.8 代码块

7.8.1 代码块概念以及分类

使用{}定义的一段代码称为代码块。根据代码块定义的位置以及关键字,分为一下四种:

  • 普通代码块
  • 构造块
  • 静态块
  • 同步代码块

7.8.2 普通代码块

普通代码块:定义在方法中的代码块

public class Main{
	public static void main(String[] args) {
		{ //直接使用{}定义,普通方法块
		int x = 10 ;
		System.out.println("x1 = " +x);
		}
	int x = 100 ;
	System.out.println("x2 = " +x);
	}
}
//x1 = 10  x2 = 100

7.8.3 构造代码块

构造块:定义在类中的代码块(不加修饰符)。也叫:实例代码块。构造代码块一般用于初始化实列成员变量

class TestStatic {
    public static int staticNum = 100000;
    public int date1 = 10;
    {
        //构造 / 实例 代码块
        System.out.println("实例代码块执行了");
        date1 = 1000;  // 一般情况下 用来初始化 非静态的数据成员
        //staticNum = 100;  // 也可以初始化静态的数据成员

    }
    static {
        System.out.println("静态代码块执行了");
        staticNum = 999;
    }
    // 先执行静态代码块 后执行实列代码块
    public static void main(String[] args) {
        TestStatic testStatic = new TestStatic();
        System.out.println(testStatic.date1);
        System.out.println(TestStatic.staticNum);  //只要类被加载 就会执行静态代码块
    }
}

在这里插入图片描述

注意:

  • 实例代码块一般情况下 用来初始化 非静态的数据成员,也可以初始化静态的数据。
  • 一定最先执行静态代码块 后执行实列代码块
  • 只要类被加载 就会执行静态代码块
  • 当都是静态的时候 按照定义的顺序执行

7.8.4 静态代码块

使用static定义的代码块称为静态代码块。一般用于初始化静态成员变量。

class TestStatic {
    public static int staticNum = 100000;
    public int date1 = 10;
    {
        //构造 / 实例 代码块
        System.out.println("实例代码块执行了");
        date1 = 1000;  // 一般情况下 用来初始化 非静态的数据成员
        //staticNum = 100;  // 也可以初始化静态的数据成员

    }

    // 多个静态代码块在编译时,会按照定义顺序来执行(合并),
    static {
        System.out.println("静态代码块执行了");
        staticNum = 999;
    }
    static {
        staticNum = 888;
    }
    // 先执行静态代码块 后执行实列代码块
    public static void main(String[] args) {
        TestStatic testStatic = new TestStatic();
        System.out.println(testStatic.date1);
        System.out.println(TestStatic.staticNum);  //只要类被加载 就会执行静态代码块
    }
}

注意:

  • 静态代码块不管生成多少个对象,其只会执行一次
  • 静态成员变量是类的属性,因此是在JVM加载类时开辟空间并初始化的
  • 如果一个类中包含多个静态代码块,在编译代码时,编译器会按照定义的先后次序依次执行(合并)
  • 实例代码块只有在创建对象时才会执行

7.10 对象的打印

Dog.java

package com.bit.www;

public class Dog {
    // 姓名
    private String name;
    // 年龄
    private int age;
    // 颜色
    private String color;

    public Dog() {

    }

    //构造方法  用来实例化狗的对象
    public Dog(String name, int age, String color) {
        this.name = name;
        this.age = age;
        this.color = color;
    }

    public String getName() {
        return name;
    }

    public void setName(String name) {
        this.name = name;
    }

    public int getAge() {
        return age;
    }

    public void setAge(int age) {
        this.age = age;
    }

    public String getColor() {
        return color;
    }

    public void setColor(String color) {
        this.color = color;
    }

    public void barks() {
        System.out.println(this.name+" 在狗叫");
    }

    public void eat() {
        System.out.println(this.name+" 在干饭");
    }

    public static void staticFun() {
        System.out.println("staticFun");
    }

    // 打印所有属性
    public void show() {
        System.out.println("狗名:"+this.name
        +" 年龄:"+this.age+" 颜色:"+this.color);
    }

/*    public String toString() {
        String ret = "狗名:"+this.name
                +" 年龄:"+this.age+" 颜色:"+this.color;
        return ret;
    }*/

    @Override //注解  当前这个代码是重写的
    public String toString() {
        return "Dog{" +
                "name='" + name + '\'' +
                ", age=" + age +
                ", color='" + color + '\'' +
                '}';
    }
}

Test.java

package com.bit.www;
import com.bit.demo1.TestDemo;

public class Test {
    public static void main(String[] args) {
        Dog dog = new Dog();
        dog.setName("旺财");
        dog.setAge(4);
        dog.setColor("黄色");
//        dog.barks();
//        dog.eat();
        //dog.show();
        System.out.println(dog);
        //分析 System.out.println(dog);
        //com.bit.www.Dog@1b6d3586
        //Dog这个类的路径    对象地址的哈希值


    }
}

在这里插入图片描述

在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1179597.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Linux个性化登录提示信息

在Linux系统中,您可以为每个用户登录后显示个性化的提示信息。这通常通过修改用户的shell配置文件来实现,这个文件通常是用户的.bashrc或.bash_profile文件。以下是一些示例步骤,来实现这个目标: 打开终端并登录到Linux系统。 使…

AI:64-基于深度学习的口罩佩戴检测

🚀 本文选自专栏:AI领域专栏 从基础到实践,深入了解算法、案例和最新趋势。无论你是初学者还是经验丰富的数据科学家,通过案例和项目实践,掌握核心概念和实用技能。每篇案例都包含代码实例,详细讲解供大家学习。 📌📌📌在这个漫长的过程,中途遇到了不少问题,但是…

“2024上海智博会”为我国智能科技产业发展注入新的动力

作为开年智能科技第一展“2024上海智博会”将于2024年三月份在国际大都市上海隆重召开,本届展会将充分展示我国智能科技产业新技术、新产品及未来发展方向。 据悉,本届展会将汇聚全球智能科技产业的领军企业和人物,共同探讨和分享最新的技术趋…

Mysql8与mariadb的安装与常用设置

一、v10服务器mariadb的安装与常用设置 V10服务器默认安装了mariadb数据库。也可使用命令sudo yum install mariadb手动安装或升级默认安装的版本。 1.1 修改数据库密码 systemctl restart mariadb,重启mariadb服务;mysql -u root -p,要求输入密码直接回车&#…

贝叶斯建模:从先验合理性到后验分布

一、说明 本文探讨贝叶斯模型,首先用摸球游戏展开模型构建步骤,然后讨论分类算法,以及实际操作方法:网格法、二次近似、蒙特卡洛。 二、针对贝叶斯的模型构建 2.1 分支剪枝和假设 在贝叶斯分析中,我们可以将这个过程想…

【C++】多文件的代码规范

算是C嘎嘎入门教程(但至少需要知道HelloWorld怎么写 内容不能说全,因为是想到哪写到哪,再次就是C是真的很杂。 (写完后博文编辑器提示我,本文章可能要20分钟读完,做好心理准备… 1、头文件(*.h)、源文件(*.cpp) 头文件…

bin.zip和bin.tar.gz以及src.zip和src.tar.gz以及rpm和dmg的区别

下载JDK时Java Downloads | Oracle会有很多文件,时间长了容易混淆,在此记录一下。 如上面三张图所示: bin代表二进制文件,是编译后的文件,而src是源码。.tar.gz是linux的压缩包,.zip是windows的压缩包 所以: bin.ta…

11.6哈夫曼树

创建哈夫曼树 经过这一步后,树的集合里就有n个叶子结点 不断从树集合里取出两个权重最小的树合并成一个新树,这时候就是两个根节点并成兄弟到一个新的根节点下,这个新的根节点的权重是两个兄弟的权重和,之后再把 每次合并的时…

32岁华为员工合同不续约,赔偿N+1,额外3个月年终奖,加班费10万+,总共25万多...

各位中生代社区的读者大大们好,我是你们的老朋友大白:) 一直以来,IT行业都有着“程序员是吃青春饭”的说法,这一年龄危机甚至逐渐演变为“45岁退休,35岁换人”的段子。 作为国内知名互联网大厂,华为近几年就曾几次三番…

Bash脚本实现Linux开机自启Redis,Nginx,MySQL等服务

一. MySQL服务自启 在CentOS 7及以上版本,MySQL以服务形式进行启动,运行两行命令即可实现。 systemctl start mysqld systemctl enable mysqld 只需运行一次即可实现MySQL开机自启动 二. 编写bash脚本 使用bash命令编写脚本实现 #!/bin/bashfunction …

linux下实现电脑开机后软件自启动

实现linux的软件自启动,需要四个文件 第一个【displayScreen.desktop】文件,.desktop文件就是一个用来运行程序的快捷方式,也叫启动器,常用来自启动用的文件,内容如下 [Desktop Entry] #要执行的脚本位置 Exec/home/yicaobao/te…

19.7 Boost Asio 传输序列化数据

序列化和反序列化是指将数据结构或对象转换为一组字节,以便在需要时可以将其存储在磁盘上或通过网络传输,并且可以在需要时重新创建原始对象或数据结构。 序列化是将内存中的对象转换为字节的过程。在序列化期间,对象的状态被编码为一组字节…

串台 fit4life | 催吐辟谷减肥药,你没看错这就是我们仨的黑历史!

点击文末“阅读原文”即可参与节目互动 剪辑、音频 / 卷圈 运营 / SandLiu 卷圈 监制 / 姝琦 封面 / 姝琦Midjourney 产品统筹 / bobo 场地支持 / 声湃轩北京录音间 运动博主/食品博士/营养师居然也都曾有程度不同的进食障碍?! 是,这没…

笔记本电脑 禁用/启用 自带键盘

现在无论办公还是生活 很多人都会选择笔记本电脑 但很多人喜欢机械键盘 或者 用一些外接键盘 但是很多时候我们想操作 会碰到笔记本原来的键盘导致错误操作 那么 我们就需要将笔记本原来的键盘禁用掉 我们先以管理员身份运行命令窗口 然后 有两个命令 禁用默认键盘 sc conf…

Apex的addError()显示的消息中实现换行

直接用‘<br/>’是无效的&#xff0c;因为addError默认不转义HTML符号&#xff0c;如果需要转义&#xff0c;应该将第二个参数escape设置为false。不过即使设置了也只对classic页面生效&#xff0c;lightning页面还是无法转义。 官方文档&#xff1a; 参考资料&#xf…

QQ邮箱批量发送

场景 已有用户邮箱,需要批量对他们发送一些广告信息。 完整代码 # coding=gbk import smtplib import csv from email.mime.text import MIMEText from email.mime.multipart import MIMEMultipartdef send_email(msg_from, passwd, msg_to_list, text_content)

服务器数据恢复—误还原虚拟机快照后如何恢复之前的数据?

服务器数据恢复环境&#xff1a; vmfs文件系统&#xff0c;存放的是SqlServer数据库及其他办公文件。 服务器故障&#xff1a; 工作人员误操作还原快照&#xff0c;导致了SqlServer数据库数据丢失。 服务器数据恢复过程&#xff1a; 1、拿到故障服务器的所有磁盘后&#xff0c…

【Linux】拓展:运维面试题,进程管理常见的7大问题

目录 一、如何判断一个程序是单线程还是多线程 二、僵尸进程是什么&#xff0c;有什么危害&#xff0c;如何解决 三、如何找回删掉的文件 四、删除文件以后&#xff0c;空间不释放 五、遇到一个病毒&#xff08;如死循环病毒&#xff09;&#xff0c;解决思路 六、机器开机…

Pytorch里面参数更新前为什么要梯度手动置为0?

因为在一般情况下&#xff0c;每次minibatch之后&#xff0c;都会计算得到一个loss&#xff0c;进而计算该loss关于全局参数的梯度。如果在下一次minibatch 进入模型&#xff0c;计算得到相应的loss和梯度之前&#xff0c;不对优化器的梯度进行置0操作&#xff0c;那么几次batc…

生成式人工智能的“经济学”,The Economic Case for Generative AI#a16z

a16z召集了行业精英&#xff0c;为我们带来了有关生成式AI的洞察。在创造力方面&#xff0c;生成式AI带来了3-4倍量级的成本优势&#xff0c;更多新的需求将诞生。 AI REVOLUTION The Economic Case for Generative AI Martin Casado MixCopilot 大家好&#xff0c;欢迎来到本期…