- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
在Winforms-MVP的半年时间里,我设计了如下的异常处理策略。我有一个基本的抽象 Presenter 类,其中有几个 Execute 方法将委托(delegate)作为输入参数(签名各不相同)。 View 和 Presenter 之间的交互是通过 IView 中定义的事件(输入)以及设置公共(public)属性(输出)或调用 IView 中定义并由 View 实现的方法来完成的。 Presenter 中的每个事件处理程序都调用其中一个 Execute 方法,为其提供具体实现。
在execute方法中我有几个catch block ,用于非常明确的可能发生的异常(主要是因为广泛使用的外部组件中的一些问题)。这些异常中的每一个都会停止当前操作的执行,被记录下来并通过调用 View 的方法向用户显示有意义的解释。
不久前(事实上非常不久前)我开始学习 WPF-MVVM,乍一看似乎与 MVP 有很多共同点。我一直在寻找有关异常处理策略的一些方便的建议(主要是通知用户有关问题),但一般来说很难搜索到这些问题——我的意思是,说了很多,但主要是原则上的。我在 app.xaml.cs 中找到了 20 多个“处理”未处理异常的示例,这一切都非常好,但请真诚地告诉我 - 如果您知道可能使您的应用程序崩溃的确切异常,您会不会处理它们?早一点(即使您将被迫关闭您的应用程序)?我不喜欢捕捉所有可能的异常。很多由网络问题、临时数据库不可用等引起的异常应该在不关闭应用程序的情况下处理,没有可怕的错误图标,让普通用户有机会重复他的请求。
因此,作为一项实验,我尝试了与我之前描述的几乎相同的事情 - 我在 ViewModel 中创建了事件以进行异常转换,并为它们订阅了 View。但是,坦率地说,这种方式让我毛骨悚然。
(这是一个很长的演讲,我知道)问题:在使用 MVVM 时,您如何处理与通知用户相关的异常?不,我暂时对数据验证不感兴趣。也欢迎任何关于 MVP 的批评和/或建议。
最佳答案
我们针对 Wpf 应用程序中不同类型的错误条件采用了几种不同的策略。
对于代码可以在不通知用户的情况下处理和继续的预期错误,我们执行正常的 Try Catch block 。
对于预期的错误,但从用户的角度来看会导致失败,我们在 ViewModels 上公开一个通知集合,绑定(bind)到我们的 View
上的 ItemsControl,它在类似的模板中Firefox/IE/Chrome 中通知栏的方式。每个通知都有一个显示持续时间属性(通知集合使用调度程序计时器进行 self 修剪)和 View 中的关闭按钮,以便它们可以在特定时间段内显示或可以由用户显式关闭。这个模型的好处是它可以用于完成消息、警告和异常——以及一些可能不会表现为异常但从用户角度来看仍然是错误条件的情况。通知通常是消息框的一个很好的替代品,因为它们不会中断用户的工作流程。
对于我们未预料到的错误,我们使用 Red Gate SmartAssembly捕获完整的详细信息,以便用户可以将它们发送给我们的支持人员进行分析。我们的观点是,在您没有预料到的异常发生后捕获并继续您的应用程序是一种非常冒险的策略 - 来自意外异常的堆栈不会展开并且您的应用程序将在错误发生后处于不一致状态(这可能导致从奇怪的 UI 到损坏的数据),并且可能会产生无法预测的副作用。应用程序崩溃并不是很好的用户体验,但由于应用程序忽略的错误导致意外状态而导致数据损坏,这是一种非常糟糕的体验。我们的策略是捕获有关崩溃的尽可能多的详细信息,以便用户知道我们对解决问题是认真的,我们将在未来的更新中修复/捕获它 - 而不是继续进行并解决可能更严重的问题。
关于c# - 通知最终用户 Winforms-MVP 和 WPF-MVVM 中的异常,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/6473021/
我有一个应用程序应该在应用程序处于前台和后台(不在历史记录中)时显示提醒通知。 在前景情况下,我通过以下方法实现了这一点。 PendingIntent pendingIntent = PendingI
如何为我的 WPF 应用程序创建通知,例如浏览器上的通知,它们通过浏览器顶部的“工具栏”显示消息或通过在右下角向上/向下滑动的弹出窗口显示“MSN”样式通知屏幕。也许在应用程序中心淡入/淡出的面板可以
关闭。这个问题是opinion-based .它目前不接受答案。 想要改进这个问题? 更新问题,以便 editing this post 可以用事实和引用来回答它. 关闭 9 年前。 Improve
我正在使用 Redis 作为分布式缓存。我有不同的应用程序,它们只听特定的键。例如:App1 听 App1.*App2 监听 App2.* 等等。 我的应用程序使用以下模式接收通知:App1:“ ke
我正在尝试构建一个基于官方节点 docker 镜像的 docker 镜像,我想知道是否有某种方法可以在推送新版本的官方节点镜像时自动重建镜像。这样我的图像就不会基于过时的基础图像。 也许有类似 rss
我在一个项目中工作,我需要在添加或修改文件时在数据库中记录文件信息,以便它们保持同步。这些文件应该存储在 Nextcloud 服务器中,那么 Nextcloud 是否有办法通知这些更改(例如 webh
通知类中的方法via 如何根据用户的偏好动态变化,一个用户可能想通过电子邮件接收,而另一个用户则不想 public function via($notifiable) { return ['d
我有一个应用程序,我正在发送推送通知,如果用户登录到应用程序,这很好 - 但是,如果他们没有/如果他们没有在 X 分钟内阅读通知,我想给他们发送一封电子邮件. 我要解决的方法是使用 Laravel N
我正在使用 Django 的 contrib.comments 并想了解以下内容。 是否有任何实用程序或应用程序可以插入到某个应用程序中,当对某个项目发表评论时向您发送通知? 我并没有真正使用过那么多
我希望用户在启动应用程序之前接受协议(protocol)。所以在 appDelegate.m 中我有以下内容: - (BOOL)application:(UIApplication *)applica
我正在创建一个新指令,我想知道如何在 angular 从 DOM 中删除元素时收到通知。 我的目标是在删除元素时添加 jquery 动画。 最佳答案 如果您尝试对元素的移除进行动画处理,则需要在移除元
我正在编写一个应用程序,其工作方式与Apple的Weather.app非常相似:底部有一个UIPageControl,屏幕中间有一个UIScrollView。在我的代码中,我实现了 - (void)s
如何查明 iPhone 注册了哪些通知? 例如: notify_post("com.apple.springboard/Prefs"); 最佳答案 虽然这个问题的答案已经得到确认,但由于 @Nate
我的 Cocoa 应用程序中有一个 TextField。该文本字段有时会被填充,有时会为空。 我希望当字段为空时按钮被禁用。现在,每当我对 Core Data 执行某些操作时,我都会检查该字段,Tex
我的应用程序在其数据库中包含文档。用户可以打开文档,在这种情况下,文档将保存到临时文件夹并在用户计算机上打开。 我希望在这些临时文件之一发生更改时收到通知,并让用户将更改后的文档保存回数据库。 在 D
我目前正在开发一个网络应用程序,它不断对 php 进行 ajax 调用(轮询),以从数据库中提取新的“任务”,有点像 gmail/facebook 检查新电子邮件和消息的方式。当前的 JavaScri
我正在尝试让通知适用于我使用 Angular 5 和 Electron 制作的 Electron 应用程序。到目前为止,我的 index.html 文件中有以下代码: function doNo
我有一个录音/播放应用程序。它在后台运行。当它进入后台时,如果任何其他音频应用程序打开或开始使用音频资源,我想适本地处理我的应用程序。 iOS 提供了一种发送此类通知的方法,如在 ipod 播放器中看
关闭。这个问题需要多问focused 。目前不接受答案。 想要改进此问题吗?更新问题,使其仅关注一个问题 editing this post . 已关闭 4 年前。 Improve this ques
是否有 Subversion 的工具可以在对某些文件提交更改时自动通知我? 最佳答案 您可以创建一个 post-commit hook script “ Hook ”提交。 在钩子(Hook)脚本中,
我是一名优秀的程序员,十分优秀!