在库方法中调用 String.getBytes("UTF-8") 时处理UnsupportedEncodingException的推荐方法是什么?
如果我正确阅读http://docs.oracle.com/javase/6/docs/technotes/guides/intl/encoding.doc.html,UTF-8编码应该始终可用,这让我相信没有将此异常传递给库的使用者的原因(即,throws
在方法签名中添加一个子句)。似乎任何使 UTF-8 编码设施不可用的故障模式都是灾难性的,导致我编写了这个处理程序:
try
{
....
return "blah".getBytes("UTF-8");
}
catch (UnsupportedEncodingException e)
{
// we're assuming UTF-8 encoding is always available.
// see
// http://docs.oracle.com/javase/6/docs/technotes/guides/intl/encoding.doc.html
e.printStackTrace();
return null; //prevent compile-time "method must return a result" errors
}
是否存在此代码段无法解决的故障模式?