线程和进程区别
一个进程可以包含多个线程,线程不能独立存在,依赖与进程
进程:是指一个内存中运行的应用程序,每个进程都有一个独立的内存空间,一个应用程序可以同时运行多个进程;进程也是程序的一次执行过程,
是系统运行程序的基本单位;系统运行一个程序即是一个进程从创 建、运行到消亡的过程。
线程:进程内部的一个独立执行单元;一个进程可以同时并发的运行多个线程,
可以理解为一个进程便相当 于一个单 CPU 操作系统,而线程便是这个系统中运行的多个任务。
多线程
在同一个进程中可以同时拥有多个线程执行不同的任务
多线程的目的:当某一线程的运行不需要用到CPU的资源,
比如只和IO等资源打交道时,让需要使用CPU资源的其他线程获取资源,提高效率,节省时间。
线程的执行是由随机性的。
多线程的目的:更大限度地利用CPU资源。
多线程使用场景:
1.后台任务,比如游戏服务器
2.定时向大量用户(100w)用户发邮件3.异步处理:发微博/记录日志等
4.分布式计算...
线程的生命周期
并发与并行
1.并行:指两个或多个事件在同一刻发生(同时发生)。
1.并发:指两个或多个事件在同一个时间段发生。
线程的创建
1.自定义类继承Thread(线程类),重写run方法,无返回值
run()方法内部,写入逻辑代码
通过初始化这个对象调用.start()方法来开启线程
例:
public class ThreadDemo1 extends Thread{
@Override
public void run() {
System.out.println("继承Thread类的多线程");
}
public static void main(String[] args) {
Thread thread = new ThreadDemo1();
thread.start();//开启线程
}
}
运行结果:继承Thread类的多线程
2.自定义类实现Runnable接口类,重写run方法,无返回值
run()方法内部,写入逻辑代码
实现接口后要初始化这个类并且要初始化Thread类去调用stare方法
例:
public class ThreadDemo2 implements Runnable{
@Override
public void run() {
System.out.println("实现Runnable的多线程");
}
public static void main(String[] args) {
ThreadDemo2 td2 = new ThreadDemo2();
Thread t1 = new Thread(td2);
t1.start();
}
}
运行结果:实现Runnable的多线程。
以上两中写法相对简单
两种方法的合成写法:
public class ThreadDemo3 {
public static void main(String[] args) {
new Thread(new Runnable() {
@Override
public void run() {
System.out.println("两种方法的合成写法");
}
}).start();
}
}
运行结果 :两种方法的合成写法。
3.自定义类,实现Callable接口,重写call(),并且有返回值