多线程的进一步理解---------线程的同步之synchronized

简介: 线程同步的方式有很多种,synchronized 这个只是其中的一种方式,把这个关键字加在方法修饰或者具体的代码块上,就实现了相应的同步,但是我们有一个问题就是哪些需要同步呐,举个例子:成员变量这个是公有的,必须要同步,不然多个线程同时操作必然会导致出现错误的情况,具体的同步应加在具体的调用方法上,方法中的局部变量时不需要同步的,凡是公有的部分都需要同步。

线程同步的方式有很多种,

synchronized 这个只是其中的一种方式,把这个关键字加在方法修饰或者具体的代码块上,就实现了相应的同步,但是我们有一个问题就是

哪些需要同步呐,举个例子:成员变量这个是公有的,必须要同步,不然多个线程同时操作必然会导致出现错误的情况,具体的同步应加在具体的调用方法上,方法中的局部变量时不需要同步的,凡是公有的部分都需要同步。

public class TestThreadSynchronized {
    public static void main(String[] args) {
        new TestThreadSynchronized().init();
    }

    public void init(){
        final  Output output = new Output();
        Thread thread = new Thread(new Runnable() {
            @Override
            public void run() {
                while (true) {
                    try {
                        Thread.sleep(10);
                    } catch (InterruptedException e) {
                        e.printStackTrace();
                    }
                    output.output("zhangxiaoxiang");
                }
            }
        });
        thread.start();

        Thread thread1 = new Thread(new Runnable() {
            @Override
            public void run() {
                while (true) {
                    try {
                        Thread.sleep(10);
                    } catch (InterruptedException e) {
                        e.printStackTrace();
                    }
                    output.output("jiangming");
                }
            }
        });
        thread1.start();
    }

    class Output{
        public synchronized void output(String name){
            int len = name.length();
            //synchronized (this) {
                for (int i = 0; i < len; i++) {
                    System.out.print(name.charAt(i));
                }
            //}
            System.out.println();
        }
    }
}
相关文章
|
3天前
|
NoSQL Java Redis
Reactor实战,创建一个简单的单线程Reactor(理解了就相当于理解了多线程的Reactor)
本文通过一个简单的单线程Reactor模式的Java代码示例,展示了如何使用NIO创建一个服务端,处理客户端的连接和数据读写,帮助理解Reactor模式的核心原理。
10 0
Reactor实战,创建一个简单的单线程Reactor(理解了就相当于理解了多线程的Reactor)
|
3天前
|
Java 编译器 程序员
【多线程】synchronized原理
【多线程】synchronized原理
15 0
|
3天前
|
设计模式 Java 物联网
【多线程-从零开始-玖】内核态,用户态,线程池的参数、使用方法详解
【多线程-从零开始-玖】内核态,用户态,线程池的参数、使用方法详解
12 0
|
3天前
|
安全 Java 程序员
【多线程-从零开始-肆】线程安全、加锁和死锁
【多线程-从零开始-肆】线程安全、加锁和死锁
13 0
|
3天前
|
Java 程序员 编译器
【多线程-从零开始-叁】线程的核心操作
【多线程-从零开始-叁】线程的核心操作
12 0
|
3天前
|
Java 调度
【多线程-从零开始-贰】线程的构造方法和常见属性
【多线程-从零开始-贰】线程的构造方法和常见属性
13 0
|
2月前
|
存储 监控 Java
Java多线程优化:提高线程池性能的技巧与实践
Java多线程优化:提高线程池性能的技巧与实践
72 1
|
14天前
|
数据采集 负载均衡 安全
LeetCode刷题 多线程编程九则 | 1188. 设计有限阻塞队列 1242. 多线程网页爬虫 1279. 红绿灯路口
本文提供了多个多线程编程问题的解决方案,包括设计有限阻塞队列、多线程网页爬虫、红绿灯路口等,每个问题都给出了至少一种实现方法,涵盖了互斥锁、条件变量、信号量等线程同步机制的使用。
LeetCode刷题 多线程编程九则 | 1188. 设计有限阻塞队列 1242. 多线程网页爬虫 1279. 红绿灯路口
|
22天前
|
Java Spring
spring多线程实现+合理设置最大线程数和核心线程数
本文介绍了手动设置线程池时的最大线程数和核心线程数配置方法,建议根据CPU核数及程序类型(CPU密集型或IO密集型)来合理设定。对于IO密集型,核心线程数设为CPU核数的两倍;CPU密集型则设为CPU核数加一。此外,还讨论了`maxPoolSize`、`keepAliveTime`、`allowCoreThreadTimeout`和`queueCapacity`等参数的设置策略,以确保线程池高效稳定运行。
88 10
spring多线程实现+合理设置最大线程数和核心线程数
|
1月前
|
Java 数据库 Android开发
一个Android App最少有几个线程?实现多线程的方式有哪些?
本文介绍了Android多线程编程的重要性及其实现方法,涵盖了基本概念、常见线程类型(如主线程、工作线程)以及多种多线程实现方式(如`Thread`、`HandlerThread`、`Executors`、Kotlin协程等)。通过合理的多线程管理,可大幅提升应用性能和用户体验。
56 15
一个Android App最少有几个线程?实现多线程的方式有哪些?

相关实验场景

更多