ice world
There is nothing too difficult if you put your heart into it.
posts - 104, comments - 103, trackbacks - 0, articles - 0
导航
BlogJava
首页
新随笔
联系
聚合
管理
<
2007年12月
>
日
一
二
三
四
五
六
25
26
27
28
29
30
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
1
2
3
4
5
常用链接
我的随笔
我的评论
我的参与
最新评论
留言簿
(8)
给我留言
查看公开留言
查看私人留言
随笔分类
ArcGIS(2)
CSS(4)
Database(14)
eclipse(10)
Hibernate(1)
Java(30)
Javascript(6)
Others(15)
Strut1(3)
Tomcat(7)
Weblogic(1)
Windows(13)
加解密(5)
随笔档案
2016年8月 (1)
2016年1月 (1)
2014年3月 (1)
2014年1月 (3)
2013年11月 (1)
2013年9月 (1)
2013年8月 (1)
2013年7月 (2)
2013年6月 (1)
2013年3月 (1)
2013年2月 (4)
2013年1月 (1)
2012年9月 (1)
2012年7月 (2)
2012年6月 (3)
2012年5月 (8)
2012年4月 (1)
2011年11月 (1)
2011年10月 (1)
2011年9月 (1)
2011年8月 (1)
2011年6月 (2)
2011年5月 (3)
2011年4月 (61)
2007年12月 (1)
搜索
最新评论
1. re: Failed to load JavaHL Library解决方法
啧啧,一语中的。
--Jerry Zhang
2. re: Error 1935的解决方法
我安装上面的方法成功了,各位同学们,千万别忘记修改注册表后重启电脑:)
--mentoruser
3. re: CXF+Spring+Tomcat简明示例
评论内容较长,点击标题查看
--无异
4. re: CXF+Spring+Tomcat简明示例
评论内容较长,点击标题查看
--chiangpan
5. re: Failed to load JavaHL Library解决方法[未登录]
顶顶顶
--小明
阅读排行榜
1. Failed to load JavaHL Library解决方法(78900)
2. CXF+Spring+Tomcat简明示例(51136)
3. java RSA加密解密(42669)
4. Java Tomcat SSL 服务端/客户端双向认证(一)(32892)
5. Java DES文件加密解密 javax.crypto.BadPaddingException: Given final block not properly padded(30882)
评论排行榜
1. CXF+Spring+Tomcat简明示例(27)
2. Java Tomcat SSL 服务端/客户端双向认证(一)(22)
3. Java数字证书对文件/加密/解密/签名/校验签名(8)
4. java RSA加密解密(7)
5. Failed to load JavaHL Library解决方法(6)
Java中局部内部类可以访问它所在方法中定义的final修饰的局部变量的合理解释
Posted on 2007-12-22 11:45
IceWee
阅读(2142)
评论(1)
编辑
收藏
所属分类:
Java
标题有点长,可能有点语病,先别管那么多!
首先看下面的这段代码:
public
class
LocalInnerClassTest
{
public
static
void
main(String[] args)
{
Outer obj
=
new
Outer();
//
生成一个外部类对象
SuperInner si
=
obj.outer();
//
调用外部类中的outer()方法,返回一个SuperInner类型对象赋值给si
si.m1();
//
调用被覆盖的方法m1(),输出:Inner's m1() 20
}
}
/**
*定义一个接口SuperInner,内部定义一个抽象方法m1(),无返回类型
*/
interface
SuperInner
{
public
void
m1();
}
/**
*定义一个类Outer,内部只定义一个方法outer(),返回类型为SuperInner
*/
class
Outer
{
public
SuperInner outer()
{
int
a
=
10
;
//
方法中定义一个局部变量a,并赋值为10
final
int
b
=
20
;
//
再定义一个final局部变量b,初始化为20
class
Inner
implements
SuperInner
{
//
在outer()方法中定义一个局部内部类Inner,实现接口SuperInner
public
void
m1()
{
//
类中只有一个覆盖接口SuperInner的方法m1()
System.out.println(
"
Inner's m1()
"
+
a);
//
编译报错
System.out.println(
"
Inner's m1()
"
+
b);
//
编译通过,输出:Inner's m1() 20
}
}
return
new
Inner();
}
}
我们先从主方法开始看代码的执行顺序,先生成一个Outer类对象obj,obj调用本类中方法outer();程序开始跳到outer()方法内执行程序语句,先后生成局部变量a和b,再定义一个局部内部类Inner,返回一个SuperInner类型的对象。将返回的SuperInner类型对象地址传给SuperInner类型对象si。si再调用m1()方法,因为已经在局部内部类中覆盖了接口中的m1()方法,所以将调用局部内部类中的m1()方法,程序跳到局部内部类中m1()方法内执行程序语句,先输出一段字符串和a,结果编译报错,先 将这条程序语句隐藏,执行下面的语句,你会发现编译通过而且输出Inner's m1() 20!
为什么会这样呢?大家都知道局部变量仅仅在一个范围内有效,在方法调用完就被内存释放,在Outer类对象obj调用outer()方法时,a和b才产生,调用结束后被内存释放,那么b这个值也就不复存在了,为什么还会输出20呢?难道局部变量被final修饰就不会被内存释放而保留?
其实有部分操作对于程序员是透明的,那是JAVA语言开发者的小把戏,在定义a和b 时JVM(JAVA虚拟机)做了程序员看不到的操作,他将b拷贝了一份给局部内部类,也就是说JVM在局部内部类中定义了一个final int b=20;这个操作程序员是不知道的!当调用m1()方法时输出的20并不是原来outer()方法中定义的b,而仅仅是JVM拷贝的一个副本。那么为什么a没被打印出呢?那是因为JVM并没有拷贝它,因为没有final修饰,说明它可以被修改,如果把a 改为 a++
,此时JVM就不知道拷贝a还是a++了,所以对于无final修饰的局部变量JVM是不会拷贝传给局部内部类的,自然无法打输出!
Feedback
#
re: Java中局部内部类可以访问它所在方法中定义的final修饰的局部变量的合理解释
回复
更多评论
2011-09-29 08:08 by
分公司
你说的拷贝我有点疑问,感觉这个是常量池的原因吧
新用户注册
刷新评论列表
只有注册用户
登录
后才能发表评论。
网站导航:
博客园
IT新闻
Chat2DB
C++博客
博问
管理
相关文章:
Java日常随意记
FTPClient上传文件蜗牛速度的解决方法
HttpClientUtils
Java获取本机IP列表
Exception loading sessions from persistent storage
Java Tomcat SSL 服务端/客户端双向认证のApache HttpClient(二)
Java Tomcat SSL 服务端/客户端双向认证(一)
Java MD5校验工具类
ExceptionUtil 获取异常堆栈内容
Java Zip Utils 压缩/解压缩工具包
Powered by:
BlogJava
Copyright © IceWee