博客
关于我
用new创建对象和用字符串常量创建对象的区别
阅读量:355 次
发布时间:2019-03-04

本文共 1535 字,大约阅读时间需要 5 分钟。

1、Demo1:

public class StringDemo2 {    public static void main(String[] args) {        String s1 = new String("hello");        String s2 = "hello";        System.out.println(s1 == s2);// false        System.out.println(s1.equals(s2));// true    }}**运行结果:**false true

内存分配图如下:

详解:

(1)、首先,通过main()方法进栈。

(2)、然后再栈中定义一个对象s1,s1由new创建,因此去堆中开辟一个内存空间,将内存空间的引用赋值给s1,“hello”是常量,然后去字符串常量池查看是否有hello字符串对象,没有的话分配一个空间存放hello,并且将其空间地址存入堆中new出来的空间中。
(3)、在栈中定义一个对象s2,s2不是由new创建,因此去字符串常量池中查看是否有”hello”字符串对象,有则直接把“hello”的地址赋值给s2。
(4)、即s1中存的是堆中分配的空间,堆中分配的空间中存的是字符串常量池中分配空间存放”hello”的空间的地址值。而s2中之中存的是字符串常量池中分配空间存放”hello”的空间的地址值。
(5)、由于s1与s2中存放的地址不同,所以输出false。因为,类String重写了equals()方法,它比较的是引用类型的 的值是否相等,所以输出true。即结果为false、true。

2、Deme2.

public class StringDemo4 {    public static void main(String[] args) {        String s1 = "hello";        String s2 = "world";        String s3 = "helloworld";        System.out.println(s3 == s1 + s2);// false        System.out.println(s3.equals((s1 + s2)));// true        System.out.println(s3 == "hello" + "world");//true        System.out.println(s3.equals("hello" + "world"));// true    }}**运行结果:**falsetruetruetrue
详解:

(1)、s1与s2相加是先在字符串常量池中开一个空间,然后拼接,这个空间的地址就是s1与s2拼接后的地址。与s3的地址不同,所以输出为false。

(2)、s3与”hello”+”world”作比较,”hello”+”world”先拼接成”helloworld”,然后再去字符串常量池中找是否有”helloworld”,常量池存在,所以和s3共用一个字符串对象,则为true。

总结:

(1)、String s = new String(“hello”)会创建2(1)个对象,String s = “hello”创建1(0)个对象。 
注:当字符串常量池中有对象hello时括号内成立!

(2)、字符串如果是变量相加,先开空间,在拼接。

(3)、字符串如果是常量相加,是先加,然后在常量池找,如果有就直接返回,否则,就创建。

(4)、对象用new创建时才在堆中分配空间,否则只在栈和常量池中分配空间。

你可能感兴趣的文章
Mysql 数据库重置ID排序
查看>>
Mysql 数据类型一日期
查看>>
MySQL 数据类型和属性
查看>>
mysql 敲错命令 想取消怎么办?
查看>>
Mysql 整形列的字节与存储范围
查看>>
mysql 断电数据损坏,无法启动
查看>>
MySQL 日期时间类型的选择
查看>>
Mysql 时间操作(当天,昨天,7天,30天,半年,全年,季度)
查看>>
MySQL 是如何加锁的?
查看>>
MySQL 是怎样运行的 - InnoDB数据页结构
查看>>
mysql 更新子表_mysql 在update中实现子查询的方式
查看>>
MySQL 有什么优点?
查看>>
mysql 权限整理记录
查看>>
mysql 权限登录问题:ERROR 1045 (28000): Access denied for user ‘root‘@‘localhost‘ (using password: YES)
查看>>
MYSQL 查看最大连接数和修改最大连接数
查看>>
MySQL 查看有哪些表
查看>>
mysql 查看锁_阿里/美团/字节面试官必问的Mysql锁机制,你真的明白吗
查看>>
MySql 查询以逗号分隔的字符串的方法(正则)
查看>>
MySQL 查询优化:提速查询效率的13大秘籍(避免使用SELECT 、分页查询的优化、合理使用连接、子查询的优化)(上)
查看>>
mysql 查询数据库所有表的字段信息
查看>>