String
concat() 方法用于将指定的字符串参数连接到字符串上。
.length() 它返回字符串对象包含的字符数。
trim()方法用于删除字符串的头尾空白符。 >.substring(beginIndex, endIndex)
从beginIndex开始取,到endIndex结束,从0开始数,其中不包括endIndex位置的字符
String字符串常量池
JVM为了提高性能和减少内存开销,内部维护了一个字符串常量池,每当创建字符串常量时,JVM首先检查字符串常量池,如果常量池中已经存在,则返回池中的字符串对象引用,否则创建该字符串对象并放入池中。
String a = "abc";
String b = "abc";
System.out.print(a == b); //true
但与创建字符串常量方式不同的是,当使用new String(String str)方式等创建字符串对象时,不管字符串常量池中是否有与此相同内容的字符串,都会在堆内存中创建新的字符串对象。
String a = "Hello";
String b = new String("Hello");
System.out.println(a == b); //false
System.out.println(a.equals(b)); //true
即使字符串内容相同,字符串常量池中的字符串与通过new String(..)等方式创建的字符串对象之间没有直接的关系,但是,可以通过字符串的intern()方法找到此种关联。intern()方法返回字符串对象在字符串常量池中的对象引用,若字符串常量池中尚未有此字符串,则创建一新的字符串常量放置于池中。
int i =1;
int j =1;
//==一般对原生类型比较
boolean result1 =i ==j;
System.out.println(result1);//true
String str1 = "123";
String str2 = "123";
boolean result2= str3==str4;
System.out.println(result2);//true
/*intern()方法返回字符串对象在字符串常量池中的对象引用*/
String str5 = str1.intern();
String str6 = str2.intern();
boolean result3 = str5 == str6;
System.out.println("intern" + ":" + result3);//true
String str3=new String("123");
String str4 = new String("123");
boolean result4 = str1.equals(str3);
//因为String类重写了equals方法 只要两个对象内容相同 则为true
System.out.println("result4" + ":" + result4);//true
简单的说,==比较两个人是否究竟是真正同一个人,equals一般用来比较两个人在逻辑上是否相等(比如规定两人成年之后身高相同就算两人相同等等),想怎么定义就怎么定义,如果不覆盖equals方法的话,默认仍然是比较两人是否同一个人(废话,两个人都还处于胚胎状态,都没有具体特征,怎么可能在逻辑上比较)。
String StringBuffer StringBuilder 区别
String str = "wang";
str.concat("shuailing");
System.out.println(str);//wang
str = str.concat("shuailing");
System.out.print(str);//wangshuailing
StringBuffer sb = new StringBuffer();
sb.append("wang");
sb.append("shuailing");
System.out.println(sb);//wangshuailing
String 是被 final 修饰的,他的长度是不可变的,就算调用 String 的concat
方法,那也是把字符串拼接起来并重新创建一个对象,把拼接后的 String 的值赋给新创建的对象
StringBuffer和StringBuilder都是可变的,当进行字符串拼接时采用append方法,在原来的基础上进行追加,所以性能比String要高
又因为StringBuffer是线程安全的而StringBuilder是线程非安全的,所以StringBuilder的效率高于StringBuffer。
3、对于大数据量的字符串的拼接,采用StringBuffer,StringBuilder。
注意String +
1 .String中使用 + 字符串连接符进行字符串连接时,连接操作最开始时如果都是字符串常量,编译后将尽可能多的直接将字符串常量连接起来,形成新的字符串常量参与后续连接(通过反编译工具jd-gui也可以方便的直接看出);
2.接下来的字符串连接是从左向右依次进行,对于不同的字符串,首先以最左边的字符串为参数创建StringBuilder对象,然后依次对右边进行append操作,最后将StringBuilder对象通过toString()方法转换成String对象(注意:中间的多个字符串常量不会自动拼接)。
String c = "xx" + "yy " + a + "zz" + "mm" + b; //实质上的实现过程是:
String c = new StringBuilder("xxyy").append(a).append("zz").append("mm").append(b).toString();
由此得出结论:当使用+进行多个字符串连接时,实际上是产生了一个StringBuilder对象和一个String对象。
Math
//生成两个30以内随机数
Random rand = new Random();
System.out.println((int)(Math.random()*30));
System.out.println(rand.nextInt(30));
floor 返回不大于的最大整数 round 则是4舍5入的计算,入的时候是到大于它的整数
round方法,它表示“四舍五入”,算法为Math.floor(x+0.5),即将原来的数字加上0.5后再向下取整,所以,Math.round(11.5)的结果为12,Math.round(-11.5)的结果为-11。
Math.floor(1.5)结果为1