如何保证对象的唯一性

简介:

/*
如何保证对象的唯一性:
   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);
    }
}

目录
相关文章
|
SQL 缓存 NoSQL
接口的幂等性设计和防重保证,详细分析幂等性的几种实现方法
本篇文章详细说明了幂等性,解释了什么是幂等性,幂等性的使用场景,讨论了幂等和防重的概念。分析了幂等性的情况以及如何设计幂等性服务。阐述了幂等性实现防重的几种策略,包括乐关锁,防重表,分布式锁,token令牌以及支付缓冲区。
4926 0
接口的幂等性设计和防重保证,详细分析幂等性的几种实现方法
|
存储 缓存 NoSQL
分布式ID(唯一性)的生成方法汇总
分布式ID(唯一性)的生成方法汇总
分布式ID(唯一性)的生成方法汇总
|
缓存 安全 Java
遵循Happens-Before规则来保证可见性|而非掌握所有底层
基于JSR -133内存模型提出了happens-before的概念,通过这个概念来阐述操作之间的内存可见性。要保证可见性,就是遵守 Happens-Before 规则,合理的使用java提供的工具。
114 0
|
前端开发 NoSQL Java
如何保证接口幂等性?一口气说了12种方法!
幂等性原本是数学上的概念,用在接口上就可以理解为:**同一个接口,多次发出同一个请求,必须保证操作只执行一次**。调用接口发生异常并且重复尝试时,总是会造成系统所无法承受的损失,所以必须阻止这种现象的发生。
469 0
分布式事物如何保证接口请求顺序性?
前言 先抛出一个问题大家思考一下:在分布式系统中,我们如何保证多个请求的顺序性问题,比如有A/B两个系统,系统A在一次订单业务处理中,向B系统发送三次请求,先进行插入订单操作,然后对订单状态进行修改,最后增加用户积分。 但是这三次请求分别落在了不同的机器上,并且插入订单的操作由于一些意外导致延迟,修改订单操作先执行了,但是此时并没有订单信息,也就会出现我们期望之外的结果了。
|
存储 算法 数据库
如何保证 ID 的全局唯一性?
如何保证 ID 的全局唯一性?
412 0
如何保证 ID 的全局唯一性?
|
安全 Java 数据安全/隐私保护
这8种保证线程安全的技术你都知道吗?(下)
这8种保证线程安全的技术你都知道吗?(下)
|
存储 算法 NoSQL
分布式环境下如何保证 ID 的唯一性
首先说下我们为什么需要分布式 ID,以及分布式 ID 是用来解决什么问题的。当我们的项目还处于单体架构的时候,我们使用数据库的自增 ID 就可以解决很多数据标识问题。但是随着我们的业务发展我们的架构就会逐渐演变成分布式架构,那么这个时候再使用数据的自增 ID 就不行了,因为一个业务的数据可能会放在好几个数据库里面,此时我们就需要一个分布式 ID 用来标识一条数据,因此我们需要一个分布式 ID 的生成服务。那么分布式 ID 的服务有什么要求和挑战呢?
分布式环境下如何保证 ID 的唯一性
Joshua Bloch使用的“失败原子性”是什么?它对不可变对象有何好处?
Joshua Bloch使用的“失败原子性”是什么?它对不可变对象有何好处?
89 0