草庐IT

c# - 使用不带参数的 catch

有什么区别:catch{MessageBox.Show("Error.");}和:catch(Exceptionex){MessageBox.Show("Error.");//weneveruseex,soisitbettertousecatchwithoutarguments?} 最佳答案 从.NET2开始,如果您不调整配置​​?什么都没有。在那之前,或者通过一些我记不清的配置调整,非托管代码可能会抛出一个异常,没有被转换成一个Exception-兼容对象。请注意,在这两者之间还有另一个选项,您可以在其中指定类型但不指定变量:ca

c# - 为什么 Try-Catch 需要花括号

只是好奇:为什么trycatchinC#的语法是(Java也是?)为多个语句硬编码?为什么语言不允许:inti;strings=DateTime.Now.Seconds%2==1?"1":"not1";tryi=int.Parse(s);catchi=0;该示例仅供引用。我知道有int.TryParse. 最佳答案 考虑一下这里实际上有三个(或更多)代码块:try{}catch(myexcption){}catch(myotherexception){}finally{}请记住,这些是在更大上下文的范围内,未捕获的异常可能会在堆栈的

c# - float 解析 : Is there a Catch All algorithm?

多文化编程中有趣的部分之一是数字格式。美国人使用10,000.50德国人使用10.000,50法语使用10000,50我的第一种方法是获取字符串,向后解析它直到遇到分隔符并将其用作我的小数点分隔符。这有一个明显的缺陷:10.000会被解释为10。另一种方法:如果字符串包含2个不同的非数字字符,则使用最后一个作为小数点分隔符并丢弃其他字符。如果我只有一个,请检查它是否出现不止一次,如果出现则丢弃它。如果它只出现一次,请检查它后面是否有3位数字。如果是,则丢弃它,否则,将其用作小数点分隔符。显而易见的“最佳解决方案”是检测用户的文化或浏览器,但如果您的法国人使用的是en-USWindows

c# - 在 C# 中验证 URL 的一种比 try-catch 更好的方法?

我正在构建一个应用程序以从Internet检索图像。尽管它工作正常,但在应用程序中使用try-catch语句时速度很慢(在错误的给定URL上)。(1)这是验证URL和处理错误输入的最佳方式吗?还是我应该改用Regex(或其他一些方法)?(2)如果我没有在文本框中指定http://,为什么应用程序会尝试在本地查找图像?privatevoidbtnGetImage_Click(objectsender,EventArgse){Stringurl=tbxImageURL.Text;byte[]imageData=newbyte[1];using(WebClientclient=newWebC

c# - .NET - 实现 "catch all exceptions handler"的最佳方法是什么

我想知道最好的方法是“如果一切都失败了”。我的意思是,您在应用程序中处理尽可能多的异常,但仍然会有错误,所以我需要有一些东西捕获所有未处理的异常,以便我可以收集信息并存储将它们保存在数据库中或将它们提交给网络服务。AppDomain.CurrentDomain.UnhandledException事件是否捕获所有内容?即使应用程序是多线程的?旁注:WindowsVista公开了允许任何应用程序使用的nativeAPI函数在崩溃后自行恢复......现在想不出这个名字......但我宁愿不要使用它,因为我们的许多用户仍在使用WindowsXP。 最佳答案

c# - 使用 "catch, when"捕获异常

我在C#中发现了这个新功能,它允许在满足特定条件时执行捕获处理程序。inti=0;try{thrownewArgumentNullException(nameof(i));}catch(ArgumentNullExceptione)when(i==1){Console.WriteLine("CaughtArgumentNullException");}我正在尝试了解这何时可能有用。一个场景可能是这样的:try{DatabaseUpdate()}catch(SQLExceptione)when(driver=="MySQL"){//MySQLspecificerrorhandlingan

c# - 我怎样才能 catch 404?

我有以下代码:HttpWebRequestrequest=(HttpWebRequest)WebRequest.Create(url);request.Method="HEAD";request.Credentials=MyCredentialCache;try{request.GetResponse();}catch{}如何捕获特定的404错误?WebExceptionStatus.ProtocolError只能检测到有错误发生,并不能给出错误的具体代码。例如:catch(WebExceptionex){if(ex.Status!=WebExceptionStatus.Protoco

c# - C# 中 try/catch 的真正开销是多少?

所以,我知道try/catch确实会增加一些开销,因此不是控制流程的好方法,但这些开销从何而来,它的实际影响是什么? 最佳答案 这里要说明三点:首先,在您的代码中实际使用try-catchblock几乎没有或没有性能损失。当试图避免在您的应用程序中使用它们时,不应考虑这一点。只有在抛出异常时才会影响性能。除了发生其他人提到的堆栈展开操作等之外还抛出异常时,您应该知道会发生一大堆运行时/反射相关的事情以填充异常的成员堆栈跟踪对象和各种类型成员等类。我相信这就是为什么如果您要重新抛出异常,一般建议只是throw;而不是再次抛出异常或构造

c# - try/catch/throw 和 try/catch(e)/throw e 的区别

有什么区别try{}catch{throw;}和try{}catch(Exceptione){throwe;}?我应该什么时候使用其中之一? 最佳答案 结构try{...}catch(){...}/*Youcanevenomitthe()here*/try{...}catch(Exceptione){...}的相似之处在于两者都会捕获tryblock中抛出的每个异常(并且,除非您只是简单地使用它来记录异常,否则应该是避免)。现在看看这些:try{...}catch(){/*...*/throw;}try{...}catch(Exce

c# - 从 try catch finally block 中返回是不好的做法吗?

所以今天早上我遇到了一些代码,看起来像这样:try{x=SomeThingDangerous();returnx;}catch(Exceptionex){thrownewDangerousException(ex);}finally{CleanUpDangerousStuff();}现在这段代码可以正常编译并正常工作,但是从tryblock中返回感觉不对,尤其是在有关联的finally的情况下。我的主要问题是如果finally抛出它自己的异常会发生什么?您有一个返回的变量,但也有一个异常需要处理...所以我很想知道其他人对从tryblock中返回有何看法?