Perkins4j2的技术博客

一个人,一根烧火棍,面对整个世界.


  • 首页

  • 标签91

  • 分类8

  • 归档123

  • 搜索

Docker部署Hazelcast

发表于 2019-09-12 | 分类于 架构
本文字数: 4.8k | 阅读时长 ≈ 4 分钟

Hazelcast management-center

1
2
3
docker pull hazelcast/management-center

docker run -d -p 8200:8080 hazelcast/management-center:latest

安装配置管理节点,监控和实时查看缓存情况

阅读全文 »

Java并发编程艺术 - 多线程状态

发表于 2019-09-10 | 更新于 2019-09-11 | 分类于 并发编程
本文字数: 1.4k | 阅读时长 ≈ 1 分钟

6种状态

线程可以有如下6种状态:

  • New (新创建)
  • Runnable (可运行)
  • Blocked (被阻塞)
  • Waiting (等待)
  • Timed waiting (计时等待)
  • Terminated (被终止)

要确定一个线程的当前状态, 可调用 getState 方法。

新创建线程

当用new操作符创建一个新线程时,如newThread(r),该线程还没有开始运行。这意味着它的状态是new。

当一个线程处于新创建状态时,程序还没有开始运行线程中的代码。在线程运行之前还有一些基础工作要做。

可运行线程

一旦调用start方法, 线程处于runnable状态。一个可运行的线桿可能正在运行也可能没有运行, 这取决于操作系统给线程提供运行的时间。

一旦一个线程开始运行,它不必始终保持运行。事实上,运行中的线程被中断,目的是为了让其他线程获得运行机会。线程调度的细节依赖于操作系统提供的服务。

抢占式调度系统给每一个可运行线程一个时间片来执行任务。当时间片用完,操作系统剥夺该线程的运行权,并给另一个线程运行机会。当选择下一个线程时,操作系统考虑线程的优先级。

现在所有的桌面以及服务器操作系统都使用抢占式调度。但是,像手机这样的小型设备可能使用协作式调度。在这样的设备中,一个线程只有在调用yield方法、或者被阻塞或等待时,线程才失去控制权。
在具有多个处理器的机器上,每一个处理器运行一个线程, 可以有多个线程并行运行。 当然, 如果线程的数目多于处理器的数目, 调度器依然采用时间片机制。
记住, 在任何给定时刻, 二个可运行的线程可能正在运行也可能没有运行(这就是为什 么将这个状态称为可运行而不是运行 。)

被阻塞线程和等待线程

当线程处于被阻塞或等待状态时,它暂时不活动。它不运行任何代码且消耗最少的资源。直到线程调度器重新激活它。细节取决于它是怎样达到非活动状态的。

  • 当一个线程试图获取一个内部的对象锁而该锁被其他线程持有,则该线程进人阻塞状态。当所有其他线程释放该锁,并且线程调度器允许本线程持有它的时候,该线程将变成非阻塞状态。

  • 当线程等待另一个线程通知调度器一个条件时,它自己进入等待状态。在调用Object.wait方法或Thread.join方法,或者是等待Lock或Condition时,就会出现这种情况。实际上,被阻塞状态与等待状态是有很大不同的。

有几个方法有一个超时参数。 调用它们导致线程进人计时等待(timed waiting)状态。这一状态将一直保持到超时期满或者接收到适当的通知。带有超时参数的方法有 Thread.sleep 和Object.wait、Thread.join、Lock,tryLock 以及Condition.await 的计时版。

线程可以具有的状态以及从一个状态到另一个状态可能的转换。当一个线程被阻塞或等待时(或终止时,) 另一个线程被调度为运行状态。当一个线程被重新激活(例如,因为超时期满或成功地获得了一个锁),调度器检查它是否具有比当前运行线程更高的优先级。如果是这样,调度器从当前运行线程中挑选一个,剥夺其运行权,选择一个新的线程运行。

被终止的线程

线程因如下两个原因之一而被终止:

  • 因为run方法正常退出而自然死亡。
  • 因为一个没有捕获的异常终止了run方法而意外死亡。

Java并发编程艺术 - Join、Yield和Sleep

发表于 2019-09-09 | 更新于 2019-09-11 | 分类于 并发编程
本文字数: 2.2k | 阅读时长 ≈ 2 分钟

Join

join() 的作用:让“主线程”等待“子线程”结束之后才能继续运行。

son.join()被调用的地方是发生在“Father主线程”中,但是son.join()是通过“子线程son”去调用的join(),父线程调用wait()的作用是让“当前线程”等待,而这里的“当前线程”是指当前在CPU上运行的线程。所以,虽然是调用子线程的wait()方法,但是它是通过“主线程”去调用的;所以,休眠的是主线程,而不是“子线程”!

阅读全文 »

Java并发编程艺术 - 管道输入和输出流

发表于 2019-09-09 | 更新于 2019-09-11 | 分类于 并发编程
本文字数: 3.4k | 阅读时长 ≈ 3 分钟

Java管道

管道连接输入流和输出流。

管道I/O基于生产者 - 消费者模式,其中生产者产生数据,而消费者消费数据。在管道I/O中,创建两个流代表管道的两端。

PipedOutputStream对象表示流的一端,PipedInputStream对象则表示流的另一端。使用两个对象的connect()方法连接两端。

阅读全文 »

Java并发编程艺术 - 多线程wait和notify

发表于 2019-09-09 | 分类于 并发编程
本文字数: 3.4k | 阅读时长 ≈ 3 分钟

等待/通知机制

等待/通知机制,是指一个线程A调用了对象O的wait()方法进入等待状态,而另一个线程B调用了对象O的notify()或者notifyAll()方法,线程A收到通知后从对象O的wait()方法返回,进而
执行后续操作。

上述两个线程通过对象O来完成交互,而对象上的wait()和notify/notifyAll()的
关系就如同开关信号一样,用来完成等待方和通知方之间的交互工作。

阅读全文 »

Java并发编程艺术 - 线程终结

发表于 2019-09-05 | 分类于 并发编程
本文字数: 1.7k | 阅读时长 ≈ 2 分钟
  • 中断状态是线程的一个标识位,而中断操作是一种简便的线程间交互
    方式,而这种交互方式最适合用来取消或停止任务。
  • 除了中断以外,还可以利用一个boolean变量来控制是否需要停止任务并终止该线程。

    阅读全文 »

Java并发编程艺术 - 线程中断

发表于 2019-09-03 | 更新于 2019-09-11 | 分类于 并发编程
本文字数: 3.3k | 阅读时长 ≈ 3 分钟

中断可以理解为线程的一个标识位属性,它表示一个运行中的线程是否被其他线程进行了中断操作。中断好比其他线程对该线程打了个招呼,其他线程通过调用该线程的interrupt()
方法对其进行中断操作。

阅读全文 »

Java并发编程艺术 - 多线程构造和启动

发表于 2019-08-29 | 分类于 并发编程
本文字数: 2k | 阅读时长 ≈ 2 分钟

构造线程

在运行线程之前首先要构造一个线程对象,线程对象在构造的时候需要提供线程所需要的属性,如线程所属的线程组、线程优先级、是否是Daemon线程等信息。

线程启动

线程对象在初始化完成之后,调用start()方法就可以启动这个线程。

线程start()方法的含当前线程(即parent线程)同步告知Java虚拟机,只要线程规划器空闲,应立即启动调用()方法的线程。

注意 启动一个线程前,最好为这个线程设置线程名称,因为这样在使用jstack分析或者进行问题排查时,就会给开发人员提供一些提示,自定义的线程最好能够起个名字。

阅读全文 »

Maven自定义打包脚本

发表于 2019-08-23 | 更新于 2019-08-27 | 分类于 工具利器
本文字数: 3.7k | 阅读时长 ≈ 3 分钟

利用Maven脚本,实现以下需求:

  • 将第三方lib单独打包
  • 将脚本单独打包
  • 将执行jar单独打包
  • 将配置文件单独打包
  • 自动关闭和启动进程
阅读全文 »

Java Collection Sort之IllegalArgumentException

发表于 2019-08-22 | 分类于 Java
本文字数: 784 | 阅读时长 ≈ 1 分钟

java.lang.IllegalArgumentException: Comparison method violates its general contract!

在 JDK 7 版本以上, Comparator 要满足自反性,传递性,对称性,不然Arrays.sort、Collections.sort会报 IllegalArgumentException 异常。

阅读全文 »

1…789…13
Perkins

Perkins

123 日志
8 分类
91 标签
RSS
0%
© 2020 Perkins | 站点总字数: 335k | 站点阅读时长 ≈ 5:04
|