朋友说这是一道价值5000¥的面试题...

本文探讨了Java中final变量与字符串拼接的原理。通过一道面试题,展示了final修饰的字符串在编译时如何优化以及非final字符串的拼接方式。讲解了直接相加与间接相加字符串在效率上的差异,并分析了字节码文件以解释结果。

前几天去朋友那,他给了我做了一道他们公司价值5000¥的面试题…

		String a = "hello2";
        final String b = "hello";
        String d = "hello";
        String c = b + 2;
        String e = d + 2;
        System.out.println((a == c));
        System.out.println((a == e));

结果:true 和 false

不知道你是否做对了,下面是讲解time…

我们可以看看反编译后的字节码文件

在这里插入图片描述

咦,为啥c变成 hello2 呢?

对于final修饰的变量,它在编译时被解析为常量值的一个本地拷贝存储到自己的常量池中或嵌入到它的字节码流中。

“+”连接符对于直接相加的字符串常量效率很高,因为在编译期间便确定了它的值.

因为 b 是final修饰的变量 所以它不会变 ,它会直接进行拼接,放入字符串常量池中

那么 String e = d + 2 又是为啥呢?

因为 程序不知道 你的 d 会不会变化,所以他不会直接拼接,他会将引用直接放入字符串常量池

对于间接相加(即包含字符串引用,且编译期无法确定值的),形如s1+s2+s3; 效率要比直接相加低,因为在编译器不会对引用变量进行优化

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值