`

java多线程

阅读更多

java多线程的原理是:


1.虚拟的cpu:  继承java.lang.Thread类,完成线程的机制(内部是native方法,源代码中是private static native void registerNatives())



2.运行线程体:  覆盖run()方法。将方法体在虚拟的cpu上运行(源代码上式:public void run() )。



3. 启动线程:  调用Start()方法,就是先启动虚拟的cpu(即在调用run()方法运行)。


  下面用生产者-消费者做个例子:

import java.util.ArrayList;  
import java.util.List;  
  
public class ThreadTest {  
  
    List<Object> basket = new ArrayList<Object>();  
  
    public synchronized Object getFood() {  
        if (basket.size() == 0) {  
            try {  
                wait();  
            } catch (InterruptedException e) {  
            }  
        }  
  
        Object food = basket.get(0);  
        basket.clear();// 清空盘子  
        notify();// 唤醒阻塞队列的某线程到就绪队列  
        System.out.println("拿到食物");  
        return food;  
    }  
  
    public synchronized void putFood(Object food) {  
        if (basket.size() > 0) {  
            try {  
                wait();  
            } catch (InterruptedException e) {  
            }  
        }  
        basket.add(food);// 往盘子里放食物  
        notify();// 唤醒阻塞队列的某线程到就绪队列  
        System.out.println("放入食物");  
    }  
      
    static class ProduceThread extends Thread{  
        private ThreadTest threadTest;  
        private Object food=new Object();  
        public ProduceThread(ThreadTest threadTest){  
            this.threadTest=threadTest;  
        }  
          
        public void run(){  
            for(int i=0;i<5;i++){  
                threadTest.putFood(food);  
            }  
        }  
    }  
      
    static class ConsumeThread extends Thread{  
        private ThreadTest threadTest;  
        public ConsumeThread(ThreadTest threadTest){  
            this.threadTest=threadTest;  
        }  
          
        public void run(){  
            for(int i=0;i<5;i++){  
                threadTest.getFood();  
            }  
        }  
    }  
      
    public static void main(String args[]){  
        try {  
        	ThreadTest threadTest=new ThreadTest();  
            Thread add=new Thread(new ProduceThread(threadTest));  
            Thread get=new Thread(new ConsumeThread(threadTest));  
            add.start();  
            get.start();  
            add.join();  
            get.join();  
        } catch (InterruptedException e) {  
            e.printStackTrace();  
        }  
        System.out.println("测试结束");  
    }  
}  

 

 

分享到:
评论

相关推荐

    Java多线程知识点总结

    Java多线程是Java编程语言中一个非常重要的概念,它允许开发者在一个程序中创建多个执行线程并行运行,以提高程序的执行效率和响应速度。在Java中,线程的生命周期包含五个基本状态,分别是新建状态(New)、就绪...

    java 多线程操作数据库

    ### Java多线程操作数据库:深入解析与应用 在当今高度并发的应用环境中,Java多线程技术被广泛应用于处理数据库操作,以提升系统的响应速度和处理能力。本文将基于一个具体的Java多线程操作数据库的应用程序,深入...

    Java多线程设计模式上传文件

    Java多线程设计模式上传文件Java多线程设计模式上传文件Java多线程设计模式上传文件Java多线程设计模式上传文件Java多线程设计模式上传文件Java多线程设计模式上传文件Java多线程设计模式上传文件Java多线程设计模式...

    java多线程经典案例

    Java多线程是Java编程中的重要概念,它允许程序同时执行多个任务,极大地提升了程序的效率和性能。在Java中,实现多线程有两种主要方式:通过实现Runnable接口或者继承Thread类。本案例将深入探讨Java多线程中的关键...

    java多线程Demo

    Java多线程是Java编程中的一个重要概念,它允许程序同时执行多个任务,提高了程序的效率和响应速度。在Java中,实现多线程有两种主要方式:继承Thread类和实现Runnable接口。 1. 继承Thread类: 当我们创建一个新...

    java多线程的讲解和实战

    Java多线程是Java编程中的重要概念,尤其在如今的多核处理器环境下,理解并熟练掌握多线程技术对于提高程序性能和响应速度至关重要。本资料详细讲解了Java多线程的原理,并提供了丰富的实战代码,非常适合Java初学者...

Global site tag (gtag.js) - Google Analytics