网站建设方面的文章WordPress手机缩略图设置
web/
2025/10/4 15:52:14/
文章来源:
网站建设方面的文章,WordPress手机缩略图设置,官网站内推广内容,网站开发学徒工作如何这是称为“ Functional Java by Example”的系列文章的第3部分。 我在本系列的每个部分中发展的示例是某种“提要处理程序”#xff0c;用于处理文档。 在前面的部分中#xff0c;我从一些原始代码开始#xff0c;并应用了一些重构来描述“什么”而不是“如何”。 为了帮助… 这是称为“ Functional Java by Example”的系列文章的第3部分。 我在本系列的每个部分中发展的示例是某种“提要处理程序”用于处理文档。 在前面的部分中我从一些原始代码开始并应用了一些重构来描述“什么”而不是“如何”。 为了帮助代码向前发展我们需要摆脱良好的java.lang.Exception 。 免责声明我们实际上无法摆脱它这就是其中的内容。 如果您是第一次来这里最好从头开始阅读。 它有助于了解我们从何处开始以及如何在整个系列中继续前进。 这些都是这些部分 第1部分–从命令式到声明式 第2部分–讲故事 第3部分–不要使用异常来控制流程 第4部分–首选不变性 第5部分–将I / O移到外部 第6部分–用作参数 第7部分–将失败也视为数据 第8部分–更多纯函数 我将在每篇文章发表时更新链接。 如果您通过内容联合组织来阅读本文请查看我博客上的原始文章。 每次代码也被推送到这个GitHub项目 。 快速了解异常 自Java 1.0以来我们的java.lang.Exception一直存在-基本上在好时机和其他时候成为我们的敌人。 关于它们的讨论不多但是如果您想阅读一些资源这是我的最爱 Java异常 JavaWorld Java例外– GeeksforGeeks geeksforgeeks.org 9种处理Java中异常的最佳实践 stackify.com 异常处理的最佳实践 onjava.com Java异常面试问答 journaldev.com 带有示例的Java中的异常处理 beginnersbook.com Java异常处理Try-catch hackerrank.com 十大Java异常处理最佳实践– HowToDoInJava howtodoinjava.com Java中的异常处理和断言– NTU ntu.edu.sg 异常处理最佳实践指南 dzone.com 在Java中处理异常的9种最佳实践 dzone.com 修复7个常见Java异常处理错误 dzone.com Java惯例-已检查异常与未检查异常 javapractices.com Java中异常的常见错误 MikaelStåldal的技术博客 staldal.nu Java开发人员在使用异常时犯的11个错误 medium.com/rafacdelnero 检查异常是好是坏 JavaWorld 检查异常Java的最大错误 精简Java literatejava.com 未经检查的异常-争议 docs.oracle.com 已检查异常的麻烦 artima.com Java例外您可能做错了 dzone.com Java理论与实践异常辩论– IBM ibm.com Java的检查异常是一个错误这是我想做的 radio-weblogs.com Buggy Java代码Java开发人员犯的十大最常见错误 Toptal toptal.com 您已经在Java 8上了吗 生活变得好多了 我… 呃…哦等等。 Java输入流的错误处理– Javamex javamex.com 在Java流中处理检查的异常 oreilly.com JDK 8流中的异常处理 azul.com 带有异常的Java 8功能接口 slieb.org 重新打包流中的异常– blog CodeFX blog.codefx.org 如何在Java 8 Stream中处理异常 –堆栈溢出 stackoverflow.com 检查异常和流| Benji的博客 benjiweber.co.uk 一个关于检查异常和Java 8 Lambda表达式的 故事 javadevguy.wordpress.com– 很好的战争故事 hgwood / java8-streams-and-exceptions github.com … 好的看来您不可能正确地做到这一点。 至少阅读上述名单后我们现在完全取决于对速度的话题55357;56898; 幸运的是我不必再写一篇博客文章介绍上面的文章已经涵盖了95的内容但是在这里我将重点讨论代码中实际存在的一个Exception 55357;56898; 副作用 既然您正在阅读这篇文章您可能会对为什么这一切都与函数式编程有关感兴趣。 在以更“实用的方式”处理代码的过程中您可能会遇到“副作用”一词这是一件“坏事”。 在现实世界中 副作用是您不希望发生的事情 您可能会说它等同于“例外”情况您会例外说明但是在函数式编程上下文中它具有更严格的含义。 维基百科有关副作用的文章说 副作用计算机科学在计算机科学中如果函数或表达式在返回范围之外修改了某些状态或与其调用函数或外界有可观察的交互作用则称该函数或表达式具有副作用。 …在函数式编程中很少使用副作用。 因此在本系列的前两篇文章之后让我们看看我们的FeedHandler代码当前的样子 class FeedHandler {Webservice webserviceDocumentDb documentDbvoid handle(ListDoc changes) {changes.findAll { doc - isImportant(doc) }.each { doc -try {def resource createResource(doc)updateToProcessed(doc, resource)} catch (e) {updateToFailed(doc, e)}}}private Resource createResource(doc) {webservice.create(doc)}private boolean isImportant(doc) {doc.type important}private void updateToProcessed(doc, resource) {doc.apiId resource.iddoc.status processeddocumentDb.update(doc)}private void updateToFailed(doc, e) {doc.status faileddoc.error e.messagedocumentDb.update(doc)}} 在一个地方我们尝试捕获异常在那儿我们循环浏览重要的文档并尝试为其创建“资源”无论是什么。 try {def resource createResource(doc)updateToProcessed(doc, resource)
} catch (e) {updateToFailed(doc, e)
} 在上面的代码中catch (e)是catch (Exception e) Groovy缩写。 是的这就是我们正在捕获的通用java.lang.Exception 。 可以是任何例外包括NPE。 如果createResource方法没有引发异常则将文档“ doc”更新为“已处理”否则将其更新为“失败”。 顺便说一句即使updateToProcessed也会引发异常但是对于当前的讨论我实际上只对成功创建资源感兴趣。 因此上面的代码可以工作 我已经通过单元测试来证明它:-)但是我对try-catch语句不满意。 我只对成功创建资源感兴趣而且很傻我只能提出createResource要么返回成功的资源 要么抛出异常。 抛出异常以表示出了点问题躲开闪避让调用者捕获该异常以进行处理这是为什么发明了异常的原因呢 而且比返回null更好吗 它一直在发生。 采取一些我们喜欢的框架例如JPA规范中的 EntityManager#find 啊 返回null 。 返回值 找到的实体实例如果该实体不存在则返回null 错误的例子。 函数式编程鼓励使用无副作用的方法或函数以使代码更易于理解且更易于推理。 如果某个方法仅接受某些输入并每次都返回相同的输出这使其成为一个纯函数则各种优化都可以在后台进行例如通过编译器或缓存并行化等。 我们可以再次用纯函数计算出的值替换纯函数这称为参考透明度 。 在上一篇文章中我们已经将一些逻辑提取到了自己的方法中例如下面的isImportant 。 给定相同的文档具有相同的 type属性作为输入我们每次都会获得相同的 布尔值输出。 boolean isImportant(doc) {doc.type important
} 这里没有可观察到的副作用没有全局变量被突变没有日志文件被更新–它只是塞进塞出 。 因此我要说的是通过我们的传统异常与外界交互的函数很少在函数式编程中使用。 我想做得更好 。 更好 。 可选救援 正如石磊韦伯表示它 关于如何在Java中有效使用异常有不同的观点。 有些人喜欢检查异常有些人则认为这是一次失败的实验他们更喜欢独占使用未检查异常。 其他人则完全避开异常而赞成传递和返回诸如Optional或Maybe之类的类型。 好的让我们尝试一下Java 8的Optional以便发出是否可以创建资源的信号。 让我们更改我们的webservice接口和createResource方法以在Optional包装并返回我们的资源 //private Resource createResource(doc) {
private OptionalResource createResource(doc) {webservice.create(doc)
} 让我们更改原始的try-catch try {def resource createResource(doc)updateToProcessed(doc, resource)
} catch (e) {updateToFailed(doc, e)
} map 处理资源和orElseGet 处理空的可选 createResource(doc).map { resource -updateToProcessed(doc, resource)}.orElseGet { /* e - */updateToFailed(doc, e)} 很棒的createResource方法返回正确结果或者为空结果。 等一下 唯一的例外e我们需要传递到updateToFailed是走了 我们有一个空的Optional替代。 我们不能存储的原因失败的原因 -这是我们做的必要性。 可能是Optional只是表示“缺席”并且是我们此处目的不正确的工具。 出色的完成 如果没有try-catch和map-orElseGet 我确实喜欢代码开始更多地反映操作“流程”的方式。 不幸的是使用Optional更适合“得到一些东西”或“什么也没有得到”这也建议使用map和orElseGet类的名称并且没有给我们提供记录失败原因的机会。 还有什么方法能够获得成功的结果或失败的原因而仍然接近我们的阅读方式呢 Future 。 更好的是 CompletableFuture 。 CompletableFuture CF知道如何返回值这类似于Optional 。 通常CF用于将来获取值集 但这不是我们想要将其用于…的原因。 从Javadoc ……支持……在完成时触发的行动的未来。 跳动它可以表示“异常”完成 -给我机会对此采取行动。 让我们更改map和orElseGet createResource(doc).map { resource -updateToProcessed(doc, resource)}.orElseGet { /* e - */updateToFailed(doc, e)} thenAccept 处理成功并exceptionally 处理失败 createResource(doc).thenAccept { resource -updateToProcessed(doc, resource)}.exceptionally { e -updateToFailed(doc, e)} CompletableFuture#exceptionally方法接受一个带有我们实际失败原因的异常e的函数。 您可能会想 tomaytotomahto。 首先我们进行了try-catch 现在我们进行了thenAccept-exceptionally 那么有什么大不同 好吧我们显然不能摆脱特殊情况但我们现在正在像Functionalville的居民那样思考我们的方法开始成为函数 告诉我们有什么东西有事。 考虑到这是我们在第4部分中需要进行的少量重构而在第5部分中甚至更多地限制了代码中的副作用。 现在就这样 作为参考这是重构代码的完整版本。 class FeedHandler {Webservice webserviceDocumentDb documentDbvoid handle(ListDoc changes) {changes.findAll { doc - isImportant(doc) }.each { doc -createResource(doc).thenAccept { resource -updateToProcessed(doc, resource)}.exceptionally { e -updateToFailed(doc, e)}}}private CompletableFutureResource createResource(doc) {webservice.create(doc)}private boolean isImportant(doc) {doc.type important}private void updateToProcessed(doc, resource) {doc.apiId resource.iddoc.status processeddocumentDb.update(doc)}private void updateToFailed(doc, e) {doc.status faileddoc.error e.messagedocumentDb.update(doc)}} - 翻译自: https://www.javacodegeeks.com/2018/01/functional-java-example-part-3-dont-use-exceptions-control-flow.html
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/web/86857.shtml
如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!