浅谈JAVA的线程安全与性能之间的权衡

简介: 1、StringBuffer 与 StringBuilderStringBuffer自JDK1.0就有了,继承自AbstractStringBuilder类,是线程安全的类,推荐在多线程环境下使用;StringBuilder是JDK1.5才加的,多线程环境下不推荐使用,非线程安全的工具类,但是单线程环境下比StringBuffer性能提高很多;StringBuffer的线程安全是用synchronized实现的,隐式加锁。

1、StringBuffer 与 StringBuilder

StringBuffer自JDK1.0就有了,继承自AbstractStringBuilder类,是线程安全的类,推荐在多线程环境下使用;
StringBuilder是JDK1.5才加的,多线程环境下不推荐使用,非线程安全的工具类,但是单线程环境下比StringBuffer性能提高很多;StringBuffer的线程安全是用synchronized实现的,隐式加锁。

经过代码多次运行测试,单线程环境下StringBuilder的性能比StringBuffer略高:
测试代码:

        System.out.println("========StringBuilder======");
        long start2 = System.currentTimeMillis();
        for(int i=0;i<1000000;i++){
            StringBuilder sb = new StringBuilder();
            sb.append(3.1415926);
            sb.append("test welcome to java world");
            sb.append(true);
            sb.toString();
        }
        System.out.println(System.currentTimeMillis() - start2 + "mills");
        
        System.out.println("========StringBuffer======");
        long start = System.currentTimeMillis();
        for(int i=0;i<1000000;i++){
            StringBuffer sb = new StringBuffer();
            sb.append(3.1415926);
            sb.append("test welcome to java world");
            sb.append(true);
            sb.toString();
        }
        System.out.println(System.currentTimeMillis() - start + "mills");
测试结果:

========StringBuilder======
1861mills
========StringBuffer======
2042mills


2、Hashtable、ConcurrentHashMap 与 HashMap
Hashtable自JDK1.0就有了,是线程安全的散列容器,HashMap是JDK1.2才开始加的,多线程环境下不推荐使用,非线程安全的,
但是单线程环境下比Hashtable性能提高很多;ConcurrentHashMap是JDK1.5才开始加的,是线程安全的,多线程环境下推荐使用;
Hashtable的线程安全是用synchronized实现的,而ConcurrentHashMap是基于显示的lock;

synchronized的用法:


public synchronized V put(K key, V value) {

    // do something

}
lock的用法:
V put(K key, int hash, V value, boolean onlyIfAbsent) {
    lock();
    try {

        // do something

    } finally {
        unlock();
    }
}

3、总结:

个人理解,线程安全和高性能不可兼得,只有最合适的选择,没有最好的选择


目录
相关文章
|
3天前
|
存储 缓存 Java
java线程内存模型底层实现原理
java线程内存模型底层实现原理
java线程内存模型底层实现原理
|
8天前
|
缓存 Java 应用服务中间件
Java虚拟线程探究与性能解析
本文主要介绍了阿里云在Java-虚拟-线程任务中的新进展和技术细节。
|
5天前
|
Java 开发者
Java中的多线程基础与应用
【9月更文挑战第22天】在Java的世界中,多线程是一块基石,它支撑着现代并发编程的大厦。本文将深入浅出地介绍Java中多线程的基本概念、创建方法以及常见的应用场景,帮助读者理解并掌握这一核心技术。
|
1天前
|
Java 调度
Java-Thread多线程的使用
这篇文章介绍了Java中Thread类多线程的创建、使用、生命周期、状态以及线程同步和死锁的概念和处理方法。
Java-Thread多线程的使用
|
7天前
|
Java
领略Lock接口的风采,通过实战演练,让你迅速掌握这门高深武艺,成为Java多线程领域的武林盟主
领略Lock接口的风采,通过实战演练,让你迅速掌握这门高深武艺,成为Java多线程领域的武林盟主
21 7
|
6天前
|
Java 程序员
Java中的多线程基础与实践
【9月更文挑战第21天】本文旨在引导读者深入理解Java多线程的核心概念,通过生动的比喻和实例,揭示线程创建、同步机制以及常见并发工具类的使用。文章将带领读者从理论到实践,逐步掌握如何在Java中高效地运用多线程技术。
|
4天前
|
Java 调度 开发者
Java中的多线程编程:从基础到实践
本文旨在深入探讨Java多线程编程的核心概念和实际应用,通过浅显易懂的语言解释多线程的基本原理,并结合实例展示如何在Java中创建、控制和管理线程。我们将从简单的线程创建开始,逐步深入到线程同步、通信以及死锁问题的解决方案,最终通过具体的代码示例来加深理解。无论您是Java初学者还是希望提升多线程编程技能的开发者,本文都将为您提供有价值的见解和实用的技巧。
13 2
|
6天前
|
监控 算法 Java
深入理解Java中的垃圾回收机制在Java编程中,垃圾回收(Garbage Collection, GC)是一个核心概念,它自动管理内存,帮助开发者避免内存泄漏和溢出问题。本文将探讨Java中的垃圾回收机制,包括其基本原理、不同类型的垃圾收集器以及如何调优垃圾回收性能。通过深入浅出的方式,让读者对Java的垃圾回收有一个全面的认识。
本文详细介绍了Java中的垃圾回收机制,从基本原理到不同类型垃圾收集器的工作原理,再到实际调优策略。通过通俗易懂的语言和条理清晰的解释,帮助读者更好地理解和应用Java的垃圾回收技术,从而编写出更高效、稳定的Java应用程序。
|
6天前
|
Java 数据处理
Java中的多线程编程:从基础到实践
本文旨在深入探讨Java中的多线程编程,涵盖其基本概念、创建方法、同步机制及实际应用。通过对多线程基础知识的介绍和具体示例的演示,希望帮助读者更好地理解和应用Java多线程编程,提高程序的效率和性能。
18 1
|
9天前
|
安全 Java 调度
Java 并发编程中的线程安全和性能优化
本文将深入探讨Java并发编程中的关键概念,包括线程安全、同步机制以及性能优化。我们将从基础入手,逐步解析高级技术,并通过实例展示如何在实际开发中应用这些知识。阅读完本文后,读者将对如何在多线程环境中编写高效且安全的Java代码有一个全面的了解。