我想知道这种设计是对是错还是两者兼而有之。
我有一个包含多个组件(对象)的应用程序,每个组件都有一个配置(标志、功能等)。在任何时候,我都想从对象中检索配置。
为此,我这样做了:
class ConfigRetriever {
public String getConfigString() {
String configString = "";
configString += "component 1 flag : "+component1.getFlag()+"\n";
configString += "component 2 flag : "+component2.getFlag()+"\n";
// ...
return( configString );
}
}
在其他地方,当需要配置时:
class SomeClass {
public void someMethod() {
ConfigRetriever configRetriever = new ConfigRetriever();
String configString = configRetriever.getConfigString();
// Do some stuff with configString...
}
}
我是对象编程的新手,为一个特定的操作创建一个对象(ConfigRetriever)仍然感觉很奇怪(即使该对象能够做其他事情)。
我也考虑过单例模式,有这样的事情:
String configString = ConfigRetriever.getInstance().getConfigString();
这是一条简洁的线,但是由于对象一直保留在内存中直到应用程序结束,我真的不知道什么是对的,什么是错的。
我的设计可以更好吗?如何 ?为什么 ?
更新
感谢您的回答。我认为我的问题有点混乱,我错过了我所要求的重点。
整个配置和组件的故事在这里作为我正在处理的那种情况的一个例子。这是快速而肮脏的代码,我应该警告你。真正的问题是:“只创建一次(或有时)创建一个对象以访问其方法之一是否很好?” 好吧,阅读您的答案并再次考虑它,似乎正确的答案是“这取决于您的目标、课程、职责等......”
我想将信息存储在我的对象中吗?不能是静态方法。
使用永久记忆的单身人士是否有问题?大多数时候是这样,因为我认为您必须有充分的理由在内存中维护具有全局状态的对象。所以,大多数时候:没有单例。
最后,创建一个用于实例化对象的类是否有问题?不是,加油!:-)