关于java拷贝的笔记

Java对象拷贝机制详解

1、直接引用

直接引用对基本数据类型与引用数据类型都不会复制一份新的,使用的都是原来的值

package clone;

public class Reference {
	public static void main(String[] args){
		People3 people=new People3();
		people.num=1315;
		Student3 stu1=new Student3();		
		stu1.age=1;
		stu1.people3=people;
		
		System.out.println("-----------原对象----------------------");
		System.out.println("stu1:"+stu1);
		System.out.println("stu1->age:"+stu1.age);
		System.out.println("stu1->num:"+stu1.people3);
		System.out.println("stu1->pepole3->num:"+stu1.people3.num);
		
		Student3 stu2=(Student3) stu1;
		
		System.out.println("-----------引用出来的对象----------------- ");
		System.out.println("stu2:"+stu2);
		System.out.println("stu2->age:"+stu2.age);
		System.out.println("stu2->num:"+stu2.people3);
		System.out.println("stu2->pepole3->num:"+stu2.people3.num);
		
		stu1.age=3;
		stu1.people3.num=1327;
		System.out.println("-----------修改原对象对引用对象的影响-----------");
		System.out.println("stu2:"+stu2);
		System.out.println("stu2->age:"+stu2.age);
		System.out.println("stu2->num:"+stu2.people3);
		System.out.println("stu2->num:"+stu2.people3.num);	
		}
}
class Student3 implements Cloneable{
	public int age;
	public People3 people3;
}
class People3{
	public int num;
}

输出的结果是这样的:

当改变原对象的基本数据类型与引用数据类型,新对象的基本数据类型与引用数据类型的值都会变,而且可以看到对象的hashcode值都是一样的

2、浅拷贝

浅拷贝会对基本数据类型复制一份新的,对引用数据类型会使用原来的对象的

package clone;

public class ShallowCopy {
	public static void main(String[] args){
		People people=new People();
		people.num=1234;
		Student stu1=new Student();
		stu1.age=1;
		stu1.people=people;
		
		System.out.println("-----------原对象----------------------");
		System.out.println("stu1:"+stu1);
		System.out.println("stu1->age:"+stu1.age);
		System.out.println("stu1->num:"+stu1.people);
		System.out.println("stu1->pepole->num:"+stu1.people.num);
		
		try {
			System.out.println("-----------浅拷贝出的对象--------------");
			Student stu2=(Student) stu1.clone();
			System.out.println("stu2:"+stu2);
			System.out.println("stu2->age:"+stu2.age);
			System.out.println("stu2->num:"+stu2.people);
			System.out.println("stu2->pepole->num:"+stu2.people.num);

			stu1.age=3;
			people.num=2345;
			System.out.println("--------修改原对象对浅拷贝出的对象的影响-----------");
			System.out.println("stu2:"+stu2);
			System.out.println("stu2->age:"+stu2.age);
			System.out.println("stu2->num:"+stu2.people);
			System.out.println("stu2->pepole->num:"+stu2.people.num);
		} catch (CloneNotSupportedException e) {
			e.printStackTrace();
		}
	}
}
class Student implements Cloneable{
	public int age;
	public People people;
		
    @Override
    public Object clone() throws CloneNotSupportedException {
        return super.clone();
    }
}
class People{
	public int num;
}

输出的结果是这样的:

当改变原对象的基本数据类型与引用数据类型,新对象的基本数据类型不变,引用数据类型的值会变,而且可以看到对象的hashcode值是一样的

3、深拷贝

package clone;

public class DeepCopy {
	public static void main(String[] args){
	People2 people2=new People2();
	people2.num=3456;
	Student2 stu1=new Student2();
	stu1.age=1;
	stu1.people2=people2;
	
	System.out.println("-----------原对象----------------------");
	System.out.println("stu1:"+stu1);
	System.out.println("stu1->age:"+stu1.age);
	System.out.println("stu1->num:"+stu1.people2);
	System.out.println("stu1->pepole->num:"+stu1.people2.num);
	try {
		Student2 stu2=(Student2) stu1.clone();
		System.out.println("-----------深拷贝出的对象--------------");
		System.out.println("stu2:"+stu2);
		System.out.println("stu2->age:"+stu2.age);
		System.out.println("stu2->num:"+stu2.people2);
		System.out.println("stu2->pepole->num:"+stu2.people2.num);
		
		stu1.age=3;
		stu1.people2.num=6789;
		
		System.out.println("--------修改原对象对深拷贝出的对象的影响-----------");
		System.out.println("stu2:"+stu2);
		System.out.println("stu2->age:"+stu2.age);
		System.out.println("stu2->num:"+stu2.people2);
		System.out.println("stu2->pepole->num:"+stu2.people2.num);
	} catch (CloneNotSupportedException e) {
		e.printStackTrace();
	}
	}
}
class Student2 implements Cloneable{
	public int age;
	public People2 people2;
		
    @Override
    public Object clone() throws CloneNotSupportedException {
    	Student2 st2=null;
    	try {
    		st2 = (Student2) super.clone();
            if (people2 != null) {
                st2.people2=(People2)people2.clone();
            }
        } catch (CloneNotSupportedException ignored) {
            
        }
        return st2;
    }
}
class People2 implements Cloneable{
	public int num;
	@Override
    public Object clone() throws CloneNotSupportedException {
        return super.clone();
    }
}

输出结果是这样的:

当改变原对象的基本数据类型与引用数据类型,新对象的基本数据类型和引用数据类型的值都不会变,而且可以看到引用对象的hashcode值是不一样的

总结一下,图大概是这样子的:

还有一个问题,包装类型的处理是遵循基本数据类型的。

 

 

 

基于51单片机,实现对直流电机的调速、测速以及正反转控制。项目包含完整的仿真文件、源程序、原理图和PCB设计文件,适合学习和实践51单片机在电机控制方面的应用。 功能特点 调速控制:通过按键调整PWM占空比,实现电机的速度调节。 测速功能:采用霍尔传感器非接触式测速,实时显示电机转速。 正反转控制:通过按键切换电机的正转和反转状态。 LCD显示:使用LCD1602液晶显示屏,显示当前的转速和PWM占空比。 硬件组成 主控制器:STC89C51/52单片机(与AT89S51/52、AT89C51/52通用)。 测速传感器:霍尔传感器,用于非接触式测速。 显示模块:LCD1602液晶显示屏,显示转速和占空比。 电机驱动:采用双H桥电路,控制电机的正反转和调速。 软件设计 编程语言:C语言。 开发环境:Keil uVision。 仿真工具:Proteus。 使用说明 液晶屏显示: 第一行显示电机转速(单位:转/分)。 第二行显示PWM占空比(0~100%)。 按键功能: 1键:加速键,短按占空比加1,长按连续加。 2键:减速键,短按占空比减1,长按连续减。 3键:反转切换键,按下后电机反转。 4键:正转切换键,按下后电机正转。 5键:开始暂停键,按一下开始,再按一下暂停。 注意事项 磁铁和霍尔元件的距离应保持在2mm左右,过近可能会在电机转动时碰到霍尔元件,过远则可能导致霍尔元件无法检测到磁铁。 资源文件 仿真文件:Proteus仿真文件,用于模拟电机控制系统的运行。 源程序:Keil uVision项目文件,包含完整的C语言源代码。 原理图:电路设计原理图,详细展示了各模块的连接方式。 PCB设计:PCB布局文件,可用于实际电路板的制作。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值