@d-stanley 想说的是,您在创建时分配内存,这是非常宝贵的资源。
更完整的答案是:创建类时考虑到一些逻辑。尽管Response.Write(new ABC().Method1()); 完全可行,但这是一个非常短的功能,而且没有那么多用处……当您设计class 时,您实现了一些逻辑边界功能和属性。例如FileStream 有一个内部属性Stream 并且可以通过各种属性访问它,你可以在重载的Open() 方法中设置它并在Dispose() 方法中销毁它。例如,另一个类BinaryReader 也实现了Stream,但威胁它的方式不同。根据您的逻辑,您可以在单个类上实现所有功能-某些MotherOfAllFunctions 类实现了FileStream 和BinaryReader 的所有功能-但这不是一种方法。
另一点:在大多数情况下,会占用一些(或大量)内存来初始化类的一些内部逻辑 - 例如SqlConnection 类。然后您调用Open() 或任何其他方法来调用数据库 - 引入了一些非常强大的机制来支持状态机初始化、托管到取消管理的调用,并且可以执行大量代码。
实际上,您在任何new SomeCLass().SomeMethod<int>(ref AnotherObject) 中所做的是:
Response.Write(
var tmpABC = new ABC(); // Constructor call . Executed always (may throw)
string result = tmpABC.Method1(); // Or whatever could be casted to `string`
tmpABC.Dispose(); // GC will kick-in and try to free memory
return result;
);
如您所见 - 这与您以这种方式编写的代码相同。所以这里发生的是大量的内存分配,几乎所有这些宝贵的内存都被扔掉了。初始化ABC() 类和它的所有功能一次然后在任何地方使用它更有意义,这样可以最大限度地减少内存over分配。例如 - 在 DAL 类中的每个函数调用中打开 SqlConnection 函数然后立即关闭它是没有任何意义的 - 更好地声明局部变量并使其保持活动状态 - 一些完全初始化的类只要应用程序线程进程就存在存在。所以在这种代码风格的情况下:
public class Program
{
private static FileStream streamToLogFile = new FileStream(...);
public int Main(string [] args)
{
new Run(new Form1(streamToLogFile));
}
}
在这个逻辑中 - 不需要保留类 Form1,我在内联创建了它,但所有需要访问 FileStream 对象(有价值的资源!)的函数都将访问同一个实例只初始化一次。