上下文异常中的上下文属性_在没有适当上下文的情况下引发异常是一种不良习惯...

上下文异常中的上下文属性

Allison Anders等人的《四个房间》(1995)。

Allison Anders等人的《四个房间》(1995)。

我不断重复同样的错误。

因此,该停止并制定规则以防止这种情况了。

错误不是致命的,但很烦人。

当查看生产日志时,经常会看到类似"File doesn't exist" ,并且我问自己:什么文件?

它应该在哪里存在?

服务器尝试使用它做什么?

崩溃前一秒钟发生了什么?

日志中没有答案,这完全是我的错。

我要么1)不重新抛出,要么2)在不提供上下文的情况下重新抛出。

两者都是错的。

代码如下所示:

if (!file.exists()) {throw new IllegalArgumentException("File doesn't exist");
}

它也可能看起来像这样:

try {Files.delete(file);
} catch (IOException ex) {throw new IllegalArgumentException(ex);
}

这两个示例都说明了处理涉及异常并报告异常的情况的风格不足。 怎么了 异常消息不够彻底。 它们根本不包含来自其来源的任何信息。

他们应该这样看:

if (!file.exists()) {throw new IllegalArgumentException(String.format("User profile file %s doesn't exist",file.getAbsolutePath()));
}

第二个示例应如下所示:

try {Files.delete(file);
} catch (IOException ex) {throw new IllegalArgumentException(String.format("Can't delete user profile data file %s",file.getAbsolutePath()),ex);
}

看到不同? 这看起来像是冗余代码,但事实并非如此。 当然,当我编写所​​有这些内容时,我并不真正在乎日志和异常。 我并不是真的希望这个文件不存在。

但是我应该。

应该有一条规则:每次我们抛出或重新抛出异常消息时,都必须尽可能详细地描述问题。

当然,我们不能忘记安全性和冒着将任何敏感信息(例如密码,信用卡号等)放入异常消息中的风险。此外,必须在更高级别上尽可能多地向异常捕获程序公开这些信息。

抛出异常实际上是将问题升级到更高级别的管理。 想象一下,老板要我安装新服务器。 几小时后我回到他身边说:“我失败了;我失败了。 抱歉。” 听起来很奇怪。 他会要求更多细节。 为什么我失败了? 到底出了什么问题? 可以做不同的事情吗? 等等。

这样的代码实际上是对客户不尊重的标志:

throw new IllegalArgumentException("File doesn't exist"
);

我必须更加详细,并提供更多细节。

我不是一个人犯这个错误。 我到处都看到它,这确实使调试变得困难,尤其是在生产中,几乎不可能立即重现该问题。

因此,请在您的异常消息中更加详细。 我将在代码中执行相同的操作:)

还有一件事,然后再走。 在大多数OOP语言中,未检查异常是不幸的 ,这意味着捕获异常不是强制性操作。 尽管如此,我还是建议您始终捕获,添加上下文并重新抛出它们。 这似乎是纯噪声,但事实并非如此! 只是使您的方法更小,并确保从它们发出的所有异常都具有有关其来源的足够信息。 您将为自己和其他人带来很大的帮助。

翻译自: https://www.javacodegeeks.com/2015/12/throwing-exception-without-proper-context-bad-habit.html

上下文异常中的上下文属性

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/336549.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

最大公约数简便算法_求最大公约数的4种算法

for(z0; z<10000000; z) 循环只是为了增加程序的运行时间&#xff0c;让我们体会算法的时间复杂度。算法一&#xff1a;短除法想法&#xff0c;采用短除法找出2个数的所有公约数&#xff0c;将这些公因子相乘&#xff0c;结果就是2个数的最大公约数。【找公因子&#xff0c;…

java 编写代码_如果您在2015年编写过Java代码-这是您不容错过的趋势

java 编写代码去年我们有机会遇到的最有趣趋势的实用概述 在这篇文章中&#xff0c;我们回顾了构成我们2015年对话的5个主题和新发展。与其他许多年终总结保持较高水平的不同&#xff0c;我们将做一个更实际的操作不用流行语 。 好吧&#xff0c;没有太多*流行语。 与往常一样…

java自动生成合同_Java 7和Java 8之间的细微自动关闭合同更改

java自动生成合同Java 7的try-with-resources语句和与该语句一起使用的AutoCloseable类型的一个不错的功能是&#xff0c;静态代码分析工具可以检测到资源泄漏。 例如&#xff0c;Eclipse&#xff1a; 当您具有上述配置并尝试运行以下程序时&#xff0c;您将收到三个警告&…

Python学习(1)

1.str字符串操作 len(str) 计算字符串长度 str.replace(xxx,xxxx) 替换指定字符 str.upper()字符串转大写 str.lower()字符串转小写 str.strip()删除左右多余的空格 str.lstrip()删除左边多余的空格 str.rstrip()删除右边的空格 format(a,b,c) 传参显示 2.索引 out hello wo…

opencv求两张图像光流_光流(optical flow)和openCV中实现

转载请注明出处&#xff01;&#xff01;&#xff01;光流(optical flow)和openCV中实现光流的概念&#xff1a;是Gibson在1950年首先提出来的。它是空间运动物体在观察成像平面上的像素运动的瞬时速度。是利用图像序列中像素在时间域上的变化以及相邻帧之间的相关性来找到上一…

swarm 和 k8s_Wildfly Swarm,朝着成熟和一小部分贡献

swarm 和 k8s我最近关注的项目之一是Wildfly Swarm 。 最终&#xff0c;在今年的JBoss BOF中的Devoxx期间&#xff0c;由于考虑与著名的Docker Swarm发生冲突&#xff0c;我的要求没有考虑更改项目名称。 那么什么是Wildfly Swarm&#xff1f; 简而言之&#xff0c;就是Wildfl…

python socket多线程 获取朋友列表_python socket多线程通讯实例分析(聊天室)

本文实例讲述了python socket多线程通讯方法。分享给大家供大家参考&#xff0c;具体如下&#xff1a;#!/usr/bin/evn python"""这是一个Socket多进程的例子(聊天服务端)"""import socketimport threading# 处理中文数据用的encoding "GBK…

8进5预警处理

题&#xff1a;在图像处理中&#xff0c;如果发现有危险标为1&#xff0c;否则标为0. 在图像处理中可能出现误报。因此采用8进5的方法&#xff0c;即前8里面有5个预警&#xff0c;我们就返回预警信息. #include <iostream> #include<queue> using namespace std;q…

facelets_Java EE 8中的MVC 1.0:使用Facelets入门

faceletsMVC 1.0是一个基于动作的Model-View-Controller Web框架&#xff0c;它将成为将来的Java EE 8的一部分。它将与基于组件的JSF框架并存&#xff0c;并提供了构建面向HTML javascript的应用程序的替代方法完全控制网址。 这篇文章总结了使用Facelets代替默认的JSP作为M…

python实现端口转发_python实现超简单端口转发的方法

本文实例讲述了python实现超简单端口转发的方法。分享给大家供大家参考。具体如下&#xff1a;代码非常简单&#xff0c;实现了简单的端口数据转发功能&#xff0c;用于真实环境还需要再修改一下。代码如下:#tcp serverimport sockethost 127.0.0.1 #Local Server IP…

C++防卫式编程

#ifndef XXXXXX #define XXXXXX //代码段 #endif 此段代码保证了&#xff0c;在多重包含情况下不会重复包含。 1.如果已经定义了defineXXX则代码段不会被编译&#xff0c;反之则会编译

storm apache_Apache Storm的实时情绪分析示例

storm apache实时情感分析是指处理自然语言文本&#xff08;或语音&#xff09;流以提取主观信息。 琐碎的用例用于构建推荐引擎或查找社交媒体趋势。 我选择了Apache Storm作为实时处理引擎。 Storm非常强大&#xff08;我们正在生产中使用它&#xff09;&#xff0c;并且非常…

怎么用python画圆的公式_怎么用python画圆

python中内置了许多第三方库&#xff0c;来帮助它完成各种功能。Turtle库就是Python语言中一个很流行的绘制图像的函数库(推荐学习&#xff1a;Python视频教程)Turtl库用于绘制线、圆、其他形状或者文本这个库被介绍为一个最常用的用来给孩子们介绍编程知识的方法库&#xff0c…

C++函数后置返回类型

//后置函数返回类型声明 auto func(int a, int b)->void; //后置函数返回类型定义 auto func(int a, int b)->void {return; }

嵌入式java基准测试_Java正则表达式库基准测试– 2015年

嵌入式java基准测试在尝试使Java在计算机语言基准游戏的regexdna挑战中排名第一时&#xff0c;我正在研究Java正则表达式库的性能。 我可以找到的最新网站是2010年的tusker.org 。因此&#xff0c;我决定使用Java Microbenchmarking Harness重做测试并发布结果&#xff08;破坏…

java决策树_【Java】决策树介绍和使用

现在生活中&#xff0c;越来越多的时候 需要进行判断和决策&#xff0c;因此关于怎么去判断和决策&#xff0c;需要根据一定的依据进行判断和决策&#xff0c;并不是凭空的按照自己的意愿去判断和决策&#xff0c;就比如举个例子&#xff1b; 假如甲同学准备结婚&#xff0c;但…

C++ 【随想录】(五)C 文件操作

#include<iostream> #include<cstdio> using namespace std;int main() {FILE *fp1 NULL; //指向源文件FILE *fp2 NULL; //指向目的文件char *byBuffNULL; //缓存int fileBytes 0; //文件大小const char* pSrc "M3.264";const char* pDest "M…

stackoverflow_Stackoverflow的见解:投票最多的是Spring 4问题

stackoverflow在Stackoverflow上对Spring 4问题进行投票和回答最多的是什么&#xff1f; 以下是最常见的五个问题和解答。 Spring中的 Component&#xff0c; Controller&#xff0c; Repository和Service批注有什么区别&#xff0c;它们可以互换使用还是具有特定功能&#xf…

java 编译顺序_关于java中一次编译多个源文件时的编译顺序的问题

为了节省回答者的时间我先把问题提出来&#xff0c;再针对问题案例作详细说明。如果能不用看问题案例就回答出来当然省时。我的问题是java里面&#xff0c;用命令行提示符环境编译源文件的时候&#xff0c;加上*通配符...为了节省回答者的时间我先把问题提出来&#xff0c;再针…

宏定义细节

#define PI(a,b) ab //分析 /* PI(a,b)a,b是参数 后面的ab进行运算 返回值作为PI的宏定义