在Java的面试题中很有可能问到的问题是StringBuffer和StringBuilder、HashTable和HashMap、Vector和ArrayList的区别。的确,每对类提供的操作基本上一样的。但他们确实有区别。
StringBuffer
vs StringBuilder
StringBuffer 是在JDK1.0中提供的,而StringBuilder的出现是在JDK1.5版本上。在JDK 1.0的时代,那时候为了解决StringBuffer在多线程的混乱问题,StringBuffer大多数的方法都加上了synchronized方法。用天朝的话来说“稳定压倒一切”,只要不出乱子就行。所以没有考虑到效率问题。但后来渐渐发现StringBuffer大多数使用在了非多线程环境中。例如在一个函数中,使用StringBuffer作为临时变量,此时肯定不会存在多线程问题。这时候肯定不会出乱子,而多加的同步干什么?不是影响效率吗?
于是到了JDK 1.5,提供了StringBuilder类,与StringBuffer的主要不同,就是不再支持多线程安全。这样提供的两个类StringBuffer和StringBuilder,一个面向多线程环境,支持线程安全,一个面向单线程环境,效率更高。
所以StringBuffer和StringBuilder的区别在于是否支持线程同步。
HashTable vs HashMap 、 Vector vs
ArrayList
HashTable、Vector和StringBuffer一样都来自JDK 1.0。他们都是线程安全的。而HashMap、ArrayList出现在1.2版本上,他们是线程不安全的。这两种类本身没有什么好与不好。关键是在于使用的环境。但从JDK 1.5或者JDK 5之后,在JCF( Java
Collections Framework)中提供了线程安全的HashMap(ConcurrentHashMap)、ArrayList(CopyOnWriteArrayList)。那么既然有新的类了,也就不需要使用原来的HashTable、Vector了。
分享到:
相关推荐
在 Java 面试中,了解 String、 StringBuffer 和 StringBuilder 的区别是非常重要的。String 是不可变的,因为它在 JDK 中被声明为 final 类,而 StringBuffer 和 StringBuilder 是可变的,因为它们的字符内容可以...
涵盖 Java 集合框架、Hashtable 与 HashMap 的区别、ArrayList 和 LinkedList 的区别、Properties 类的特点、线程安全、Struts2 框架、反射机制、线程池、Tomcat 配置、Java 优化、Servlet 规范、StringBuffer 与 ...
- Vector和ArrayList都基于动态数组实现,适用于随机访问,但Vector线程安全,ArrayList则不是。 - LinkedList是链表结构,适合在任意位置插入和删除,但不适合频繁的随机访问。 三、HashTable、HashMap和TreeMap的...
Java面试中的核心知识点涵盖了许多方面,这里主要讨论的是面向对象的特性、字符串处理、数据类型转换、字符串缓冲类以及集合框架中的ArrayList、Vector和LinkedList,还有HashMap与HashTable的区别,以及final、...
* 可变性:StringBuffer 和 StringBuilder 可变,而 String 不可变。 * 线程安全性:String 不可变,因此是线程安全的;StringBuilder 不是线程安全的;StringBuffer 是线程安全的,内部使用 synchronized 进行同步...
- **ArrayList** 和 **Vector** 在线程安全方面不同,Vector默认同步,ArrayList默认不同步。在数据增长时,ArrayList增长率为50%,而Vector增长率为一倍。 - 对于ArrayList和Vector,检索和末尾操作效率相同,...
在Java编程语言中,String、StringBuffer和StringBuilder是常见的字符串处理类。String对象一旦创建就无法修改,因为它是final类,确保了不可变性,这对于多线程环境下的安全性有一定的帮助,但同时也意味着每次修改...
1. **String, StringBuffer, StringBuilder的区别** - **String** 是一个不可变类,意味着一旦创建,其内容就不能更改。这是由于String在Java中被声明为final,确保了它的不可变性。 - **StringBuffer** 和 **...
2. **Vector、ArrayList、LinkedList和Hashtable、HashMap的区别**: - **Vector与ArrayList**:两者都是List接口的实现,主要用于存储有序元素。ArrayList基于动态数组,性能较好,但在多线程环境中不是线程安全的...
- StringBuffer和StringBuilder是可变的,适合字符串拼接等动态构建字符串的操作,线程安全的是StringBuffer,非线程安全的是StringBuilder。 4. 运行时异常与一般异常: - 运行时异常是程序运行中常见的错误,如...
1. String、StringBuffer、StringBuilder的对比: - String是不可变的,每次操作都会创建新的对象,不推荐在频繁修改字符串的情况下使用。 - StringBuffer和StringBuilder都是可变的,它们在原对象上进行操作。...
(String和StringBuffer、StringBuilder的区别是什么?String为什么是不可变的?、什么是反射机制?反射机制的应用场景有哪些?......) (Arraylist 与 LinkedList 异同、ArrayList 与 Vector 区别、HashMap的底层...
(String和StringBuffer、StringBuilder的区别是什么?String为什么是不可变的?、什么是反射机制?反射机制的应用场景有哪些?......) (Arraylist 与 LinkedList 异同、ArrayList 与 Vector 区别、HashMap的底层...
4、 说出 ArrayList,Vector, LinkedList 的存储性能和特性 5、 Collection 和 Collections 的区别。 6、HashMap 和 Hashtable 的区别。 7、 线程的基本概念、线程的基本状态以及状态之间的关系 8、 abstract class...
StringBuilder 是非线程安全的,而 StringBuffer 在多线程环境中更安全,但在单线程环境下,StringBuilder 效率更高。 4. **异常处理** - Java 异常体系以 Throwable 类为根,分为 Error 和 Exception。Exception ...
* Vector 和 ArrayList 基本一样,区别是 Vector 使用了 synchronized 方法,可以说其实线程安全的 ArrayList,所以其特点和 ArrayList 相同,但是其效率和 ArrayList 相比较低。 * LinkedList 底层数据结构为带头...
- **HashTable**:同Vector,也具有线程安全的特性,但因为速度问题,通常使用 ConcurrentHashMap 替代。 3. **String、StringBuffer和StringBuilder**: - **String**:不可变对象,创建后不能修改,适合少量...
#### ArrayList vs LinkedList vs Vector - **ArrayList**: - 基于动态数组实现,查询速度快。 - 默认初始容量为10,当数组空间不足时会自动扩容。 - 非线程安全。 - **LinkedList**: - 基于双向链表实现,插入...
4. String、StringBuffer、StringBuilder 的区别:String 是不可变字符串,StringBuffer 和 StringBuilder 是可变字符串,StringBuffer 是线程安全的,而 StringBuilder 是非线程安全的。 5. 重载和重写的区别:重载...
5. **ArrayList vs Vector vs LinkedList**:`ArrayList`和`Vector`都是基于数组实现的列表,但`Vector`是线程安全的,而`ArrayList`不是。`LinkedList`基于链表实现,对于插入和删除操作更为高效,但随机访问速度较...