进程和线程概念 |
进程: 是并发执行的程序在执行过程中分配和管理资源的基本单位,是一个动态概念,竟争计算机系统资源的基本单位。每一个进程都有一个自己的地址空 间,即进程空间或(虚空间)。进程空间的大小 只与处理机的位数有关,一个 16 位长处理机的进程空间大小为 216 ,而 32 位处理机的进程空间大小为 232 。进程至少有 5 种基本状态,它们是:初始态,执行态,等待状态,就绪状态,终止状态。
线程: 线程,是进程的一部分,一个没有线程的进程可以被看作是单线程的。线程有时又被称为轻权进程或轻量级进程,也是 CPU 调度的一个基本单位。
从上面又引入了新的概念 并发和并行
What’s the
并发:在一个时间段内,处理两个及以上的任务
并行:同一时刻,同时处理两个及以上的任务
主线程 |
主线程: 执行主(main)方法的线程
单线程程序: java程序中只有一个线程执行从main方法开始,从上到下依次执行 jvm执行main()方法,Main方法会进入到栈内存,jvm会找操作系统开辟一条main方法通向cpu的执行路径,cpu就可以通过这个路径来执行main方法 ,而这个路径就有一个名字,叫main(主)线程
但是一般作为我们初学者写的程序都是单线程的,如果遇到这种情况程序就挂了
public class Demo01MainThread {
public static void main(String[] args) {
Person p1=new Person("小强");
p1.run();
System.out.println(0/0); //Exception in thread "main" java.lang.ArithmeticException: / by zero,执行到这里就挂了,
Person p2=new Person("旺财");
p2.run();
}
}
public class Person {
public String name;
public Person(String name){
this.name=name;
}
public void run(){
for (int i = 0; i <=20; i++) {
System.out.println(name+"->"+i);
}
}
}
怎么创建多线程呢? |
创建多线程程序的第一种方式:创建Thread类的子类
java.lang.Thread类:是描述线程的类,我们想要实现多线程程序,就必须继承Thread类
实现步骤:
1.创建一个Thread类的子类
2.在Thread类的子类中重写Thread类中的run方法,设置线程任务(开启线程要做什么?)
3.创建Thread类的子类对象
4.调用Thread类中的方法start方法,开启新的线程,执行run方法
void start() 使该线程开始执行:java虚拟机调用该线程的run方法。
结果是两个线程并发地运行;当前线程(从调用返回给 start 方法)和另一个线程(创建的新线程,执行其 run 方法)。
多次启动一个线程是非法的。特别是当线程已经结束执行后,不能再重新启动。
java程序属于抢占式调度,哪个线程的优先级高,哪个线程优先执行,同一个优先级,随即选择一个执行
//1.创建一个Thread类的子类
public class MyThread extends Thread {
//2.重写 run方法
@Override
public void run() {
for(int i=0;i<20;i++){
System.out.println("run:"+i);
}
}
}
public class Demo01Thread {
public static void main(String[] args) {
//3.创建Thread类的子类对象
MyThread mt=new MyThread();
mt.start();
for(int i=0;i<20;i++) {
System.out.println("main:" + i);
}
}
}
运行的结果是:
main:0
run:0
main:1
run:1
main:2
这体现了java程序的抢占式调度
多线程原理 |
内存中多线程是怎么表现出来的呢?
原来每开一个线程就会开辟一个新的栈空间来运行新线程里的代码,就是这样子的。
本人也只是初学者若有不妥,请各位大佬指出。