systemverilog单例模式

单例模式

单例模式(Singleton Pattern)是 Java 中最简单的设计模式之一。这种类型的设计模式属于创建型模式,它提供了一种创建对象的最佳方式。

这种模式涉及到一个单一的类,该类负责创建自己的对象,同时确保只有单个对象被创建。这个类提供了一种访问其唯一的对象的方式,可以直接访问,不需要实例化该类的对象。

注意:

  • 1、单例类只能有一个实例。
  • 2、单例类必须自己创建自己的唯一实例。
  • 3、单例类必须给所有其他对象提供这一实例。       

下面是一个SV的例子:

class MyObject;

   string myState;

   static MyObject myObj;

   //构造函数前加local修饰,所以不可以外部使用构造函数,保证了全局唯一
   local function new();
   endfunction

   //静态方法,可以通过MyObject::getObject调用
   static function MyObject getObject();
      if(myObj == null)
         myObj = new();
      return myObj;
   endfunction

endclass //MyObject

// Top Module      
module singleton_pattern;

   MyObject anObject;
   MyObject firstObj, secondObj;

   initial
   begin

      // 如果像下面这样写,编译会报错
      //anObject = new();
 
      firstObj  = MyObject::getObject();//调用静态方法
      firstObj.myState = "This is Me!";
      $display("Object Status | First  Object State: %s", firstObj.myState);

      secondObj = MyObject::getObject();
      $display("Object Status | Second Object State: %s", secondObj.myState);
   end

endmodule //singleton_pattern

程序运行结束后打印消息:

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值