草庐IT

try-catch-rethrow

全部标签

c# - Try/Catch 和线程

我知道为什么,但我想问一下是否有人很好地理解为什么线程内引发的异常从未被启动它的代码捕获。下面是一些非常简单的代码来演示我的意思:usingSystem;usingSystem.Collections.Generic;usingSystem.Threading;namespaceTestCrash{classProgram{privatestaticvoidCrash(objectcontrol){AutoResetEventare=(AutoResetEvent)(((object[])control)[0]);are.Set();thrownewException("Burnbab

c# - 退出 Try/Catch 以防止运行后的代码

例如,我的方法中有一个try/catch:}catch(OurCustomExceptionObject1ex){txtErrorMessage.InnerHtml="test1";}catch(OurCustomExceptionObject2ex){txtErrorMessage.InnerHtml="test2";}catch(OurCustomExceptionObject3ex){txtErrorMessage.InnerHtml="test3";}...restofcodehereisbeingexecutedafterthetry/catch如果捕获到任何异常,我不希望运

c# - 在 C# 下,try、throw 和 catch block 对性能的影响有多大

首先声明:我有使用其他语言的经验,但仍在学习C#的精妙之处关于问题...我正在查看一些代码,它以我关心的方式使用try/catchblock。当调用解析例程时,程序员没有返回错误代码,而是使用了以下逻辑catch(TclExceptione){thrownewTclRuntimeError("unexpectedTclException:"+e.Message,e);}这被调用者捕获,抛出相同的错误......被调用者捕获,抛出相同的错误........被调用者捕获,抛出相同的错误......备份大约6个级别。我是否认为所有这些catch/throwblock都导致了性能问题,或者这是

c# - 如果从 C# 中的 try 或 catch block 返回,finally block 是否会被执行?如果是这样,是在返回之前还是之后?

没有可用的内容! 最佳答案 是的,执行了finallyblock,但是流程离开了tryblock-无论是到达结尾、返回还是抛出异常。来自C#4规范,第8.10节:Thestatementsofafinallyblockarealwaysexecutedwhencontrolleavesatrystatement.Thisistruewhetherthecontroltransferoccursasaresultofnormalexecution,asaresultofexecutingabreak,continue,goto,orr

c# - 使用 IronPython 时禁用第一次机会异常但调试器在 try...catch 中停止

应在不停止调试器的情况下执行以下代码:varengine=Python.CreateEngine(AppDomain.CurrentDomain);varsource=engine.CreateScriptSourceFromString("Foo.Do()");varcompiledCode=source.Compile(newPythonCompilerOptions{Optimized=true});try{compiledCode.Execute(engine.CreateScope(newDictionary{{"Foo",newFoo()}}));MessageBox.Sh

c# - 为什么编译器不允许在 catch block 中使用 await

假设我有一个异步方法:publicasyncTaskDo(){awaitTask.Delay(1000);}另一种方法是尝试在catchblock中调用Do方法publicasyncTaskDoMore(){try{}catch(Exception){awaitDo();//compilederror.}}但是这样一来,编译器就不允许在catch中使用await了,有没有什么原因导致我们不能那样使用它? 最佳答案 更新这将在C#6中得到支持。事实证明,这并非根本不可能,并且该团队想出了如何做到这一点而又不会在实现过程中陷入困境:)原

c# - 构造函数中的 Try/catch block

在构造函数中使用try/catchblock是否是一种糟糕的编程习惯?或者只要我们的程序优雅地处理typeinitializer异常就没有什么区别。在C#中,如果构造函数中有任何异常,框架总是抛出类型初始化异常。谢谢,沙米卡 最佳答案 System.TypeInitializationException在static构造函数抛出异常时抛出,而不是在实例构造函数上。异常通常在实例构造函数中抛出。除此之外,与其他任何地方一样,它也没有什么“错误”;处理您可以从中正确恢复的异常,并允许那些您无法恢复的异常。

c# - 重新抛出无参数 catch 和什么都不做的区别?

假设我在两个不同的程序集中有以下两个类://inassemblyApublicclassTypeA{//ConstructoromittedpublicvoidMethodA{try{//dosomething}catch{throw;}}}//inassemblyBpublicclassTypeB{publicvoidMethodB{try{TypeAa=newTypeA();a.MethodA();}catch(Exceptione)//Handleexception}}}在这种情况下,MethodA中的try-catch只是提升了异常,但并没有真正处理它。在MethodA中使用t

c# - 如果我从 C# 中的 try/finally block 中返回,finally 中的代码是否总是运行?

根据一些初步测试,它似乎确实如此,但我想知道的是它是否保证返回,或者在某些情况下是否不能返回?这对我的应用程序至关重要,但我还没有找到它不会返回的用例。我想获得有关该主题的专业知识。 最佳答案 其他答案中有许多不准确之处。当控制权正常离开tryblock时,控制权被传递到finallyblock——也就是说,通过return、goto、break、continue或简单地从末尾掉下来。当控制权离开tryblock时,控制权将通过已被封闭的catchblock捕获的异常传递给finallyblock。在任何其他情况下,都不能保证fin

c# - `Fault` try block 中的关键字

在探索反射器中的程序集时,我偶然发现了编译器生成的类中的fault关键字。你们知道这个关键字的意思吗?C#privateboolMoveNext(){boolflag;try{//[...]}fault{this.Dispose();}returnflag;}vb.netPrivateFunctionMoveNext()AsBooleanDimflagAsBooleanTry'[...]FaultMe.DisposeEndTryReturnflagEndFunction 最佳答案 Doanyofyouknowthemeaningif