生产者消费者测试



package test.thread;

import java.util.LinkedList;

public class ProducerConsumerTest {
 public static void main(String[] args) {
  ClsQueue queue=new ClsQueue();
  Producer p=new Producer(queue);
  Consumer c=new Consumer(queue);
  p.start();
  c.start();
 }
}
class Goods{
 private String name;
 private String price;
 
 public Goods(String name,String price){
  this.name=name;
  this.price=price;
 }
 public String toString(){
  return "名称:"+name+"价格:"+price;
 }
}

class ClsQueue{
 private LinkedList ll;
 public ClsQueue(){
  this.ll=new LinkedList();
 }
 public synchronized Object get(){
  if(ll.size()<=0){
   try {
    this.wait();
   } catch (InterruptedException e) {
    e.printStackTrace();
   }
  }
  Object o=ll.removeFirst();
  return o;
 }
 public synchronized void put(Object o){
  int size=ll.size();
  ll.addLast(o);
  if(size==0){
   this.notify();
  }
 }
}

class Producer extends Thread{
 private ClsQueue queue;
 public Producer(ClsQueue queue){
  this.queue=queue;
 }
 public void run(){
  int i=0;
  while(true){
   Goods goods=new Goods("货物"+i,"单价"+i);
   queue.put(goods);
   System.out.println("生产: "+goods.toString());
   i++;
   try {
    Thread.sleep(500);
   } catch (InterruptedException e) {
    e.printStackTrace();
   }
  }
 }
}

class Consumer extends Thread{
 private ClsQueue queue;
 public Consumer(ClsQueue queue){
  this.queue=queue;
 }
 public void run(){
  while(true){
   System.out.println("消费: "+queue.get().toString());
   try {
    Thread.sleep(1000);
   } catch (InterruptedException e) {
    e.printStackTrace();
   }
  }
 }
}


运行结果:

生产: 名称:货物0价格:单价0
消费: 名称:货物0价格:单价0
生产: 名称:货物1价格:单价1
生产: 名称:货物2价格:单价2
消费: 名称:货物1价格:单价1
生产: 名称:货物3价格:单价3
生产: 名称:货物4价格:单价4
消费: 名称:货物2价格:单价2
生产: 名称:货物5价格:单价5
生产: 名称:货物6价格:单价6
消费: 名称:货物3价格:单价3
生产: 名称:货物7价格:单价7
生产: 名称:货物8价格:单价8
消费: 名称:货物4价格:单价4
生产: 名称:货物9价格:单价9
生产: 名称:货物10价格:单价10
消费: 名称:货物5价格:单价5
生产: 名称:货物11价格:单价11
生产: 名称:货物12价格:单价12
消费: 名称:货物6价格:单价6
生产: 名称:货物13价格:单价13
生产: 名称:货物14价格:单价14
消费: 名称:货物7价格:单价7
生产: 名称:货物15价格:单价15
生产: 名称:货物16价格:单价16
消费: 名称:货物8价格:单价8
生产: 名称:货物17价格:单价17
生产: 名称:货物18价格:单价18
消费: 名称:货物9价格:单价9
生产: 名称:货物19价格:单价19

。。。。。。

### Java RabbitMQ 生产者消费者连接示例 以下是一个完整的 Java RabbitMQ 生产者消费者连接示例,包含生产者消费者的代码实现。 #### 1. Maven 依赖配置 在项目的 `pom.xml` 文件中添加 RabbitMQ 客户端依赖和日志依赖: ```xml <dependencies> <dependency> <groupId>com.rabbitmq</groupId> <artifactId>amqp-client</artifactId> <version>5.14.0</version> </dependency> <dependency> <groupId>org.slf4j</groupId> <artifactId>slf4j-nop</artifactId> <version>1.7.25</version> </dependency> </dependencies> ``` 此部分配置用于确保项目能够正确引入 RabbitMQ 客户端库[^5]。 #### 2. 生产者代码示例 以下是生产者的代码实现,负责将消息发送到队列中: ```java import com.rabbitmq.client.Channel; import com.rabbitmq.client.Connection; import com.rabbitmq.client.ConnectionFactory; public class Producer { private static final String QUEUE_NAME = "hello_queue"; public static void main(String[] args) { try { // 创建连接工厂 ConnectionFactory factory = new ConnectionFactory(); factory.setHost("localhost"); // 建立连接 try (Connection connection = factory.newConnection(); Channel channel = connection.createChannel()) { // 声明队列 channel.queueDeclare(QUEUE_NAME, false, false, false, null); // 发送消息 String message = "Hello, RabbitMQ!"; channel.basicPublish("", QUEUE_NAME, null, message.getBytes()); System.out.println("Sent: " + message); } } catch (Exception e) { e.printStackTrace(); } } } ``` 生产者通过 `ConnectionFactory` 创建连接,并使用 `Channel` 对象声明队列和发送消息[^2]。 #### 3. 消费者代码示例 以下是消费者的代码实现,负责从队列中接收消息: ```java import com.rabbitmq.client.Channel; import com.rabbitmq.client.Connection; import com.rabbitmq.client.ConnectionFactory; import com.rabbitmq.client.DeliverCallback; public class Consumer { private static final String QUEUE_NAME = "hello_queue"; public static void main(String[] args) { try { // 创建连接工厂 ConnectionFactory factory = new ConnectionFactory(); factory.setHost("localhost"); // 建立连接 Connection connection = factory.newConnection(); Channel channel = connection.createChannel(); // 声明队列 channel.queueDeclare(QUEUE_NAME, false, false, false, null); // 设置回调函数 DeliverCallback deliverCallback = (consumerTag, delivery) -> { String message = new String(delivery.getBody(), "UTF-8"); System.out.println("Received: '" + message + "'"); }; // 开始消费消息 channel.basicConsume(QUEUE_NAME, true, deliverCallback, consumerTag -> {}); } catch (Exception e) { e.printStackTrace(); } } } ``` 消费者通过 `DeliverCallback` 接收消息并打印到控制台[^1]。 #### 4. 测试步骤 1. 启动 RabbitMQ 服务。 2. 运行 `Producer` 类,发送消息到队列。 3. 运行 `Consumer` 类,从队列中接收消息并打印。 ### 注意事项 - 确保 RabbitMQ 服务已启动并在本地运行(默认端口为 5672)。 - 如果需要远程连接,请修改 `ConnectionFactory` 的 `setHost` 和 `setPort` 方法参数。 - 队列名称必须一致,否则生产者消费者无法通信。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值