java多线程看这一篇就足够啦(多线程的基本概念及实现方式)
java多线程看这一篇就足够啦(多线程的基本概念及实现方式)§ 进程是程序的一部分,程序运行的时候会产生一个或多个进程。 进程与程序: 执行中的程序叫做进程(Process),是一个动态的概念。线程: 线程是独立调度和分派的基本单位,共享进程资源。每一个线程会有一个独立的栈.
一 基本概念
程序:
java源程序和字节码文件被称为“程序” (Program),是一个静态的概念。
进程:
执行中的程序叫做进程(Process),是一个动态的概念。
线程:
线程是独立调度和分派的基本单位,共享进程资源。每一个线程会有一个独立的栈.
进程与程序:
§ 进程是程序的一部分,程序运行的时候会产生一个或多个进程。
§ 多进程: 在操作系统中能同时运行多个任务(程序)
§ 多线程: 在同一应用程序中有多个顺序流同时执行
§ 线程是进程的一部分,所以线程有的时候被称为是轻权进程或者轻量级进程。
§ 一个没有线程的进程是可以被看作单线程的,如果一个进程内拥有多个进程,进程的执行过程不是一条线(线程)的,而是多条线(线程)共同完成的。
§ 系统在运行的时候会为每个进程分配不同的内存区域,但是不会为线程分配内存(线程所使用的资源是它所属的进程的资源),线程组只能共享资源。那就是说,除了CPU之外(线程在运行的时候要占用CPU资源),计算机内部的软硬件资源的分配与线程无关,线程只能共享它所属进程的资源。
进程与线程:
线程和进程最根本的区别在于:进程作为资源分配的单位,线程是调度和执行的单位
二 实现多线程的方法
第一种方法:
[java] view plain copy
- package com.gdzy.ThreadTest;
- /**
- * 多线程实现的第一种方式:
- * 新建一个类继承java.lang.Thread类 重写run方法. 此类代表一个新的线程
- */
- public class ThreadTest01 {
- public static void main(String[] args){
- MyThread01 t1 = new MyThread01();
- t1.start();
- for(int i=0; i<100; i ){ //建立一个for循环 表示main线程的进行
- System.out.println("main线程 " i);
- }
- }
- }
- class MyThread01 extends Thread{
- @Override
- public void run(){ //重写run方法
- for(int i=0; i<100; i ){ //建立一个for循环 表示MyThread01线程的进行
- System.out.println("MyThread01线程-----" i);
- }
- }
- }
第二种方法:
[java] view plain copy
- package com.gdzy.ThreadTest;
- /**
- * 多线程的第二种实现方式
- * 1.新定义一个类(新的线程) 实现Runnable接口 重写run方法.
- * 2.在主程序中实例化这个类.
- * 3.利用Thread有参构造构造函数 将Runnable一个实例传入 这个引用才可以使用start方法.
- *
- *
- */
- public class ThreadTest02 {
- public static void main(String[] args){
- MyThread02 t2 = new MyThread02();
- Thread tt = new Thread(t2);
- tt.start();
- for(int i=0; i<100; i ){
- System.out.println("main线程输出 " i);
- }
- }
- }
- class MyThread02 implements Runnable{
- public void run() {
- for(int i=0; i<100; i ){
- System.out.println("MyThread02线程输出----" i);
- }
- }
- }
推荐使用实现Runnable接口的方式 原因如下:
1.保留了类的继承权
2.适合多个相同的程序代码去处理同一个资源
3.增加程序的健壮性,代码可以被多个线程共享.代码和数据独立
如果对java微服务、分布式、高并发、高可用、大型互联网架构技术以及大数据等技术,可以关注私信我哈。