并行,相当于并联
并发,宏观上,实则分先后,相当于串联
进程与线程的区别 与联系
因为一个进程中的多个线程是并发运行的,那么从微观角度看也是有先后顺序的,哪个线程执行完全取决于 CPU 的调度,程序员是干涉不了的。而这也就造成的多线程的随机性。
多线程,特点,随机性,单核cpu并发一会执行这个线程,一会执行另外一个线程,造成代码随机性的现象,可做多个事情!!!
创建新执行线程有两种方法。一种方法是将类声明为 Thread 的子类。该子类应重写 Thread 类的 run 方法。接下来可以分配并启动该子类的实例。如:
class PrimeThread extends Thread {
public void run() {
. . .
}
}
PrimeThread p = new PrimeThread(143);
p.start();
另一种方法是声明实现 Runnable 接口的类。该类然后实现 run 方法。然后可以分配该类的实例,在创建 Thread 时作为一个参数来传递并启动。如:、
class PrimeRun implements Runnable {
public void run() {
. . .
}
}
PrimeRun p = new PrimeRun(143);
new Thread(p).start();
start()开启新一个的栈内存(可以把main()当做旧的栈内存),实则执行的是run()。但若是直接调用run()则没有开启新栈内存,还在main()的栈内存中,不是多线程。
实现Runnable接口比继承Thread类所具有的优势:
-
适合多个相同的程序代码的线程去共享同一个资源。成员变量
-
可以避免java中的单继承的局限性。
-
增加程序的健壮性,实现解耦(耦合:类与类之间关系)操作,代码可以被多个线程共享,代码和线程独立。
多线程
原文:https://www.cnblogs.com/21556guo/p/13382073.html