草庐IT

异常系列

全部标签

c# - Xamarin:不传播任务引发的异常

我在Xamarin中有以下代码(在ios中测试):privatestaticasyncTaskTaskWithException(){returnawaitTask.Factory.StartNew(()=>{thrownewException("Booo!");return"";});}publicstaticasyncTaskRunTask(){try{returnawaitTaskWithException();}catch(Exceptionex){Console.WriteLine(ex.ToString());throw;}}调用它作为awaitRunTask(),确实会从

c# - 最佳实践返回值与异常与枚举

关闭。这个问题是opinion-based.它目前不接受答案。想要改进这个问题?更新问题,以便editingthispost可以用事实和引用来回答它.关闭8年前。Improvethisquestion我正在尝试找出具有多个结果值的方法的优点和缺点。例如,我正在使用登录方法。如果登录成功,则通过,否则我需要知道为什么失败。1。返回true或false(信息不足)boolLogin(stringuser,stringpassword);2。如果成功则返回true,否则抛出异常publicclassUnknownUserException:Exception{}publicclassWron

c# - "using"构造和异常处理

“using”结构对于需要开始和分开的结束部分的情况看起来非常方便。快速举例说明:using(newTag("body")){Trace.WriteLine("hello!");}//...classTag:IDisposable{Stringname;publicTag(Stringname){this.name=name;Trace.WriteLine("");Trace.Indent();}publicvoidDispose(){Trace.Unindent();Trace.WriteLine("")}}开始部分定义为构造函数,结束部分为Dispose方法。然而,尽管这个结构很有

c# - 堆栈展开时嵌套异步方法中的堆栈溢出异常

我们有很多嵌套的异步方法,看到了我们并不真正理解的行为。以这个简单的C#控制台应用程序为例publicclassProgram{staticvoidMain(string[]args){try{varx=Test(index:0,max:int.Parse(args[0]),throwException:bool.Parse(args[1])).GetAwaiter().GetResult();Console.WriteLine(x);}catch(Exceptionex){Console.WriteLine(ex);}Console.ReadKey();}staticasyncTas

c# - Silverlight Rest 服务,安全异常

我试图让Silverlight与快速示例应用程序一起工作,并在另一台计算机上调用休息服务。具有其余服务的服务器有一个clientaccesspolicy.xml,如下所示:并且正在被拾取(至少根据我运行的网络跟踪),并且没有对crossdomain.xml的请求。C#代码如下所示:publicPage(){InitializeComponent();stringrestUrl="http://example.com/rest_service.html?action=test_result";WebClienttestService=newWebClient();testService.

c# - 如何记录异步方法的异常?

带有XML文档的示例方法://summaryandparamtagsareherewhenyou'renotlooking.//////isnull.///publicvoidWrite(stringtext){if(text==null)thrownewArgumentNullException("text","Textmustnotbenull.");//syncstuff...}Write(null)按预期抛出异常。这是一个异步方法:publicasyncTaskWriteAsync(stringtext){if(text==null)thrownewArgumentNullEx

c# - 无效的转换异常泛型

我遇到了这个问题,我正在使用反射从类中提取属性,但问题是反射将它们作为对象返回,而我无法将其放入我的实际类型中。举个例子,如果这是类:publicclassRow{publicstaticexplicitoperatorRow(Rowo){returnnewRow{Name=o.Name,Value=o.Value};}publicstringName{get;set;}publicTValue{get;set;}}类型转换自一说Row至Row作品:vara=newRow{Name="Foo",Value=true};varb=(Row)a;//Works但是当我尝试从object开始

c# - 返回 Task 的方法应该抛出异常吗?

返回Task的方法有两个报告错误的选项:立即抛出异常返回将异常结束的任务调用者是否应该期望两种类型的错误报告,或者是否有一些标准/协议(protocol)将任务行为限制为第二种选择?例子:classPageChecker{TaskCheckWebPage(stringurl){if(url==null)//ArgumentcheckthrowException("BadURL");//Someothersynchronouscheckif(!HostPinger.IsHostOnline(url))throwException("Hostisdown");returnTask.Fact

c# - 处理 ViewModel/Model 中的致命异常

我有一个使用M-V-VM方法编写的应用程序。数据访问在模型中完成。如果此处发生fatalerror(例如,与数据源的连接丢失),则抛出Exception。此异常冒泡到ViewModel。但是,因为数据访问的原始触发器是数据绑定(bind),WPF吞下了这个异常(它只在应用程序在调试器下运行时记录在输出窗口中)。我宁愿这个异常保持未处理状态,这样我的应用程序范围内的未处理异常处理程序就可以拾取它、记录它并优雅地退出。我怎样才能做到这一点? 最佳答案 您可以在调度程序上对异常抛出操作进行排队。//Thispropertyisconnec

c# - 如果列表/集合为空或 null 且无法迭代(不是参数),抛出什么异常类型?

假设一个简单的例子,其中一个方法检索一个集合(例如包含一些配置字符串的列表)并尝试以某种方式检查它:voidInit(){XmlDocumentconfig=newXmlDocument();config.Load(someXml);varlist=config.SelectNodes("/root/strings/key");//Normally,listshouldnotbenulloremptyif(list==null||list.Count==0)thrownewSomeExceptionType(message);//Whatkindofexceptiontothrow?/