![](https://img-blog.csdnimg.cn/20201014180756724.png?x-oss-process=image/resize,m_fixed,h_64,w_64)
多线程
liyingying111111
这个作者很懒,什么都没留下…
展开
-
java并发基础多线程学习(1)-线程创建两种方式
一:创建线程的两种方式: (1) Thread thread1 = new Thread(){ public void run(){ try { Thread.sleep(1000); } catch (InterruptedException e) { ...原创 2019-03-28 10:38:51 · 125 阅读 · 0 评论 -
java并发基础多线程学习(2)-并发互斥技术synchronized
synchronized关键字一般称为互斥锁。在多线程并发执行情况下。如果没有加互斥锁就回出现各种问题。如下面的问题: 现在有两个字符串 duoxiancheng 和 esondf15.那么我想让两个线程交替去打印字符串打印的时候一个字符一个字符的打印,那么看会有什么问题? 1:定义打印字符串的方法: publid void print(String str){ for(i...原创 2019-03-28 11:29:54 · 479 阅读 · 0 评论 -
java并发基础多线程学习(3)-线程同步通信技术
线程同步通信技术:多线程之间要实现数据同步。通过通信实现同步。那么怎么实现呢? 看一个问题: 有两个线程,子线程先执行10次,然后主线程执行5次,然后再切换到子线程执行10,再主线程执行5次……如此往返执行50次。 分析: (1)两个线程 主线程和子线程 子线程执行一个任务10次。主线程执行一个任务5次。然后交替执行50次 (2)两个任务,这个时候可以创建一个类封装这两个任务。 (...原创 2019-03-28 11:44:12 · 145 阅读 · 0 评论 -
java并发基础多线程学习(4)-线程范围内共享数据
假设一个场景:现在有一个公共变量火车票数量。多个线程同时执行操作然后去获取最后的火车票数量。那么肯定会出现数据混乱的问题: package com.nuanshui.frms.native1.thread; import java.util.Random; import java.util.concurrent.ConcurrentHashMap; /** * @author liyy ...原创 2019-03-28 14:44:32 · 212 阅读 · 0 评论 -
java并发基础多线程学习(5)-多线程间共享变量
package com.nuanshui.frms.native1.thread; /** * @author liyy * @description:多线程通信 * @date 2019-03-27 19:58 * @program frms-parent */ public class MultiThreadShareData { public static void ...原创 2019-03-28 15:13:45 · 359 阅读 · 0 评论 -
java并发基础多线程学习(6)-线程池的使用
场景如下:100张票。多个线程同时执行任务去卖。买完就退出。用到的技术: 线程池技术: 1:Executors线程池工具类可以通过该工具类创建固定线程数量的线程池也可以构建缓存线程池。这里构建固定数量 的线程池。 2:CallAble接口。类似Runnable接口。可以通过该接口创建任务丢给Executors创建的线程去执行任务。该接口有两个地方 是Runnable接口不具备的。(1):...原创 2019-03-28 16:00:31 · 304 阅读 · 0 评论 -
Condition的基本使用
Condition的基本使用可以来代替传统并发锁synchornized wait notify关键字。传统代码改造如下: 任务封装类: package com.nuanshui.frms.native1.thread; import java.util.concurrent.locks.Condition; import java.util.concurrent.locks.Loc...原创 2019-03-28 16:23:17 · 289 阅读 · 0 评论