jjzjj

c# - 如何处理调用了异步方法的对象?

我有这个实现了IDisposable的对象PreloadClient,我想处理它,但是在异步方法完成它们的调用之后...这并没有发生privatevoidPreload(SlideHandlerslide){using(PreloadClientclient=newPreloadClient()){client.PreloadCompleted+=client_PreloadCompleted;client.Preload(slide);}//Hereclientisdisposedimmediately}privatevoidclient_PreloadCompleted(objec

c# - 在 C# 中安全地处理 Excel 互操作对象?

我正在开发一个winformsc#visualstudio2008应用程序。该应用程序与excel文件对话,我正在使用Microsoft.Office.Interop.Excel;来执行此操作。我想知道如何确保即使出现错误也能释放对象?这是我的代码:privatevoidbutton1_Click(objectsender,EventArgse){stringmyBigFile="";OpenFileDialogopenFileDialog1=newOpenFileDialog();DialogResultresult=openFileDialog1.ShowDialog();//Sh

c# - 一次性使用模式

using(FileStreamfileStream=newFileStream(path)){//dosomething}现在我知道using模式是IDisposable的实现,即设置了Try/Catch/Finally并在对象上调用了Dispose。我的问题是如何处理Close方法。MSDN说它没有被调用,但我已经阅读了其他内容。我知道FileStream继承自Stream,这在here中有解释.现在说不要覆盖Close(),因为它是由Dispose()调用的。那么有些类是只在Dispose()方法中调用Close()还是在using中调用Close()?

c# - 使用语句和关闭方法

与数据库连接对象一起使用时,using语句是否真的调用了close方法?TheMSDNdocumentation说它确保调用Dispose方法但没有提到关闭。我在StackOverflow上看到有人说它可以同时做到这两点。是否有人从Microsoft或其他确凿的证据中以某种方式给出了具体的答案? 最佳答案 这是SqlConnection类的“Dispose”方法:protectedoverridevoidDispose(booldisposing){if(disposing){this._userConnectionOptions=

c# - 为什么处置后的对象在使用它时不会抛出异常?

在处置对象上调用方法是否合法?如果是,为什么?在下面的演示程序中,我有一个一次性类A(它实现了IDisposable接口(interface))。据我所知,如果我将一次性对象传递给using()构造,然后在右括号处自动调用Dispose()方法:Aa=newA();using(a){//...}//如果正确,请解释这个程序的输出:publicclassA:IDisposable{inti=100;publicvoidDispose(){Console.WriteLine("Dispose()called");}publicvoidf(){Console.WriteLine("{0}",

c# - 调用 Dispose() 与对象超出范围/方法完成时的对比

我有一个方法,里面有一个try/catch/finalyblock。在tryblock中,我声明SqlDataReader如下:SqlDataReaderaReader=null;aReader=aCommand.ExecuteReader();在finallyblock中,手动处理的对象是那些在类级别设置的对象。那么实现IDisposable的方法中的对象,比如上面的SqlDataReader,它们会被自动释放吗?Close()在while循环执行后调用aReader以获取阅读器的内容(应该是Dispose(),因为调用关闭())。如果没有调用Close(),该对象是否会在方法完成或

c# - IDisposable 实现 - 'if (disposing)' 中应该包含什么

我一直在修复winforms应用程序中的一些内存泄漏问题,并注意到一些未明确处理的一次性对象(开发人员尚未调用Dispose方法)。Finalize方法的实现也无济于事,因为它没有进入if(disposing)子句。所有的静态事件注销和集合清除都放在了if(disposing)子句中。如果对象是一次性的,最好的做法是调用Dispose,但不幸的是,这种情况有时会发生如果有非托管对象、静态事件处理程序和一些托管集合需要在处置时清除。if(disposing)子句如何决定什么进什么出。Disposemethod.//Dispose(booldisposing)executesintwodi

c# - CA2213 代码分析规则和自动实现的属性

我在我们的项目中使用静态代码分析来检查代码违规情况。广泛使用的规则之一是CA2213,它检查一次性字段的正确处理。我注意到CA2213不检查自动实现属性的处理。此外,如果类继承自实现IDisposable的类且未重写Dispose方法,则CA2213既不检查字段也不检查自动实现的属性的处置。实例:publicsealedclassGood:IDisposable{privateFontfont;publicFontFont{get{returnfont;}set{font=value;}}publicGood(){font=newFont("Arial",9);}publicvoidD

c# - LINQ IEnumerable 扩展是否在其 IEnumerable 上调用 Dispose?

假设我已经编写了一个实现IEnumerable的类,并返回一个IEnumerator,它不仅仅是IDisposable的枚举器,但是在完成枚举后,由于拥有它需要Dispose()的托管资源,我是否可以相信只要我的枚举器正确,以下将Dispose()这些托管资源在其IDisposable实现中处理这些托管资源?return(newMyClass()).Select(x=>x);编辑:这个问题看起来与标记为类似它的一个模组相似,但它在语义上是不同的IMO(我在提出问题之前看到了它) 最佳答案 是的,您可以从LINQ方法内部对迭代器调用D

c# - 什么可能导致 WCF 中出现 "Cannot access a disposed object"错误?

我正在使用以下代码:privateWSHttpBindingws;privateEndpointAddressSrv_Login_EndPoint;privateChannelFactorySrv_LoginChannelFactory;privateSrv_Login.Srv_ILoginLoginService;Login是我的构造函数:publicLogin(){InitializeComponent();ws=newWSHttpBinding();Srv_Login_EndPoint=newEndpointAddress("http://localhost:2687/Srv_L