String,HashMap,HashTable的深层分析


import java.util.HashMap;
import java.util.Hashtable;

public class Main {
// 1. 继承Map
private HashMap<String,String> hashmap = new HashMap<String,String>();
// 1.继承Dictionary
private Hashtable<String,String> hashtable = new Hashtable<String,String>();

public static void main(String[] s) {
Main main = new Main();

main.HashMapTest();

main.HashTableTest();

// String因为复写了equals方法,所以该方法是比较里面的内容.java的所有对象都有hashcode和equals方法.如果要复写equals,必须复写hashcode
main.StringTest();
}

private void HashMapTest(){
hashmap.put("0", "0");
// 2.可以放null值,一般会有特定的位置存储,比如0位置
hashmap.put(null, "null");
System.out.println(hashmap.get(null));

// 3.所谓的不是线程安全的,是因为hashmap的put和get方法实现如下:
// public V put(K paramK, V paramV)
// public V get(Object paramObject)
}

private void HashTableTest(){
hashtable.put("0", "0");
// 2. 不可以放null值
// hashtable.put(null, "null");
// System.out.println(hashtable.get(null));

// 3.所谓的线程安全的,是因为Hashtable的put和get方法实现如下:
// public synchronized V put(K paramK, V paramV)
// public synchronized V get(Object paramObject)
}

private void StringTest(){
// 由于String是final类,因此你不可以继承这个类、不能修改这个类。
// 会在内存中创建对象,可以通过intern放入String的string池中
String str1 = new String("exam");
String str2 = new String("exam");
// 首先会去string池中判断是否有该对象,有的话就直接返回已有对象的地址,否则会在内存中创建对象,并且放入String的string池中
String str3 = "exam";
// 所以它不会创建内存空间
String str4 = "exam";
// false
System.out.println(str1==str2);
// true
System.out.println(str1.equals(str2));

// false
System.out.println(str1 == str3);
// true
System.out.println(str1.equals(str3));

// true
System.out.println(str4 == str3);
// true
System.out.println(str4.equals(str3));


str1 = str1.intern();
// true
System.out.println(str1 == str3);
// true
System.out.println(str1.equals(str3));
}
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值