之前一直以为final修饰的变量不能改变,这个理解是有问题的。
首先final修饰的基本变量是不可变的,但是final修饰的对象要看以下情况:
先定义一个自定义对象
@Data
public class FinalUser {
private String name;
public FinalUser(String name) {
this.name = name;
}
}
然后在别的对象里引用一下,加上final修饰符
@Data
public class Mananger {
final FinalUser finaluser=new FinalUser("final User");
User user=new User("User");
}
测试类
public class Test {
public static void main(String[] args) {
Mananger manangerA = new Mananger();
Mananger manangerB = new Mananger();
FinalUser finaluserA = manangerA.getFinaluser();
FinalUser finaluserB = manangerB.getFinaluser();
System.out.println(finaluserA==finaluserB);
finaluserA=new FinalUser("");
}
}
结果输出false,并且A可以被赋值,那问题就是,加个final不是跟不加一样嘛有区别吗,看似是没区别的。
通过查资料发现get到的finalUser对象如果不加final的声明是可以引用的,加了final的声明是不可引用的,等于说,final就是个写代码时,也就是编译前用来限制的作用吗?
public class Test {
public static void main(String[] args) {
Mananger manangerA = new Mananger();
Mananger manangerB = new Mananger();
final FinalUser finaluserA = manangerA.getFinaluser();
final FinalUser finaluserB = manangerB.getFinaluser();
System.out.println(finaluserA==finaluserB);
finaluserA=new FinalUser(""); //报错
}
}
实际中常常见到这样的写法:
public class Test {
@Autowired
private Mananger mananger;
}
就是说,通常一些配置类,或者单例context的容器喜欢在自己的成员变量加上final
我可以理解成,如果是一些没必要注入容器的,比如Stringbuff,某些Integer等这样的对象,加上fianl的意义和自己的service服务里通过@Autowried引入其他单例服务类似,至少在自己class里面无法再改变值了,外界也没法拿到改值,就起到了“该声明地址唯一且无法被重新引用”的效果