Java多线程实例-阿里云开发者社区

开发者社区> anmypeng1> 正文

Java多线程实例

简介:
+关注继续查看

Thread类的构造方法:
public Thread( );
public Thread(Runnable target);
public Thread(String name);
public Thread(Runnable target, String name);
public Thread(ThreadGroup group, Runnable target);
public Thread(ThreadGroup group, String name);
public Thread(ThreadGroup group, Runnable target, String name);
public Thread(ThreadGroup group, Runnable target, String name, long stackSize);

Runnable target
实现了Runnable接口的类的实例。要注意的是Thread类也实现了Runnable接口,因此,从Thread类继承的类的实例也可以作为target传入这个构造方法。

String name
线程的名子。这个名子可以在建立Thread实例后通过Thread类的setName方法设置。如果不设置线程的名子,线程就使用默认的线程名:Thread-N,N是线程建立的顺序,是一个不重复的正整数。

ThreadGroup group
当前建立的线程所属的线程组。如果不指定线程组,所有的线程都被加到一个默认的线程组中。关于线程组的细节将在后面的章节详细讨论。

long stackSize
线程栈的大小,这个值一般是CPU页面的整数倍。如x86的页面大小是4KB。在x86平台下,默认的线程栈大小是12KB。

================================================

public class MultiThreadsTest
{


public static void main(String args[]){
    Resource res = new Resource();
    ProducerThread p1 = new ProducerThread(res);
    ProducerThread p2 = new ProducerThread(res);
    ProducerThread p3 = new ProducerThread(res);
    p1.start();
    p2.start();
    p3.start();
    
    new Thread(p1,"p1");
    
    ConsumerThread c1 = new ConsumerThread(res);
    c1.start();
}

}

/**

  • 资源类,拥有product,以及生产和消费product的方法
  • @author hp
    *

*/
class Resource {

private int product = 0;

public Resource(){
    this.product = 0;
}

public int getProduct()
{
    return product;
}

public void setProduct(int product)
{
    this.product = product;
}

public synchronized void produce(){
    if(this.product > 100){
        try{
            wait();
            System.out.println("产品已满,请稍后再生产。");
        }catch(Exception e){
            e.printStackTrace();
        }
        return;
    }
    
    this.product++;
    System.out.println("生产一个产品,当前有产品:" + this.product);
    notifyAll();
}

public synchronized void consume(){
    if(this.product <= 0){
        try{
            wait();
            System.out.println("缺货,请稍等。");
        }catch(Exception e ){
            e.printStackTrace();
        }
        return;
    }
    
    this.product--;
    System.out.println("消费一个产品,当前有产品:" + this.product);
    notifyAll();
}

}

/**

  • 生产者,可实例化多个生产者线程实例。调用Resource的生成方法生产product
  • @author hp
    *

*/
class ProducerThread extends Thread{

private Resource r;
public ProducerThread(Resource r){
    this.r = r;
}

public void run(){
    while(true){
        try
        {
            Thread.sleep(1000);
        } catch (InterruptedException e)
        {
            e.printStackTrace();
        }
        r.produce();
    }
}

}

/**

  • 消费者,可实例化多个消费者线程实例。调用Resource的消费方法消费product
  • @author hp
    *

*/
class ConsumerThread extends Thread{

private Resource r;
public ConsumerThread(Resource r){
    this.r = r;
}

public void run(){
    while(true){
        try
        {
            Thread.sleep(100);
        } catch (InterruptedException e)
        {
            e.printStackTrace();
        }
        r.consume();
    }
}

}

版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。

相关文章
SAP成都研究院CEC团队三巨头之一:M君的文章预告
国人总倾向于把特点或者作用类似的人或物放在一起比较并做出排名,于是就有了许多“某某某三巨头”的称谓。
3 0
Spring cloud stream【入门介绍】
在实际开发过程中,服务与服务之间通信经常会使用到消息中间件,而以往使用了哪个中间件比如RabbitMQ,那么该中间件和系统的耦合性就会非常高,如果我们要替换为Kafka那么变动会比较大,这时我们可以使用SpringCloudStream来整合我们的消息中间件,来降低系统和中间件的耦合性。
3 0
SpringCloud-分布式配置中心【加密-非对称加密】
非对称加密我们需要生成对应的公钥和私钥,jdk中提供的有java-keytool工具帮助我们生成
5 0
ECS体验
阿里云使用起来,非常省力。不需要花时间维修服务器硬件,有阿里监控服务器,让我很放心。 阿里云服务器稳定,不会出现异常关机等掉线状况。 阿里云服务器非常安全,不会出现安全问题。 阿里云的价格也非常的亲民,非常省钱,尤其对我们学生用户非常友好。
5 0
ECS使用体验
阿里云开发者社区里不光有着丰富的知识,还有着十分优秀的性能和非常优秀的服务!他的优点还很多,对于我来说他的优点,是可以花费很少的钱去学习,性价比高,里面的知识丰富,我很需要。 还有的就是,我使用阿里云,感觉非常省力,不需要花时间担心卡掉或死机的问题。
3 0
JPA + EclipseLink + SAP云平台 = 运行在云端的数据库应用
JPA(Java Persistence API)的实现Provider有Hibernate,OpenJPA和EclipseLink等等。 本文介绍如何通过JPA + Eclipse连接SAP云平台上的HANA数据库实例。 1. 登陆SAP云平台Cockpit,创建一个新的HANA DB实例:
5 0
使用ABAP(ADBC)和Java(JDBC)连接SAP HANA数据库
在表DBCON里维护一条记录,指向HANA数据库。con_ENV里填入HANA数据库的主机名和端口号。如vmXXXX:30015
4 0
码出高效:Java开发手册-第2章(7)
本章开始讲解面向对象思想,并以Java 为载体讲述面向对象思想在具体编程语言中的运用与实践。当前主流的编程语言有50 种左右,主要分为两大阵营:面向对象编程与面向过程编程。面向对象编程(Object-Oriented Programming,OOP)是划时代的编程思想变革,推动了高级语言的快速发展和工业化进程。OOP 的抽象、封装、继承、多态的理念使软件大规模化成为可能,有效地降低了软件开发成本、维护成本和复用成本。面向对象编程思想完全不同于传统的面向过程编程思想,使大型软件的开发就像搭积木一样隔离可控、高效简单,是当今编程领域的一股势不可......
4 0
ECS使用感受
阿里云服务器初体验
5 0
+关注
9
文章
0
问答
文章排行榜
最热
最新
相关电子书
更多
文娱运维技术
立即下载
《SaaS模式云原生数据仓库应用场景实践》
立即下载
《看见新力量:二》电子书
立即下载