Java_String

本文详细解析了Java中String与StringBuffer的内存分配原理及区别,包括常量池的使用、对象创建方式对内存的影响等关键概念。同时,介绍了String与StringBuffer的特点,以及在不同场景下的应用。

package stringTest;

public class Test {
	public static void main(String[] args) {
		// String str = new String();
		String temp = "a";
		System.out.println(temp);
		temp = temp + "b";
		System.out.println(temp);
		StringBuffer strbus = new StringBuffer();
		strbus.append("a").append("b");
		System.out.println(strbus.length());
		strbus.append("c");
		System.out.println(strbus);
		String a = "ab";
		String c ="ab";
		System.err.println(a);
		String b = "a" + "b";
		
		String aa = new String("aa");
		String bb = new String ("aa");
		System.out.println((aa==bb));
		if (a == c) {
			System.out.println("aaaaa");
		}
		int inta =12345;
		String aaa = "aaa";
		aaa.intern();
		aaa="bbb";
	}

	public static void printStackTrace() {
		Throwable dummyException = new Throwable();
		StackTraceElement locations[] = dummyException.getStackTrace();
		for (int i = 0; i < locations.length; i++) {
			System.out.println("Stack trace [" + i + "] ......");
			StackTraceElement location = locations[i];

			// Caller will be the third element
			String cname = "unknown";
			String method = "unknown";
			String fname = "unknown";
			int lnum = -1;
			if (location != null) {
				StackTraceElement caller = location;
				cname = caller.getClassName();
				method = caller.getMethodName();
				fname = caller.getFileName();
				lnum = caller.getLineNumber();

				System.out.println("File : " + fname);
				System.out.println("Line : " + lnum);
				System.out.println("Caller : " + cname);
				System.out.println("Method : " + method);
			}

			System.out.println();
		}
	}

}

转至: http://sllereak.blog.163.com/blog

--String a="zhangsan";
String b="zhangsan";
内存分析:
第一句:String a="zhangsan"; -----"zhangsan"是常量,所以会在data segment中的字符串缓冲池中开辟内存空间并将其放入,放入后直接将这块内存的地址给a
第二句:String b="zhangsan";------"zhangsan"是常量,所以首先回去data segment中的字符串缓冲池中找这个字符串,由于找到了,直接将这块内存地址给b
于是a==b//true, a.equals(b)//true
--String a=new String("zhangsan");
String a=new String("zhangsan");
内存分析
第一句:String a=new String("zhangsan"); -----"zhangsan"是常量,所以会在data segment中的字符串缓冲池中开辟内存空间并将其放入,但是使用了new关键字,在堆中开辟空间并将将该data segment的值拷贝到该堆内存中,并返回引用地址给a
第二句:String b=new String("zhangsan"); -----"zhangsan"是常量,所以首先回去data segment中的字符串缓冲池中找这个字符串,由于找到了,而且使用了new关键字,在堆中开辟空间并将将该data segment的值拷贝到该堆内存中,并返回引用地址给b
于是a==b//false, a.equals(b)//true
--String a = "ja"+"va";--不会在堆中创建内存空间,强调"ja"+"va"在编译的后就成为"java"了,所以不会在data segment中创建"ja" 和 "va"
String b="java"
String c=a+"good";--创建堆上空间将a的值拷贝到其中,在创建"good"内存空间将"good"的值拷贝到其中,在堆上创建第三个内存空间合并a和"good"返回内存地址
内存分析:a和b指向相同的data segment区域,指针一样,都不会在堆上创建内存空间,但是这种直接指向data segment的类型如果需要运算的话会在堆上创建临时空间,但是指针不会改变


--String a="a,b,c,";a.split(",")和String a="a,b,c, ";a.split(",")的区别
*非常智能第一个返回三个元素的数组,第二个返回四个元素的数组

--String和StringBuffer的区别
*String代表的是不可变的字符序列
为不可变对象,一旦被创建,就不能修改它的值.
对于已经存在的String对象的修改都是重新创建一个新的对象,然后把新的值保存进去.
*StringBuffer代表的是可变的字符序列
是一个可变对象,当对他进行修改的时候不会像String那样重新建立对象
为什么能变呢?因为里面用char数组动态增加内存容量,所以可以用append方法动态改变字符串,且内存地址不变

String a="zhangsan";
s+="a";
可以分析出这种开销是非常大的

--File类,并不是代表一个实际存在的文件
*它只是在内存中保存该文件的文件名字而已,不是一个实际的文件奥
--public String final File.Separator静态属性存放间隔修饰符号。不区分任何的操作系统
*路径中/在使用的时候需要转义奥
--java中的枚举
记住固定用法就行了,我觉得一般也不需要过多的使用enum的一些高级特性,否则就和简单易懂的初衷想违背了。
public enum Color{
Red,
Blue
}
void main(String[] args){
Color color=Color.Red;
//枚举可以用在switch中
}




评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值