Hazelcast management-center
1 | docker pull hazelcast/management-center |
安装配置管理节点,监控和实时查看缓存情况
一个人,一根烧火棍,面对整个世界.
1 | docker pull hazelcast/management-center |
安装配置管理节点,监控和实时查看缓存情况
线程可以有如下6种状态:
要确定一个线程的当前状态, 可调用 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 的计时版。
线程可以具有的状态以及从一个状态到另一个状态可能的转换。当一个线程被阻塞或等待时(或终止时,) 另一个线程被调度为运行状态。当一个线程被重新激活(例如,因为超时期满或成功地获得了一个锁),调度器检查它是否具有比当前运行线程更高的优先级。如果是这样,调度器从当前运行线程中挑选一个,剥夺其运行权,选择一个新的线程运行。
线程因如下两个原因之一而被终止:
join() 的作用:让“主线程”等待“子线程”结束之后才能继续运行。
son.join()被调用的地方是发生在“Father主线程”中,但是son.join()是通过“子线程son”去调用的join(),父线程调用wait()的作用是让“当前线程”等待,而这里的“当前线程”是指当前在CPU上运行的线程。所以,虽然是调用子线程的wait()方法,但是它是通过“主线程”去调用的;所以,休眠的是主线程,而不是“子线程”!
管道连接输入流和输出流。
管道I/O基于生产者 - 消费者模式,其中生产者产生数据,而消费者消费数据。在管道I/O中,创建两个流代表管道的两端。
PipedOutputStream对象表示流的一端,PipedInputStream对象则表示流的另一端。使用两个对象的connect()方法连接两端。
等待/通知机制,是指一个线程A调用了对象O的wait()方法进入等待状态,而另一个线程B调用了对象O的notify()或者notifyAll()方法,线程A收到通知后从对象O的wait()方法返回,进而
执行后续操作。
上述两个线程通过对象O来完成交互,而对象上的wait()和notify/notifyAll()的
关系就如同开关信号一样,用来完成等待方和通知方之间的交互工作。
除了中断以外,还可以利用一个boolean变量来控制是否需要停止任务并终止该线程。
中断可以理解为线程的一个标识位属性,它表示一个运行中的线程是否被其他线程进行了中断操作。中断好比其他线程对该线程打了个招呼,其他线程通过调用该线程的interrupt()
方法对其进行中断操作。
在运行线程之前首先要构造一个线程对象,线程对象在构造的时候需要提供线程所需要的属性,如线程所属的线程组、线程优先级、是否是Daemon线程等信息。
线程对象在初始化完成之后,调用start()方法就可以启动这个线程。
线程start()方法的含当前线程(即parent线程)同步告知Java虚拟机,只要线程规划器空闲,应立即启动调用()方法的线程。
注意 启动一个线程前,最好为这个线程设置线程名称,因为这样在使用jstack分析或者进行问题排查时,就会给开发人员提供一些提示,自定义的线程最好能够起个名字。
在 JDK 7 版本以上, Comparator 要满足自反性,传递性,对称性,不然Arrays.sort、Collections.sort会报 IllegalArgumentException 异常。