如何保证对象的唯一性

简介:

/*
如何保证对象的唯一性:
   1.不允许其他程序用new来创建该类对象。
   2.在该类创建一个本类实例。
   3.对外提供一个方法让其他程序可以获取该对象的引用。
*/
public class Test{
    public static void main(String[] args){
        
       //Subject sub = Subject.oSub;//这种方法不可控,一般不访问成员
       Subject sub = Subject.getInstance();//我们可以在方法中增加条件,根据条件是否返回对象的引用,增加程序的可控性!
       new Student().show(sub);
       new Teacher().show(sub);
   }
}
 
class Subject{
    public  String sub;
    public static Subject oSub = new Subject();
    private Subject(){
        sub = "计算机科学与技术";
    }
     
    public static Subject getInstance(){
        //oSub = new Subject();
        //if(****) 增加 if 判断 可以 增加程序的可控性
        return oSub;
    }
     
    public String getSubject(){
        return sub;
    }
     
    public void setSubjcet(String name){
        sub = name;
    }
}
 
/*
 静态成员变量和普通成员变量的显示初始化的不同之处:
 以下面的例子为例:
 静态变量的显示初始化编译之后不会放进 构造函数中!(想一想啊,如果放进了构造函数中,那不就是产生对象了吗?那可能吗?
      它是静态的,是属于类的!普通成员变量是属于对象的,所以显示初始化会放进构造函数中)所以不会使构造函数一直调用,最终栈溢出
 而普通成员变量的显示初始化编译之后回放进构造函数中, 这样就会导致构造函数一直被反复调用!
 class Subject{
    public  String sub;
    //public Subject ss = new Subject();
    public static Subject oSub = new Subject();//恶汉式
        //public static Subject oSub = null;//懒汉式
    private Subject(){
            //oSub = new Subject();//oSub是静态变量,加上这一句就会导致oSub显示初始化时栈溢出!
        sub = "计算机科学与技术";
    }
     
    public static Subject getSubject(){       
        return oSub;
                //return oSub = new Subject();
    }
}
*/
 
class Student{
    public void show(Subject sub){
        System.out.println(sub.sub);
    }
}
 
class Teacher{
    public void show(Subject sub){
        System.out.println(sub.sub);
    }
}

目录
相关文章
|
23天前
|
数据采集 数据处理 数据库
在处理重复值时,如何保证数据的准确性?
在使用Pandas处理数据重复值时,要保证数据的准确性,需要综合考虑多方面因素,并采取相应的方法和策略,
39 8
|
21天前
|
存储 算法 Java
如何保证 hashCode()方法的唯一性
在Java中,`hashCode()` 方法用于生成对象的哈希码,是实现数据结构如哈希表的基础。虽然完全保证 `hashCode()` 的唯一性几乎不可能,但通过合理设计,如结合对象的关键属性,可以极大减少哈希冲突,提高程序效率和稳定性。
52 8
|
2月前
|
存储 监控 关系型数据库
如何避免使用冗余索引
【10月更文挑战第15天】如何避免使用冗余索引
36 1
|
4月前
|
SQL 数据管理 数据库
|
7月前
|
关系型数据库 数据库 数据库管理
关系型数据库数据唯一性保证
【5月更文挑战第17天】
119 1
|
存储 缓存 NoSQL
分布式ID(唯一性)的生成方法汇总
分布式ID(唯一性)的生成方法汇总
分布式ID(唯一性)的生成方法汇总
|
缓存 安全 Java
遵循Happens-Before规则来保证可见性|而非掌握所有底层
基于JSR -133内存模型提出了happens-before的概念,通过这个概念来阐述操作之间的内存可见性。要保证可见性,就是遵守 Happens-Before 规则,合理的使用java提供的工具。
163 0
分布式事物如何保证接口请求顺序性?
前言 先抛出一个问题大家思考一下:在分布式系统中,我们如何保证多个请求的顺序性问题,比如有A/B两个系统,系统A在一次订单业务处理中,向B系统发送三次请求,先进行插入订单操作,然后对订单状态进行修改,最后增加用户积分。 但是这三次请求分别落在了不同的机器上,并且插入订单的操作由于一些意外导致延迟,修改订单操作先执行了,但是此时并没有订单信息,也就会出现我们期望之外的结果了。
|
存储 算法 数据库
如何保证 ID 的全局唯一性?
如何保证 ID 的全局唯一性?
488 0
如何保证 ID 的全局唯一性?
|
存储 算法 NoSQL
分布式环境下如何保证 ID 的唯一性
首先说下我们为什么需要分布式 ID,以及分布式 ID 是用来解决什么问题的。当我们的项目还处于单体架构的时候,我们使用数据库的自增 ID 就可以解决很多数据标识问题。但是随着我们的业务发展我们的架构就会逐渐演变成分布式架构,那么这个时候再使用数据的自增 ID 就不行了,因为一个业务的数据可能会放在好几个数据库里面,此时我们就需要一个分布式 ID 用来标识一条数据,因此我们需要一个分布式 ID 的生成服务。那么分布式 ID 的服务有什么要求和挑战呢?
分布式环境下如何保证 ID 的唯一性