草庐IT

img_final

全部标签

C# - Try-Catch-Finally 返回

这个问题在这里已经有了答案:WillcodeinaFinallystatementfireifIreturnavalueinaTryblock?(12个答案)关闭7年前。我有以下代码:publicDataTableGetAllActiveUsers(){DataTabledataTable=newDataTable();try{connection.Open();SqlCommandgetAllActiveUsersCommand=newSqlCommand(getAllUsers,connection);SqlDataAdapterdataAdapter=newSqlDataAdap

c# - 在 C# 中将参数作为 final 传递

这可能是一个重复的问题。但无法在搜索中找到它在java中,为了将方法参数标记为常量,我们将其声明为final等效的C#关键字是什么?喜欢publicvoiddoSomeThing(finalobjectmyObject){//printmyobject} 最佳答案 这在C#中是不可能的-无法将传入的参数标记为常量。如果您有一个const需要对许多函数可用,为什么不使用正确的作用域(类作用域或全局作用域,如果需要)声明它? 关于c#-在C#中将参数作为final传递,我们在StackOve

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

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

c# - 在 finally block 中访问函数返回的值

我想知道是否可以在finallyblock中获取函数的返回值。我有一些这样的代码。try{return1;}finally{//Getthevalue1}我知道可以通过添加一个可以保存返回值的变量来实现。但我想知道是否有可能以任何方式获得值(value)。谢谢 最佳答案 不,你不能那样做。 关于c#-在finallyblock中访问函数返回的值,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.com/ques

c# - TaskCompletionSource 抛出 "An attempt was made to transition a task to a final state when it had already completed"

我想使用TaskCompletionSource来包装MyService这是一个简单的服务:publicstaticTaskProcessAsync(MyServiceservice,intparameter){vartcs=newTaskCompletionSource();//EverytimeProccessAsynciscalledthisassignstoCompleted!service.Completed+=(sender,e)=>{tcs.SetResult(e.Result);};service.RunAsync(parameter);returntcs.Task;}

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

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

c# - finally block when 后编译器生成无限循环

我使用的是针对.Net4.6.2的标准VS2015编译器。编译器在finallyblock失败后发出无限循环。一些例子:调试:IL_0000:nop.try{IL_0001:nopIL_0002:nopIL_0003:leave.sIL_000c}//end.tryfinally{IL_0005:nopIL_0006:br.sIL_000a//loopstart(head:IL_000a)IL_0008:nopIL_0009:nopIL_000a:br.sIL_0008//endloop}//endhandler//loopstart(head:IL_000c)IL_000c:br.s

c# - 使用语句和 try-catch()-finally 重复?

using(...)语句是try{}finally{}的语法糖。但是如果我有如下的using语句:using(FileStreamfs=File.Open(path)){}现在我想捕获打开这个文件可能导致的异常(这是相当高风险的代码,因为它可能会因环境而失败),但是如果我在里面写try-catch会不会重复?当代码被编译为IL时,我认为当代码被JITted时重复将被删除?但是,我想捕获打开文件可能导致的异常(所以我应该将try-catch包装在using语句的范围之外),以及我在usingblock中所做的任何异常,所以我应该添加block内的try-catch。这似乎是我对CLR可能

c# - .NET4.5.1的Try-Catch-Finally阻止问题

我有一个简单的try-catch-finally代码块,该块在.NET3.5中可以按预期工作,但是在使用.NET4.5.1创建的项目中,相同的代码的行为完全不同。基本上,在.NET4.5.1中,如果发生异常(这不是我从try-catch-finally块所期望的行为),则“finally”块不会被命中。我尝试了不同的机器,并且我的另外2个同事也尝试了,我们都得到了相同的结果。这是我关心的问题,因为我使用了finally块来关闭DataReader,某些连接以及诸如此类的东西。如果在没有调试器的情况下在RELEASE模式下引发了异常,或者在运行RELEASE编译的EXE文件时,.NET4

javascript - 公理。即使 api 返回 404 错误,如何在 try catch finally 中获得错误响应

例如(async()=>{letapiRes=null;try{apiRes=awaitaxios.get('https://silex.edgeprop.my/api/v1/a');}catch(err){console.error(err);}finally{console.log(apiRes);}})();在finally中,apiRes将返回null。即使api收到404响应,响应中仍然有我想使用的有用信息。当axios抛出错误时,如何在finally中使用错误响应。https://jsfiddle.net/jacobgoh101/fdvnsg6u/1/