final修饰符

final

       用于声明属性不可变、方法不可重载、类不可被继承。
       主要谈一谈属性不可变:被final修饰的变量不可变,不可变具有两重含义:一是引用不可变;二是对象不可变。引用不可变的意思是指当final修饰的是对象的引用时,该引用指向的内存地址不可变;对象不可变是指当final修饰的是具体的值(如final int a = 5)时,该值不可变。
       下面放几个测试代码。

1	public static void main(String[] args){
2		final StringBuffer s = new StringBuffer("Hello");
3		System.out.println(s.hashcode());
4		s.append(" world");
5		System.out.println(s);
6		System.out.println(s.hashcode());
7	}

       这段代码的运行结果为:

       可以看到两次hashcode() s指向的地址没有发生变化,但是s指向的内存地址中的内容发生了改变。
       我们可以接着看一下append的代码。

1	public AbstractStringBuilder append(String str) {
2       	if (str == null)
3            		return appendNull();
4        	int len = str.length();
5        	ensureCapacityInternal(count + len);
6       	str.getChars(0, len, value, count);
7        	count += len;
8        	return this;
9    	}

       可以看到,StringBuffer的append方法是调用的AbstractStringBuilder的append方法,该方法最终返回的this,虽然StringBuffer的内容发生了改变,然而其地址仍然是原来的区域。
代码1

1	public static void main(String[] args){
2     		final StringBuffer s = new StringBuffer("Hello");
3  		s = new StringBuffer("Hello wolrd"); //编译错误
4	}

代码2

1	public static void main(String[] args){
2   		final String s = new String("Hello");
3  		s = s + " world"; //编译错误
4	}

       上面两段代码都是编译出错。对于代码1第3行,s指向了新一块的内存地址(“Hello world”的地址)。由于s指向的地址不能发生改变,于是编译出错。
       对于代码2第3行, 这行代码实际上是创建了另外一个对象(“Hello world”),并将其引用赋给了s,所以s指向的内存地址发生了改变。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值