近来在学习Java多线程这一知识点,在分析线程安全集合时,提到了弱一致性的CopyOnWriteList集合。书上分析源码时候说这是借鉴了copy on wirte这一思想设计的相对线程安全的List。但是对于copy on wirte这一知识点却没有详细的介绍。这篇博客就copy on write ...
分类:
其他好文 时间:
2020-06-10 13:20:36
阅读次数:
63
Executors 工具类的不同方法按照我们的需求创建了不同的线程池,来满足业务 的需求。 Executor 接口对象能执行我们的线程任务。 ExecutorService 接口继承了 Executor 接口并进行了扩展,提供了更多的方法我 们能获得任务执行的状态并且可以获取任务的返回值。 使用 T ...
分类:
编程语言 时间:
2020-06-08 00:55:23
阅读次数:
119
Java 多线程基础(二)多线程的实现方式 在Java中,java使用Thread类代表线程,所有的线程对象都必须是Thread或者其子类的实例,每个线程的作用是完成一定任务,实际上是就是执行一段程序流(一段顺序执行的代码)。实现多线程一共有4种方式,分别是继承于Thread 类、实现 Runnab ...
分类:
编程语言 时间:
2020-06-06 21:50:59
阅读次数:
71
一 . 为什么要用分布式锁 我们在开发应用的时候,如果需要对某一个共享变量进行多线程同步访问的时候,可以使用我们学到的Java多线程的18般武艺进行处理,并且可以完美的运行,毫无Bug! 注意这是单机应用,也就是所有的请求都会分配到当前服务器的JVM内部,然后映射为操作系统的线程进行处理!而这个共享 ...
分类:
其他好文 时间:
2020-06-06 16:51:03
阅读次数:
59
使用Runnable接口 首先我们要知道使用Thread创建的子类可以添加新的成员变量,以及添加方法,使用线程中的功能,但是Java不允许将子类再往后继承,也就是不能再扩展后代. Runnable接口与目标对象 那么这时候就出现了使用Runnable接口如果用Thread类直接创建对象通常使用以下的 ...
分类:
编程语言 时间:
2020-06-05 23:04:49
阅读次数:
78
什么是上下文: cpu会为每个线程分配一个时间片,这个时间片是非常短的,毫秒级别的,cup不断的切换线程执行任务时,会记录这个任务的状态,下次切换回来时,可以通过这个状态继续执行任务,让我们感觉有多个程序在运行 比如 我们在看java核心思想看到100页,然后想到80页有相关的内容,返回80查看完后 ...
分类:
编程语言 时间:
2020-06-01 23:59:42
阅读次数:
101
Java多线程基础:Synchronized关键字 对象的内存布局 下面的讨论都是针对HotSpot虚拟机。 首先我们来了解一下对象的内存布局,对象在内存中存储的布局整体可以分为3块区域: ...
分类:
编程语言 时间:
2020-06-01 11:57:31
阅读次数:
57
##线程状态 NEW:刚创建未启动的线程 RUNNABLE:正在执行状态 BLOCKED:处于阻塞状态的线程 WAITING:正在等待另一个线程执行特定动作的线程 TIMED_WAITING:等待另一个线程执行时间到达指定时间 TERMINATED:线程退出执行 public class TestS ...
分类:
编程语言 时间:
2020-05-31 19:40:59
阅读次数:
63
一、无等待,直接出票【虽然解决了不会冲票问题,但显然不符合实际生活】: package com.thread.sale; public class Sale { public static void main(String[] args) {//悟,那么设计爬虫的时候,下载的资源唯一,使用多线程下载 ...
分类:
编程语言 时间:
2020-05-30 21:38:10
阅读次数:
111
多线程 一、什么是多线程? 进程:正在执行的程序。 线程:可以理解成进程中独立运行的子任务,一个进程至少有一个线程。 多线程:一个进程中有多个线程。 二、为什么要使用多线程? 为了更好地利用CPU资源。 进程之间不能共享数据,线程可以。 系统创建进程需要为该进程重新分配系统资源,创建线程代价比较小。 ...
分类:
编程语言 时间:
2020-05-30 20:00:12
阅读次数:
59