JUC并发编程(小细节)
多线程进阶=>JUC并发编程
自身基础:
-
Java
-
多线程的基础
1、什么是JUC
源码+官方文档 面试高频问

java.util工具包 包、分类
业务:普通的线程代码 Thread
Runnable没有返回值,效率相比于Callable相对较低!


2、线程与进程
线程、进程,如果不能使用一句话说出来的技术,不扎实!
进程:一个程序,QQ.exe Music.exe 程序的集合 ; .jar
一个进程往往可以包含多个线程,至少包含一个!
Java默认有几个线程?main、GC
线程:开了一个进程Typora,写字,自动保存(线程负责的)
对于Java而言:Thread、Runnable、Callable
public synchronized void start() {
/**
* This method is not invoked for the main method thread or "system"
* group threads created/set up by the VM. Any new functionality added
* to this method in the future may have to also be added to the VM.
*
* A zero status value corresponds to state "NEW".
*/
if (threadStatus != 0)
throw new IllegalThreadStateException();
/* Notify the group that this thread is about to be started
* so that it can be added to the group's list of threads
* and the group's unstarted count can be decremented. */
group.add(this);
boolean started = false;
try {
start0();
started = true;
} finally {
try {
if (!started) {
group.threadStartFailed(this);
}
} catch (Throwable ignore) {
/* do nothing. If start0 threw a Throwable then
it will be passed up the call stack */
}
}
}
//本地方法,底层的C++,Java无法直接操作硬件
private native void start0();
Java真的可以开启线程吗? 开不了
并发、并行
并发编程:并发、并行
并发(多线程操作同一个资源)
- CPU 一核,模拟出来多条线程,天下武功,唯快不破,快速交替
并行(多个人一起行走)
-
CPU 多核,多个线程可以同时执行;最高性能--->线程池
package com.chao.demo01; public class Test1 { public static void main(String[] args) { //获取cpu的核数 //CPU密集型,IO密集型 System.out.println(Runtime.getRuntime().availableProcessors()); } }
并发编程的本质:充分利用CPU的资源
所有的公司都很看重!
企业,挣钱=>提高效率,裁员,找一个厉害的人顶替三个不怎么样的人;
人员(减)、技术成本(高)
线程有几个状态
public enum State {
//新生
NEW,
//运行
RUNNABLE,
//阻塞
BLOCKED,
//等待,死死地等
WAITING,
//超时等待
TIMED_WAITING,
//终止
TERMINATED;
}
wait/sleep区别
1、来自不同的类
wait => Object
sleep => Thread
企业当中,休眠


2、关于锁的释放
wait会释放锁,sleep睡觉了,抱着锁睡觉,不会释放!
3、使用的范围是不同的
wait 必须在同步的代码块中
sleep 可以在任何地方睡
4、是否需要捕获异常
wait 不需要捕获异常
sleep 必须要捕获异常
浙公网安备 33010602011771号