(HashMap vs HashSet)
Here, we will see how Hashtable differs from HashMap in Java?
在这里,我们将看到Hashtable与Java中的HashMap有何不同?
(Hashtable class)
- Hashtable is a class which is available in java.util
Hashtable是一个可在java.util包中使用的类。 - In Hashtable, every method of the class is synchronized so that it provides Thread Safety.
在Hashtable中,该类的每个方法都是同步的,以便提供线程安全。 - Hashtable is Thread Safe (i.e. only one thread is allowed to operate on Hashtable object at a time).
Hashtable是线程安全的(即一次只允许一个线程在Hashtable对象上操作)。 - In Hashtable one thread operates on Hashtable object at a time so it takes more time to complete the task or in other words, we can say it increases the waiting time of the thread.
在Hashtable中,一个线程一次在Hashtable对象上操作,因此需要更多的时间来完成任务,换句话说,可以说它增加了线程的等待时间。 - In the case of Hashtable, performance is low just because of taking the more waiting time of the thread.
在Hashtable的情况下,性能低下只是因为花费了更多的线程等待时间。 - We can insert null for both keys and values.
我们可以为键和值插入null。 - Hashtable is a legacy class because this class is introduced in earlier version 1.0 of Java so this class is the need to re-engineered to support collection when collection framework came.
Hashtable是一个遗留类,因为该类是在Java的早期版本1.0中引入的,因此在收集框架到来时需要重新设计该类以支持收集。 - Hashtable does not provide uniqueness fully (i.e. duplicate are not allowed for keys and duplicates are allowed for values).
哈希表不能完全提供唯一性(即,键不允许重复,值不允许重复)。 - In Hashtable insertion, the order is not preserved (i.e. insertion and retrieval order is not needed to be same).
在哈希表插入中,不保留顺序(即,插入和检索顺序不需要相同)。
Example:
例:
import java.util.Hashtable;
class HashTableClass {
int hashcode;
// class constructor to instantiate hashcode
HashTableClass(int hashcode) {
this.hashcode = hashcode;
}
// override hashCode()
public int hashCode() {
return hashcode;
}
// override toString() for string conversion
public String toString() {
return hashcode + " ";
}
public static void main(String[] args) {
// Creating an instance
Hashtable ht = new Hashtable();
// By using put() to add few objects in Hashtable
ht.put(new HashTableClass(10), "Java");
ht.put(new HashTableClass(3), "C");
ht.put(new HashTableClass(4), "C++");
ht.put(new HashTableClass(3), "Ruby");
ht.put(new HashTableClass(5), "C");
ht.put(new HashTableClass(6), "null");
// Display Current Hashtable
System.out.println("Current Hashtable is :" + ht);
}
}
Output
输出量
E:\Programs>javac HashTableClass.java
E:\Programs>java HashTableClass
Current Hashtable is :{10 =Java, 6 =null, 5 =C, 4 =C++, 3 =Ruby, 3 =C}
Here, we will see how HashMap differs from Hashtable in Java?
HashMap与Java中的Hashtable有何不同?
(HashMap)
- HashMap is a class which is available in java.util
HashMap是一个可在java.util包中使用的类。 - In HashMap no method of the class is synchronized so that it does not provide Thread Safety.
在HashMap中,没有类的方法被同步,因此它不提供线程安全性。 - HashMap is not Thread Safe (i.e. multiple threads is allowed to operate on Hashtable object at a time).
HashMap不是线程安全的(即,一次允许多个线程对Hashtable对象进行操作)。 - In HashMap multiple threads operate on Hashtable object at a time so it takes less time to complete the task or in other words, we can say it decrease the waiting time of the thread.
在HashMap中,多个线程同时在Hashtable对象上运行,因此完成任务所需的时间更少,换句话说,我们可以说它减少了线程的等待时间。 - In the case of HashMap performance is high just because of taking the less waiting time of the thread.
在HashMap的情况下,性能高是因为花费了更少的线程等待时间。 - We can insert null for both keys(once) and values(multiple times).
我们可以为键(一次)和值(多次)插入null。 - HashMap is not a legacy class because this class is introduced in later version 1.2 of Java so this class does not need to re-engineered to support collection when collection framework came.
HashMap不是遗留类,因为该类是在Java的更高版本1.2中引入的,因此在收集框架到来时,无需重新设计该类来支持收集。 - HashMap does not provide uniqueness fully (i.e. duplicate are not allowed for keys and duplicates are allowed for values).
HashMap不能完全提供唯一性(即,键不允许重复,值不允许重复)。 - In HashMap insertion order is not preserved (i.e. insertion and retrieval order is not needed to be same).
在HashMap中,不保留插入顺序(即插入和检索顺序不需要相同)。
Example:
例:
// Java program to demonstrate the behavior of Map
import java.util.Collection;
import java.util.HashMap;
class HashMapClass {
public static void main(String[] args) {
// Creating an instance of HashMap
HashMap hm = new HashMap();
// By using put() method to add some values in HashMap
hm.put("Java", 1000);
hm.put("C", 2000);
hm.put("C++", 3000);
hm.put("Ruby", 4000);
hm.put("Python", 1000);
hm.put("null", null);
hm.put("Django", null);
// Here we will not get any error but one null is accepted for keys
hm.put("null", 7000);
// Display retrieval order of Map
System.out.println("Current HashMap list is :" + hm);
// by using values() to find values of HashMap
Collection values = hm.values();
// Display Values of HashMap
System.out.println("Current HashMap Key values is :" + values);
}
}
Output
输出量
E:\Programs>javac HashMapClass.java
E:\Programs>java HashMapClass
Current HashMap list is :{Ruby=4000, C=2000, Django=null,
Python=1000, C++=3000, null=7000, Java=1000}
Current HashMap Key values is :[4000, 2000, null, 1000, 3000, 7000, 1000]
翻译自: https://www.includehelp.com/java/differences-between-hashtable-and-hashmap-class-in-java.aspx