读书人

java.lang.String小结

发布时间: 2013-11-15 22:28:15 作者: rapoo

java.lang.String总结
// 在池中和堆中分别创建String对象"abc",s1指向堆中对象String s1 = new String("abc");// s2直接指向池中对象"abc"String s2 = "abc";// 在堆中新创建"abc"对象,s3指向该对象String s3 = new String("abc");// 在池中创建对象"ab" 和 "c",并且s4指向池中对象"abc"String s4 = "ab" + "c";// c指向池中对象"c"String c = "c";// 在堆中创建新的对象"abc",并且s5指向该对象String s5 = "ab" + c;String s6 = "ab".concat("c");String s7 = "ab".concat(c);System.out.println("------------实串-----------");System.out.println(s1 == s2); // falseSystem.out.println(s1 == s3); // falseSystem.out.println(s2 == s3); // falseSystem.out.println(s2 == s4); // trueSystem.out.println(s2 == s5); // falseSystem.out.println(s2 == s6); // falseSystem.out.println(s2 == s7); // falseSystem.out.println("-------------------------");String b1 = new String("");String b2 = "";String b3 = new String("");String b4 = "".intern();String b5 = "" + "";String b6 = "".concat("");String b7 = " ".trim();String b8 = " ";String b9 = " ".trim();System.out.println("------------空串-----------");System.out.println(b1 == b2); // falseSystem.out.println(b1 == b3); // falseSystem.out.println(b2 == b3); // falseSystem.out.println(b2 == b4); // trueSystem.out.println(b2 == b5); // trueSystem.out.println(b2 == b6); // trueSystem.out.println(b2 == b7); // falseSystem.out.println("-----a----");System.out.println(b2.equals(b7)); // true*System.out.println(b7 == b8); // falseSystem.out.println(b7 == b9); // falseSystem.out.println(b7.equals(b9)); // trueSystem.out.println(b9 == null);// false

?

四、字符串转码

1)转一个码,又用该码来构建一个字符串,是绝对不会出现乱码的,相当于没转。

2)转码与否,与字符串本身编码有关,字符串本身的编码与谁有关?文件编码,或者你的IDE设置的编码有关。文件已经是UTF-8了,你非要转为GBK,不乱才怪,呵呵

public class TestEncoding {public static void main(String[] args) throws UnsupportedEncodingException {System.out.println("转码前,输出Java系统属性如下:");System.out.println("user.country:" + System.getProperty("user.country"));System.out.println("user.language:"+ System.getProperty("user.language"));System.out.println("sun.jnu.encoding:"+ System.getProperty("sun.jnu.encoding"));System.out.println("file.encoding:"+ System.getProperty("file.encoding"));System.out.println("---------------");String s = "哈哈";String s1 = new String(s.getBytes(), "UTF-8");String s2 = new String(s.getBytes("UTF-8"), "UTF-8");String s3 = new String(s.getBytes("UTF-8"));String s4 = new String(s.getBytes("UTF-8"), "GBK");String s5 = new String(s.getBytes("GBK"));String s6 = new String(s.getBytes("GBK"), "GBK");System.out.println(s1);System.out.println(s2);System.out.println(s3);System.out.println(s4);System.out.println(s5);System.out.println(s6);}}

?

?五、案例

通过内存监控发现,GC的动作比较频繁,偶然发现了大量如下代码:log.debug(“userId=” + user.getUserId())

原因分析:

以上代码执行时,分两步:

1. 先执行的是括号中的字符串相”+”的动作,而每次”+”运算都会导致新字符串的生成,这样就产生了很多“中间字符串”,在极大次数被调用时,这种字符串被创建和销毁的数量非常庞大,从而造成了jvm gc频繁执行,进而影响了性能。

2. 再执行log.debug()函数,在生产环境log level一般大于info,所以实际不会打印debug信息 综上所述,这些代码在生产环境不会产生日志,但会执行字符串”+”运算,而这些运算是无意义的,所以需要先判断日志的优先级,方式是log.isXXXEnabled() { log.XXX(……); }

Log Level的级别: Fatal->error->warn->info->debug,级别从高到低

一般我们生成环境的log level都是error,所以对于Error以上级别的日志,不用判断;对于error以下级别的都要加上判断。

?

?

?

读书人网 >移动开发

热点推荐