我为我的类创建了一个包含 MemcachedClient 实例的 Singleton(这可以是任何需要连接到服务器的对象,但我提供了一个具体示例)。我在静态初始化块中初始化 MemcachedClient。如果 MemcachedClient 由于连接错误而无法创建实例,这意味着我的类现在毫无价值,因为它有一个空的 MemcachedClient 实例。
我的问题:这种情况的最佳解决方案是什么?其他人如何处理这种情况?
我为我的类创建了一个包含 MemcachedClient 实例的 Singleton(这可以是任何需要连接到服务器的对象,但我提供了一个具体示例)。我在静态初始化块中初始化 MemcachedClient。如果 MemcachedClient 由于连接错误而无法创建实例,这意味着我的类现在毫无价值,因为它有一个空的 MemcachedClient 实例。
我的问题:这种情况的最佳解决方案是什么?其他人如何处理这种情况?
这个问题(如标题中所述)太宽泛了,这取决于单例的用途。
就您而言,一个明显的问题是:如果初始化失败,您能否期望该问题会在不久的将来得到解决?继续尝试(重新设计以使您的应用程序不会以奇怪的方式向下崩溃)而不是仅仅重新启动您的应用程序的成本是多少?
如果您不希望错误能够轻松解决,只需使您的应用程序崩溃(使用正确的日志/警报/通知)。如果您希望它继续运行直到问题解决,那么步骤将是:
1)将初始化传递给单例的构造函数(如果可以控制对构造函数的访问,为什么要把它放在静态块中)。
2a) 当构造函数失败时,调用getInstance
将返回 null。修改您的应用程序以使其能够处理。
2b) 如果存在问题,请在没有正确初始化的情况下创建单例。在解决初始化问题/对象已初始化之前,对该对象的方法的调用不会执行任何操作。修改您的应用程序以能够处理这些虚拟方法。这种方法更快但更复杂。
3)当请求一个新的实例(如果是2a)或者一个方法被调用(如果是2b)时,再次检查对象是否可以被初始化。
将之前所有的成本与问题解决后重新启动应用程序的成本进行比较。