赞
踩
进程、线程:
进程就可以视为程序的一个实例。大部分程序可以同时运行多个实例进程(例如记事本、画图、浏览器等),也有的程序只能启动一个实例进程(例如网易云音乐、360 安全卫士等)
一、关于进程和线程,首先从定义上理解就有所不同
1、进程是什么?
是具有一定独立功能的程序、它是系统进行**资源(内存)分配和调度的最小单位**,重点在系统调度和单独的单位,也就是说进程是可以独 立运行的一段程序。
2、线程又是什么?
线程**进程的一个实体,是CPU调度和分派的基本单位**,他是比进程更小的能独立运行的基本单位,线程自己基本上不拥有系统资源。
二、他们之间的关系
1、一个线程只能属于一个进程,而一个进程可以有多个线程,但至少有一个线程(通常说的主线程)。
2、资源分配给进程,同一进程的**所有线程共享该进程的所有资源**。
3、线程在执行过程中,需要**协作同步(生产者消费者)**。不同进程的线程间要利用消息通信的办法实现同步。
4、CPU是分给线程,即真正在CPU上运行的是线程。
进程作为拥有资源的基本单位,线程是作为CPU调度和分配的基本单位。
进程是拥有资源的独立单位,线程是不拥有系统资源,但是可以访问隶属于进程的资源。
同步异步 asynchronize
并行与并发
单核 cpu 下,线程实际还是串行执行的。操作系统中有一个组件叫做任务调度器,将 cpu 的时间片(windows下时间片最小约为 15 毫秒,人能感知到的是0.1秒)分给不同的线程使用,只是由于 cpu 在线程间(时间片很短)的切换非常快,人类感觉是同时运行的 。总结为一句话就是: 微观串行,宏观并行 。
一般会将这种线程轮流使用 CPU 的做法称为并发, concurrent。多核 cpu下,每个核(core) 都可以调度运行线程,这时候线程可以是并行的。
大部分时候是既有并行又有并发,虽然有多个核,但是来的线程数多。
同步和异步
需要等待结果返回,才能继续运行就是同步
不需要等待结果返回,就能继续运行就是异步
Java里面创建线程有两种方式:
1、直接继承Thread
2、实现Runnable接口
两者最大区别就是,Java里面是单继承的,继承Thread类方式将单继承这个位置给占了,只能去实现接口,不能再去继承别的类了,而实现Runnable接口这种方式不影响继承类也不影响实现其他接口。
public class MyThread extends Thread{
@Override
public void run() {
for (int i = 0; i < 100; i++) {
System.out.println(i);
}
}
}
public static void main(String[] args) { MyThread myThread = new MyThread(); //这不是启动一个线程,这是调用对象里面一个普通方法run()方法 //myThread.run(); //真正启动一个线程调用start()方法,执行的代码就是run()方法里面代码 myThread.start(); } 实现Runnable接口方式: public class MyRunnable implements Runnable{ @Override public void run() { for (int i = 0; i < 100; i++) { System.out.println(i); } } } public static void main(String[] args) { MyRunnable myRunnable = new MyRunnable(); Thread thread = new Thread(myRunnable); thread.start(); }
synchronized:(同步 加锁)
Synchroni
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。