多线程和多进程?
1、概念
早期的操作系统是单进程的,比如DOS,同一时刻只能做一个事情,IOS系统是单进程操作系统,苹果规定了只有音乐类和地图类等固定类型的APP拥有后台保留进程。
早期的操作系统是单进程的,比如DOS,同一时刻只能做一个事情,IOS系统是单进程操作系统,苹果规定了只有音乐类和地图类等固定类型的APP拥有后台保留进程。
多进程:
在操作系统中能(同时)运行多个任务(程序)
例如:Android是多进程系统,每启动一个软件就启动一个进程。
在操作系统中能(同时)运行多个任务(程序)
例如:Android是多进程系统,每启动一个软件就启动一个进程。
多线程:
在同一应用程序中有多个顺序流(同时)执行 例如:一边显示应用程序主界面,一边下载文件、播放音乐。
在同一应用程序中有多个顺序流(同时)执行 例如:一边显示应用程序主界面,一边下载文件、播放音乐。
总结进程和线程:看图
线程就是进程中一个程序执行的流程,一边执行一个流程,一边执行另一个流程。
线程就是进程中一个程序执行的流程,一边执行一个流程,一边执行另一个流程。
实现多线程的代码:
自定义线程类:
package com.ideal.demo;
public class IdealThread extends Thread {
public void run() {
for (int i = 0; i < 100; i++) {
System.out.println("☆☆ideal的线程☆☆"+i);
try {
sleep(1000); //线程休眠1000毫秒
} catch (InterruptedException e) {
e.printStackTrace();
}
}
}
}
测试类:
package com.ideal.demo;
public class Test {
public static void main(String[] args) {
//生成自定义线程类的对象
IdealThread it = new IdealThread();
//启动线程
it.start();
//it.run();//千万别这样写
for (int i = 0; i < 100; i++) {
System.out.println("★★程序主线程★★"+i);
}
}
}
线程休眠(暂停执行),以“减慢线程”。
当线程睡眠时,它睡在某个地方,在苏醒之前不会返回到可运行状态。
当睡眠时间到期,则返回到可运行状态。
线程睡眠的原因:线程执行太快,或者需要强制进入下一轮,因为Java规范不保证合理的轮换。
睡眠的实现:调用静态方法。
当线程睡眠时,它睡在某个地方,在苏醒之前不会返回到可运行状态。
当睡眠时间到期,则返回到可运行状态。
线程睡眠的原因:线程执行太快,或者需要强制进入下一轮,因为Java规范不保证合理的轮换。
睡眠的实现:调用静态方法。
try {
Thread.sleep(1000);
} catch (InterruptedException e) {
e.printStackTrace();
}
睡眠的位置:为了让其他线程有机会执行,可以将Thread.sleep()的调用放线程run()之内。这样才能保证该线程执行过程中会睡眠。
注意:
1、线程睡眠是帮助所有线程获得运行机会的最好方法。
2、线程睡眠到期自动苏醒,并返回到可运行状态,不是运行状态。sleep()中指定的时间是线程不会运行的最短时间。因此,sleep()方法不能保证该线程睡眠到期后就开始执行。
3、sleep()是静态方法,只能控制当前正在运行的线程。
1、线程睡眠是帮助所有线程获得运行机会的最好方法。
2、线程睡眠到期自动苏醒,并返回到可运行状态,不是运行状态。sleep()中指定的时间是线程不会运行的最短时间。因此,sleep()方法不能保证该线程睡眠到期后就开始执行。
3、sleep()是静态方法,只能控制当前正在运行的线程。
实例二:一个计数器,计数到100,在每个数字之间暂停1秒,每隔10个数字输出一个字符串
public class MyThread extends Thread {
public void run() {
for (int i = 0; i < 100; i++) {
if ((i) % 10 == 0) {
System.out.println("-------" + i);
}
System.out.print(i);
try {
Thread.sleep(1000);
System.out.print(" 线程睡眠1秒!\n");
} catch (InterruptedException e) {
e.printStackTrace();
}
}
}
public static void main(String[] args) {
new MyThread().start();
}
}