【Java基础】简说多线程(上)

简介: 【Java基础】简说多线程(上)

进程是一个静态的概念,线程是一个进程里面不同的执行路径。一个CPU只能支持一个线程,真正的多线程是2个CPU以上。

基本概念

举例说明

进程,打开任务管理器,下图的一个个程序就是进程

进程再进一步,比如360卫士,一边杀毒一边体检就是两个线程

概念

  1. 线程是一个程序内部的顺序控制流
  2. Java的线程是通过java.lang.Thread类来实现的。
  3. VM启动时会有一个由主方法(public void main(){})所定义的线程
  4. 可以通过创建Thread的实例来创建新的线程
  5. 每个线程都是通过某个特定的Thread对象所对应的方法run()来完成其操作的,方法run()称为线程体。
  6. 通过调用Thread类的start()方法来启动一个线程

线程和进程的区别

  • 每个进程都有独立的代码和数据空间(进程上下文),进程间的切换会有较大的开销
  • 线程可以看成时轻量级的进程,同一类线程共享代码和数据空间,每个线程都有独立的运行栈和程序计数器
  • 多进程:在操作系统中能同时运行多个任务(程序)
  • 多线程:在同一应用程序中有多个顺序流同时执行
线程的创建和启动

创建线程有两种方式

第一种:
  • 定义线程类Runnable接口
  • Thread myThread=new Thead(target) // target为Runnable接口类型
  • Runnable中只有一个方法
  • publicvoid run ();用以定义线程运行体
  • 使用Runnable接口可以为多个线程提供共享数据
  • 在实现Runnable接口的类的run方法定义中可以使用Thread

case:

public class TestThread{
  public static void main(String[] args){
    Runner r=new Runner();
    r.run();
    Thread t=new Thread(r);
    
    t.start();
    
    for(int i=0;i<100;i++){
      System.out.println("Main Thread:------"+i);
    }
  }
}

class Runner implements Runnable{
  public void run(){
    for(int i=0;i<100;i++){
      System.out.println("Runner:"+i);
    }
  }
}
第二种:
  • 可以定义一个Thread的子类并重写其run方法如:
class MyThread extends Thead{
  public void run(){}
}
  • 然后生成该类的对象:
MyThread myThread =new MyThead();

case

public class TestThread{
  public static void main(String[] args){
    Runner r=new Runner();
    r.start();
    //Thread t=new Thread(r);
    
    //t.start();
    
    for(int i=0;i<100;i++){
      System.out.println("Main Thread:------"+i);
    }
  }
}

//class Runner implements Runnable{
class Runner extends Thread{
  public void run(){
    for(int i=0;i<100;i++){
      System.out.println("Runner:"+i);
    }
  }
}

实现Runnable接口避免多继承局限,接口可调用,体现了共享的概念

还有两种操作多线程的方式

第三种 callable接口
public class Callable{
  public static void main(String[] args) throws ExecutionException,InterruptedException{
  FutureTask<Integer> futureTask=new FutureTask(new Mythread());
  new Thread(futureTask,"A").start();

  Integer result=futureTask.get();
  System.out.pritln(result);
}
}
第四种 操纵线程池

通过Executor 的工具类可以创建三种类型的普通线程池:

  • FixThreadPool(int n); 固定大小的线程池
  • SingleThreadPoolExecutor :单线程池
  • CashedThreadPool(); 缓存线程池
 public class CeShiDemo {
    private static ExecutorService executor = Executors.newFixedThreadPool(15);
    public static void main(String[] args) {
        for (int i = 0; i < 10; i++) {
            executor.execute(new SubThread());
        }
    }
}

实现Runnable接口


class MyThread implements Runnable {
    @Override
    public void run() {
        try {
            Thread.sleep(10000);
        } catch (InterruptedException e) {
            //do nothing
        }
    }
}

参考博客:https://blog.csdn.net/qsbbl/article/details/86622144

目录
相关文章
|
3天前
|
缓存 NoSQL Java
Java高并发实战:利用线程池和Redis实现高效数据入库
Java高并发实战:利用线程池和Redis实现高效数据入库
17 0
|
1天前
|
Java 调度
【Java基础】 线程状态转化
Java线程状态转化
13 2
|
3天前
|
监控 Java API
Java 程序设计 第八章 线程
Java 程序设计 第八章 线程
|
3天前
|
存储 安全 Java
Java多线程编程--JUC
Java多线程编程
|
4天前
|
Java API
详细探究Java多线程的线程状态变化
Java多线程的线程状态主要有六种:新建(NEW)、可运行(RUNNABLE)、阻塞(BLOCKED)、等待(WAITING)、超时等待(TIMED_WAITING)和终止(TERMINATED)。线程创建后处于NEW状态,调用start()后进入RUNNABLE状态,表示准备好运行。当线程获得CPU资源,开始执行run()方法时,它处于运行状态。线程可以因等待锁或调用sleep()等方法进入BLOCKED或等待状态。线程完成任务或发生异常后,会进入TERMINATED状态。
|
4天前
|
存储 安全 Java
Java多线程中线程安全问题
Java多线程中的线程安全问题主要涉及多线程环境下对共享资源的访问可能导致的数据损坏或不一致。线程安全的核心在于确保在多线程调度顺序不确定的情况下,代码的执行结果始终正确。常见原因包括线程调度随机性、共享数据修改以及原子性问题。解决线程安全问题通常需要采用同步机制,如使用synchronized关键字或Lock接口,以确保同一时间只有一个线程能够访问特定资源,从而保持数据的一致性和正确性。
|
4天前
|
监控 安全 Java
Java多线程的使用
Java多线程允许程序同时执行多个任务,提高了系统的整体性能和响应速度。通过创建Thread类或其子类的实例,或使用Runnable接口,Java开发者可以定义并发执行的代码段。多线程在处理复杂任务、资源共享、网络通信等方面具有显著优势,但也需要注意线程安全、同步和死锁等问题。Java提供了丰富的API和工具来处理这些并发问题,使多线程编程更加高效和可靠。
|
4天前
|
API
java-多线程-CountDownLatch(闭锁) CyclicBarrier(栅栏) Semaphore(信号量)-
java-多线程-CountDownLatch(闭锁) CyclicBarrier(栅栏) Semaphore(信号量)-
10 1
|
5天前
|
安全 Java 程序员
Java基础18-一文搞懂Java多线程使用方式、实现原理以及常见面试题(二)
Java基础18-一文搞懂Java多线程使用方式、实现原理以及常见面试题(二)
26 4
|
5天前
|
Java 程序员 调度
Java基础18-一文搞懂Java多线程使用方式、实现原理以及常见面试题(一)
Java基础18-一文搞懂Java多线程使用方式、实现原理以及常见面试题(一)
22 0
Java基础18-一文搞懂Java多线程使用方式、实现原理以及常见面试题(一)