Java多线程进一步理解之----------线程共享数据

简介: 说起线程共享数据有几种方式,1.使用公共集合类来实现,代码很简单就不多解释:public class TestThreadShareData { private static int data = 0;...

说起线程共享数据有几种方式,

1.使用公共集合类来实现,代码很简单就不多解释:

public class TestThreadShareData {
    private static int data = 0;
    private static Map<Thread,Integer> map = new HashMap<Thread,Integer>();
    public static void main(String[] args) {
        for (int i = 0; i < 2; i++) {
            new Thread(new Runnable() {
                @Override
                public void run() {
                    data = new Random().nextInt();
                    map.put(Thread.currentThread(), data);
                    System.out.println("main" + Thread.currentThread().getName() + "data=" + data);
                    new A().get();
                    new B().get();
                }
            }).start();
        }
    }
    static class A {
        public void get() {
            data = map.get(Thread.currentThread());
            System.out.println("A from main"+Thread.currentThread().getName() + "data = "+data);
        }
    }
    static class B {
        public void get() {
            data = map.get(Thread.currentThread());
            System.out.println("B from main"+Thread.currentThread().getName() + "data = "+data);
        }
    }
}

2.使用互斥的访问机制

public class doThreadShareData {
    //java.util.concurrent
    public static void main(String[] args) {
        ShareData shareData =new ShareData();
        new Thread(new Runnable() {
            @Override
            public void run() {
                shareData.deccreament();
            }
        }).start();
        new Thread(new Runnable() {
            @Override
            public void run() {
                shareData.increment();
            }
        }).start();
    }

}
class ShareData {
    private int j = 0;
    public synchronized void increment(){
        j++;
    }
    public synchronized void deccreament(){
        j--;
    }
}

 

相关文章
|
1天前
|
数据采集 前端开发 Java
基于Java爬取微博数据(一)
【5月更文挑战第9天】讲述如何通过 Java 爬取微博数据,以及相应的注意点
|
1天前
|
Python
|
1天前
|
存储 安全 Java
Java多线程基础知识总结,36岁老码农现身说法
Java多线程基础知识总结,36岁老码农现身说法
|
1天前
|
消息中间件 关系型数据库 网络安全
实时计算 Flink版操作报错合集之Flink sql-client 针对kafka的protobuf格式数据建表,报错:java.lang.ClassNotFoundException 如何解决
实时计算Flink版作为一种强大的流处理和批处理统一的计算框架,广泛应用于各种需要实时数据处理和分析的场景。实时计算Flink版通常结合SQL接口、DataStream API、以及与上下游数据源和存储系统的丰富连接器,提供了一套全面的解决方案,以应对各种实时计算需求。其低延迟、高吞吐、容错性强的特点,使其成为众多企业和组织实时数据处理首选的技术平台。以下是实时计算Flink版的一些典型使用合集。
10 1
|
1天前
|
Java 测试技术
Java多线程的一些基本例子
【5月更文挑战第17天】Java多线程允许并发执行任务。示例1展示创建并启动两个`MyThread`对象,各自独立打印&quot;Hello World&quot;。示例2的`CounterExample`中,两个线程(IncrementThread和DecrementThread)同步地增加和减少共享计数器,确保最终计数为零。这些例子展示了Java线程的基本用法,包括线程同步,还有如Executor框架和线程池等更复杂的用例。
9 0
|
2天前
|
Java
阅读《代码整洁之道》总结(1),java多线程面试
阅读《代码整洁之道》总结(1),java多线程面试
|
2天前
|
缓存 安全 Java
7张图带你轻松理解Java 线程安全,java缓存机制面试
7张图带你轻松理解Java 线程安全,java缓存机制面试
|
3天前
|
Java 数据库
【Java多线程】对线程池的理解并模拟实现线程池
【Java多线程】对线程池的理解并模拟实现线程池
16 1
|
2天前
|
监控 Java 测试技术
在多线程开发中,线程死循环可能导致系统资源耗尽,影响应用性能和稳定性
【5月更文挑战第16天】在多线程开发中,线程死循环可能导致系统资源耗尽,影响应用性能和稳定性。为解决这一问题,建议通过日志记录、线程监控工具和堆栈跟踪来定位死循环;处理时,及时终止线程、清理资源并添加错误处理机制;编码阶段要避免无限循环,正确使用同步互斥,进行代码审查和测试,以降低风险。
17 3
|
3天前
|
设计模式 消息中间件 安全
【Java多线程】关于多线程的一些案例 —— 单例模式中的饿汉模式和懒汉模式以及阻塞队列
【Java多线程】关于多线程的一些案例 —— 单例模式中的饿汉模式和懒汉模式以及阻塞队列
11 0