有时候,生活中的很多东西其实只需要一个就够了,就像一个公司只需要一个CEO,一个王朝只需要一个皇帝。在UVM验证环境中,也有很多这样的需求------有些对象,我们希望它在整个仿真过程中只存在一个实例。这就是我们今天要聊的单例模式(Singleton patterns)。
在UVM的世界里,单例模式随处可见。最典型的几个例子:
uvm_factory - 整个UVM环境只需要一个工厂实例,负责创建所有的对象。如果有多个工厂,就不知道该听谁的了。
uvm_report_server - 报告服务器收集整个验证环境的消息,必须是唯一的。多个报告服务器会让日志变得混乱不堪。
uvm_config_db - 配置数据库存储全局配置信息,必须保证全局唯一性。想象一下如果有多个配置数据库,同样的配置项可能有不同的值,那就乱套了。
uvm_coreservice_t - 核心服务提供者,管理着整个UVM基础设施的核心服务,自然只能有一个。