JAVA静态代码块的异常,怎样才可以向上抛啊

zhangzhd 2009-06-09 10:14:45
JAVA静态代码块的异常,怎样才可以向上抛啊,急啊
...全文
1663 23 打赏 收藏 转发到动态 举报
AI 作业
写回复
用AI写文章
23 条回复
切换为时间正序
请发表友善的回复…
发表回复
zty598416146 2011-06-23
  • 打赏
  • 举报
回复
学习了
YangMacgrady 2010-03-03
  • 打赏
  • 举报
回复 1
引用 8 楼 shenguangliang 的回复:
静态代码块中的异常原则上必须处理,不应该也不能再往上抛
    原因:在类加载器,加载该类时,首先执行的就是static{}块中的代码,
        如果static{}块中的异常没有处理,异常就会导致该类加载失败,
        也就是说“该类夭折,不存在”,显然与其相关的操作肯定就不能执行

当然了,如果你“不得不”向外抛可以这样写:(用InputStream举例,可根据你自己的代码修改一下)
static{
try {
InputStream inputStream = new FileInputStream("") ;
} catch (FileNotFoundException e) {
// 抛出 运行式异常 (这样写,实质上也应该算是处理了异常)
throw new RuntimeException(e) ;
}
}


没有白进来~~
proproBook 2010-03-03
  • 打赏
  • 举报
回复
静态代码块中可以抛出:
throw new ExceptionInInitializerError(e);
h70885 2009-06-14
  • 打赏
  • 举报
回复
学习8楼
SimonYeung 2009-06-14
  • 打赏
  • 举报
回复
mark
johnston678 2009-06-13
  • 打赏
  • 举报
回复
可以抛,
不过不建议这么做!
Emerson_Li 2009-06-13
  • 打赏
  • 举报
回复
人多力量大,嘿嘿
young_smile 2009-06-12
  • 打赏
  • 举报
回复
8楼正确!throw new java.lang.RuntimeException();
virginkj 2009-06-12
  • 打赏
  • 举报
回复
[Quote=引用 8 楼 shenguangliang 的回复:]
静态代码块中的异常原则上必须处理,不应该也不能再往上抛
原因:在类加载器,加载该类时,首先执行的就是static{}块中的代码,
如果static{}块中的异常没有处理,异常就会导致该类加载失败,
也就是说“该类夭折,不存在”,显然与其相关的操作肯定就不能执行

当然了,如果你“不得不”向外抛可以这样写:(用InputStream举例,可根据你自己的代码修改一下)
static{
try {
InputStream inputStrea…
[/Quote]
学习了...
yooyoozoo 2009-06-12
  • 打赏
  • 举报
回复
[Quote=引用 8 楼 shenguangliang 的回复:]
静态代码块中的异常原则上必须处理,不应该也不能再往上抛
原因:在类加载器,加载该类时,首先执行的就是static{}块中的代码,
如果static{}块中的异常没有处理,异常就会导致该类加载失败,
也就是说“该类夭折,不存在”,显然与其相关的操作肯定就不能执行

当然了,如果你“不得不”向外抛可以这样写:(用InputStream举例,可根据你自己的代码修改一下)
static{
try {
InputStream inputStrea…
[/Quote]
牛X正解
daiafei 2009-06-12
  • 打赏
  • 举报
回复
有收获
Cheng_Tian 2009-06-12
  • 打赏
  • 举报
回复
[Quote=引用 8 楼 shenguangliang 的回复:]
静态代码块中的异常原则上必须处理,不应该也不能再往上抛
原因:在类加载器,加载该类时,首先执行的就是static{}块中的代码,
如果static{}块中的异常没有处理,异常就会导致该类加载失败,
也就是说“该类夭折,不存在”,显然与其相关的操作肯定就不能执行

当然了,如果你“不得不”向外抛可以这样写:(用InputStream举例,可根据你自己的代码修改一下)
static{
try {
InputStream inputStrea…
[/Quote]
向高手学习了
say___baby 2009-06-12
  • 打赏
  • 举报
回复
[Quote=引用 8 楼 shenguangliang 的回复:]
静态代码块中的异常原则上必须处理,不应该也不能再往上抛
原因:在类加载器,加载该类时,首先执行的就是static{}块中的代码,
如果static{}块中的异常没有处理,异常就会导致该类加载失败,
也就是说“该类夭折,不存在”,显然与其相关的操作肯定就不能执行

当然了,如果你“不得不”向外抛可以这样写:(用InputStream举例,可根据你自己的代码修改一下)
static{
try {
InputStream inputStream = new FileInputStream("")…
[/Quote]

同意
MagicError 2009-06-12
  • 打赏
  • 举报
回复
[Quote=引用 8 楼 shenguangliang 的回复:]
静态代码块中的异常原则上必须处理,不应该也不能再往上抛
原因:在类加载器,加载该类时,首先执行的就是static{}块中的代码,
如果static{}块中的异常没有处理,异常就会导致该类加载失败,
也就是说“该类夭折,不存在”,显然与其相关的操作肯定就不能执行

当然了,如果你“不得不”向外抛可以这样写:(用InputStream举例,可根据你自己的代码修改一下)
static{
try {
InputStream inputStrea…
[/Quote]

同意
长天一色 2009-06-10
  • 打赏
  • 举报
回复
Java 规定 静态块中不能抛出异常,如果内部语句出现异常,必须在静态块内处理
shenguangliang 2009-06-09
  • 打赏
  • 举报
回复 1
静态代码块中的异常原则上必须处理,不应该也不能再往上抛
原因:在类加载器,加载该类时,首先执行的就是static{}块中的代码,
如果static{}块中的异常没有处理,异常就会导致该类加载失败,
也就是说“该类夭折,不存在”,显然与其相关的操作肯定就不能执行

当然了,如果你“不得不”向外抛可以这样写:(用InputStream举例,可根据你自己的代码修改一下)
static{
try {
InputStream inputStream = new FileInputStream("") ;
} catch (FileNotFoundException e) {
// 抛出 运行式异常 (这样写,实质上也应该算是处理了异常)
throw new RuntimeException(e) ;
}
}


  • 打赏
  • 举报
回复
[Quote=引用 6 楼 WYhack 的回复:]
直接在main()后面throws Exception确实是简化了操作,但是这是一种不负责的表现,当系统出现异常时你就找不到具体的异常位置了,所以不建议这样用的!
[/Quote]
恩。
WYhack 2009-06-09
  • 打赏
  • 举报
回复
直接在main()后面throws Exception确实是简化了操作,但是这是一种不负责的表现,当系统出现异常时你就找不到具体的异常位置了,所以不建议这样用的!
WYhack 2009-06-09
  • 打赏
  • 举报
回复
啥不说,直接在main()后面throws Exception
lywlqx 2009-06-09
  • 打赏
  • 举报
回复
在方法后面throws Exception就行了
加载更多回复(3)

62,634

社区成员

发帖
与我相关
我的任务
社区描述
Java 2 Standard Edition
社区管理员
  • Java SE
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧