/**
* String字符串:
* 由多个字符组成的一串数据
* 字符的本质是一个字符数组
*
* 两种创建方式的存放地不同
* (方法区的)常量池:String s = "123"; 直接赋值
* 堆:String s = new String("123"); 通过构造方法(先在堆里new String,然后指向常量池里的字符串地址)
* ==:
* 基本数据类型:比较的是基本数据类型的 值 是否相同
* 引用数据类型:比较的是引用数据类型的 地址 是否相同
*
* String(char[] value)
分配一个新的 String,使其表示字符数组参数中当前包含的字符序列
String(String original)
初始化一个新创建的 String 对象,使其表示一个与参数相同的字符序列;
换句话说,新创建的字符串是该参数字符串的副本。
*
*
* String 的判断:
* boolean equals(Object obj);比较字符串内容是否相当
* boolean equalsIgnoreCase(String anotherString) 比较字符串内容是否相等,忽略大小写
* boolean startsWith(String starts) 测试此字符串是否以指定的starts开始
* boolean endsWith(String suffix) 测试此字符串是否以指定的后缀结束。
*
*
* String 是一个特殊的引用数据类型,可以直接输出字符对象中的数据,String的长度不会变
* String s="1"; s+="2";是不会报错的。
* ->常量区新建"1",s指向"1"
* ->常量区新建"2"和"12"
* ->s中断指向"1",指向"12"
* 结论:长度不变指的是“值”的长度不变,当有新的赋值的时候,是在常量区建立新值并
* 指向新值,而旧值则是原值不变并且不被 引用 。(也就会浪费空间)
*/
/*
* String定义
*/
// String s = "asd";
// String s1 = new String("asd");//也可以new String(chs)
// String s3 = "asd";
// char[] chs = {‘a‘,‘b‘,‘c‘,‘d‘,‘e‘,‘f‘};
//String(char[] value,int offset,int count)
// String s2 = new String(chs,1,3);
/*
* 对比:(引用地址)
* String了"asd"的值(不管是构造方法还是直接赋值)以后,首先是在方法区的
* 常量池里新建了"asd"这个字符串。
* 如果是构造方法,那么是栈里的s1指向堆里的new String,堆里指向常量池
* 如果是直接赋值,会先寻找常量池里有没有"asd",有就指向常量池
* ->常量池创建"asd"后,s指向"asd"
* ->s1指向堆里的new String,new String指向"asd"
* ->s3搜索常量池里有没有"asd",有,指向"asd"
*
* 如果不加括号,"s==s3"+s以后,再与s3作对比,便是false了
*/
// System.out.println("s==s1:"+(s==s1));//s==s1:false
// System.out.println("s==s3:"+s==s3);//false
// System.out.println("s==s3:"+(s==s3));//s==s3:true
/**
* StringBuilder:是一个可变的字符串。字符串缓冲区 类。(也就是需要先实例化)
* String和StringBulider的区别:
* String是固定的,StringBuilder是可变的。
*/
/*
* StringBuilder
*/
// StringBuilder sss = new StringBuilder("hehe ");
// System.out.println(sss.capacity());//返回sss的容量
// System.out.println(sss.length());//返回sss的实际大小
// System.out.println(sss.append(s));//在sss后加上字符串
// //链式编程
// sss.append("a").append("b").append("c");
// //逆序
// sss.reverse();
/* * object和equals */ // Student stu = new Student(); // System.out.println(stu.toString());//com.inclass.study.Student@1db9742 // System.out.println(stu);//com.inclass.study.Student@1db9742 //说明我们输出一个对象就是默认输出这个对象的toString /* Object类中的源码 * public String toString() { return getClass().getName() + "@" + Integer.toHexString(hashCode()); } //getclass作用是获取包名 */ // Student stu2 = new Student(); // System.out.println(stu2); // System.out.println(stu.equals(stu2)); /* 这个时候是false * public boolean equals(Object obj) { return (this == obj); } 在Student类中重写(直接用Source里的get hashcode and equals就可以)equals后 @Override public boolean equals(Object obj) { if (this == obj) return true; if (obj == null) return false; if (getClass() != obj.getClass()) return false; Student other = (Student) obj; if (age != other.age) return false; if (name == null) { if (other.name != null) return false; } else if (!name.equals(other.name)) return false; return true; } 便会return true */
是
原文:https://www.cnblogs.com/bkytep/p/9614337.html