1. hashCode方法

代码:

package NeiBuLei;

public class hashCode {

    public static void main(String[] args) {
AA aa = new AA();
AA aa2 = new AA();
AA aa3 = aa;
AA aa4 = aa2;
System.out.println("aa.hashCode()="+ aa.hashCode()); //aa.hashCode()=2129789493
System.out.println("aa2.hashCode()="+ aa2.hashCode()); //aa2.hashCode()=1313922862
System.out.println("aa3.hashCode()="+ aa3.hashCode()); //aa3.hashCode()=2129789493
System.out.println("aa4.hashCode()="+ aa4.hashCode()); //aa4.hashCode()=1313922862 }
}
class AA{}

两个引用,如果指向的是同一个对象,则哈希值肯定一样

两个引用,如果指向的是不同对象,则哈希值是不一样的

哈希值主要根据地址号来!不能将哈希值完全等价于地址

2. toString方法

代码:

package NeiBuLei;
public class toString {
public static void main(String[] args) {
test test = new test(1,2,3);
test.toString();
System.out.println(test.toString());
}
}
class test{
public int name;
public int age;
public int score;
@Override
public String toString() {
return "test{" + "name=" + name + ", age=" + age + ", score=" + score + '}';
} public test() {
} public test(int name,int age,int score) {
this.name = name;
this.age = age;
this.score = score;
}
}

3.clone方法

代码:

package NeiBuLei;
//用于创建并返回一个对象的拷贝
// clone 方法是浅拷贝,对象内属性引用的对象只会拷贝引用地址,而不会将引用的对象重新分配内存,相对应的深拷贝则会连引用的对象也重新创建。
public class clone {
public static void main(String[] args) {
Charen p = new Charen(23, "zhang");
Charen p1 = p;
System.out.println(p); //NeiBuLei.Charen@7ef20235
System.out.println(p1); //NeiBuLei.Charen@7ef20235
//打印的地址值是相同的,既然地址都是相同的,那么肯定是同一个对象。p和p1只是引用而已,他们都指向了一个相同的对象
// 可以把这种现象叫做引用的复制
Charen s = new Charen(23, "zhang");
Charen s1 = null;
try { //要捕获
s1 = (Charen)s.clone();
} catch (CloneNotSupportedException e) {
e.printStackTrace();
}
//两个对象的地址是不同的,也就是说创建了新的对象, 而不是把原对象的地址赋给了一个新的引用变量
System.out.println(s); //NeiBuLei.Charen@27d6c5e0
System.out.println(s1); //NeiBuLei.Charen@4f3f5b24
}
}
class Charen implements Cloneable {
int age;
String name; public Charen() {
} public Charen(int age,String name) {
this.age = age;
this.name = name;
}
@Override //重写方法
protected Object clone() throws CloneNotSupportedException {
return (Charen)super.clone();
}
}

深拷贝:深复拷贝象所引用的对象都复制了一遍

浅拷贝:被复制对象的所有变量都含有与原来的对象相同的值,而所有的对其他对象的引用仍然指向原来的对象

浅复制仅仅复制所考虑的对象,而不复制它所引用的对象

String name 中name是String 引用,所以浅拷贝指向同一个name,深拷贝又复制了一个新的name,指向新复制的name。

4.getClass方法

代码:

package NeiBuLei;
//当垃圾收集确定不再有对该对象的引用时,垃圾收集器在对象上调用该对象
//返回对象的类
public class getClass {
public static void main(String[] args) {
Object o1= new Object();
System.out.println(o1.getClass()); //class java.lang.Object
A a = new A();
System.out.println(a.getClass()); //class NeiBuLei.A }
}
class A{}

用于返回对象的类

5.equals方法

==是一个比较运算符

  1. ==: 既可以判断基本类型,又可以判断引用类型
  2. ==: 如果判断的是基本类型,判断的是值是否相等
 //==: 如果判断的是基本类型,判断的是 值 是否相等
int x1 = 10;
int x2 = 10;
double x3 = 10.0;
System.out.println(x1 == x2);//true
System.out.println(x1 == x3);//true
  1. ==: 如果判断的是引用类型,判断的是地址是否相等,即判断是不是同一个对象
package denghao;
public class Test01 {
public static void main(String[] args) {
//==: 如果判断的是引用类型,判断的是地址是否相等,即判断是不是同一个对象
A a = new A();
A b = a;
A c = b;
System.out.println(a==c);// ? true
System.out.println(b==c);// true B obj = a;
System.out.println(obj==c);// true
}
}
class B{}
class A extends B{}

eauals:

只能判断引用类型

代码:

package NeiBuLei;

public class ObjectLei {
public static void main(String[] args) {
Person p1 = new Person();
p1.name = "zyx";
Person p2 = new Person();
p2.name = "zyx";
//flase //对象不同
System.out.println(p1 == p2);// 引用类型——判断是否为同一个对象(地址)
//true //字符串相同
System.out.println(p1.name.equals(p2.name));// p.name是String类型,重写了equals()方法——判断内容是否一样
//flase //对象不同
System.out.println(p1.equals(p2));//p1,p2属于Person类,该类并没有重写equals()方法(继承父类equals()方法,即判断地址) String s1 = new String("abc");
String s2 = new String("abc");
//true //字符串相同
System.out.println(s1.equals(s2));
//false //对象不同
System.out.println(s1 == s2);
}
}
class Person{
public String name;
}

6.wait和notify方法

代码:

package NeiBuLei;

//run()和start()方法属于线程类Thread
public class wait{
static Object locate=new Object();
public static class T1 extends Thread{ //T1线程
public void run(){
synchronized (locate){ //同步锁
System.out.println("T1 start");
try {
System.out.println("T1等待locate对象");
locate.wait();
} catch (InterruptedException e) {
e.printStackTrace();
}
System.out.println("T1 end");
}
} }
public static class T2 extends Thread{ //T2线程
public void run(){
synchronized (locate){ //同步锁
System.out.println("T2 被唤起");
locate.notify();
System.out.println("T2 end"); try {
Thread.sleep(5000);
} catch (InterruptedException e) {
e.printStackTrace();
}
}
}
} public static void main(String[] args) {
Thread t1=new T1();
Thread t2=new T2();
t1.start();
t2.start();
}
}

运行结果:

T1 start
T1等待locate对象
T2 被唤起
T2 end
//过几秒
T1 end

(1)对象的wait()方法和notify方法

Object.wait() 线程等待,当调用wait()方法,线程就是停止执行当前任务,转为等待,直到被唤起

Object.notify() 线程唤起,将等待状态下的线程唤起,继续执行任务

(2)线程wait()和notify()的工作原理:

当对象Object调用了wait()方法后,线程进入到Object对象的等待队列,多个线程等待同一个对象

当对象Object调用了wait()方法后,就会从等待队列里面随机选取一个线程并将其唤起,完全随机

(3)注意事项:

notifyALL():唤起所有等待序列的线程

wait()和notify()都必须先获取目标对象的监视器,这样才能进行后续工作

wait方法不能随便使用,必须包含在synchronized中

JavaSE常用类之Object类的更多相关文章

  1. java 常用类库:Object类和Objects类

    1,Object类: Object类是所有的类,数组,枚举的父类,也就是说,JAVA中允许把任何的对象赋值给Object类(包括基础数据类型),当定义一个类的时候,没有使用extends关键字显示指定 ...

  2. Java基础12:深入理解Class类和Object类

    更多内容请关注微信公众号[Java技术江湖] 这是一位阿里 Java 工程师的技术小站,作者黄小斜,专注 Java 相关技术:SSM.SpringBoot.MySQL.分布式.中间件.集群.Linux ...

  3. 夯实Java基础系列9:深入理解Class类和Object类

    目录 Java中Class类及用法 Class类原理 如何获得一个Class类对象 使用Class类的对象来生成目标类的实例 Object类 类构造器public Object(); register ...

  4. java class类和object类

    Class类 介绍 Java的Class类是java反射机制的基础,通过Class类我们可以获得关于一个类的相关信息 Java.lang.Class是一个比较特殊的类,它用于封装被装入到JVM中的类( ...

  5. Java基础知识强化26(1):Object类之Object类的概述

    1.Object类 类Object是类层次结构的根类,每个类都使用 Object作为超类.所有对象(包括数组)都实现这个类的方法 每个类直接或者间接继承自Object类   2.Object类无参构造 ...

  6. Java的常用API之Object类简介

    Object类 1.toString方法在我们直接使用输出语句输出对象的时候,其实通过该对象调用了其toString()方法. 2.equals方法方法摘要:类默认继承了Object类,所以可以使用O ...

  7. Java.lang 包 (包装类、String类、Math类、Class类、Object类)

    Java 的核心 API(Application Programming Interface)是非常庞大的,这给开发者带来了很大的方便. java.lang 包是 Java 的核心类库,它包含了运行 ...

  8. Java:面向对象(继承,方法的重写(overide),super,object类及object类中方法的重写,父子类代码块执行顺序)

    继承: 1.继承是对某一匹类的抽象,从而实现对现实世界更好的建模. 2.提高代码的复用性. 3.extends(扩展),子类是父类的扩展. 4.子类继承父类可以得到父类的全部属性和方法.(除了父类的构 ...

  9. Java笔记:与系统交互、系统相关的类,Object类

    1.程序与用户交互 (1)运行一个Java程序的时候要给它提供一个main方法入口,这边分析一下这个main方法的签名public static void main(String[] args);pu ...

  10. 各种异常 及异常类和Object类

    Day05 异常 Object类 equals方法,用于比较两个对象是否相同,它其实就是使用两个对象的内存地址在比较.Object类中的equals方法内部使用的就是==比较运算符. 2. 描述人这个 ...

随机推荐

  1. spring源码干货分享-对象创建详细解析(set注入和初始化)

    记录并分享一下本人学习spring源码的过程,有什么问题或者补充会持续更新.欢迎大家指正! 环境: spring5.X + idea 建议:学习过程中要开着源码一步一步过 Spring根据BeanDe ...

  2. Flink消费kafka

    Flink消费Kafka https://blog.csdn.net/boling_cavalry/article/details/85549434 https://www.cnblogs.com/s ...

  3. DataTemplate的用法

    WPF 模板主要分为两大类:1.ControlTemplate: 控件的外观,也就是控件是什么样子.2.DataTemplate: 是数据内容的表现,一条数据显示成什么样子. (1)DataTemla ...

  4. 用iptables封杀内网的bt软件

    我所在的网络情况是这样的!1台FC3和3台win2000组成一个局域网!四台机都接在100m的交换机上.在FC3上有两个网卡eth0接外网 adsl eth1接在交换机.FC3做nat带3台win20 ...

  5. 『现学现忘』Docker基础 — 29、Docker容器数据卷的应用

    目录 1.验证容器和宿主机之间数据共享 2.容器停止退出后,主机修改后数据是否同步 3.带只读权限的挂载数据卷 1.验证容器和宿主机之间数据共享 通过上面的操作,接下来我们演示一下通过数据卷的挂载,实 ...

  6. Mycat+MySql 主从复制-读写分离 看这一篇就够了

    ​ 通过mycat和mysql的主从复制配合搭建数据库的读写分离,可以实现mysql的高可用性,下面我们来搭建mysql的读写分离. 1.一主一从 1.在node01上修改/etc/my.cnf的文件 ...

  7. 半吊子菜鸟学Web开发 -- PHP学习 4 --异常

    PHP异常处理 1 抛出一个异常 与Python的try except类似,PHP用try catch来捕获异常 基本语法 try{ //可能出现错误或异常的代码 //catch表示捕获,Except ...

  8. Java常见的垃圾收集器有哪些?

    守拙者_6a98关注 2020.04.11 22:06:31字数 2,135阅读 394 实际上,垃圾收集器( GC , Garbage Collector )是和具体 JVM 实现紧密相关的,不同厂 ...

  9. pg数据库org.postgresql.util.PSQLException: ERROR: "xxx" is not a sequence

    问题场景 对pg数据表执行插入语句的时候,报错如下: { "timestamp": 1587012576734, "status": 500, "er ...

  10. MyISAM 表格将在哪里存储,并且还提供其存储格式?

    每个 MyISAM 表格以三种格式存储在磁盘上: ·".frm"文件存储表定义 ·数据文件具有".MYD"(MYData)扩展名 索引文件具有".MY ...