当前位置: 首页 > news >正文

如何用Java程序实现一个简单的消息队列?

在Java程序中,可以使用内置的java.util.concurrent.BlockingQueue作为消息队列存放的容器,来实现一个简单的消息队列。

具体实现如下,在这个例子中,我们创建了一个生产者线程和一个消费者线程,他们共享同一个阻塞队列。

public class MyBlockingQueue {private static final BlockingQueue<String> queue=new LinkedBlockingQueue<>();public static void main(String[] args) {Thread producer= new Thread(()->{for(int i=0 ; true; i++){try{String str="生产者发送消息";System.out.println(str);queue.put(str);Thread.sleep(1000);}catch(Exception e){Thread.currentThread().interrupt();}}});producer.start();Thread consumer=new Thread(()->{while(true){try{String take = queue.take();System.out.println("消费者获取到消息-->"+take);}catch (Exception e){Thread.currentThread().interrupt();}}});consumer.start();}}

上述程序运行结果如下:

 在实际应用中,你可能会用到更复杂的消息队列服务,如RabbitMQ、Kafka等,但上述代码展示了如何利用Java标准库中的并发工具来实现基本的消息队列功能。

http://www.lryc.cn/news/370467.html

相关文章:

  • OpenAI 宕机事件:GPT 停摆的影响与应对
  • linux常用的基础命令
  • 618家用智能投影仪推荐:这个高性价比品牌不容错过
  • 自愿离婚协议书
  • WPS JSA 宏脚本入门和样例
  • Printing and Exporting
  • c++【入门】正多边形每个内角的度数
  • spring boot3登录开发-邮箱登录/注册接口实现
  • 数据结构-二叉搜索树
  • JUnit:Java开发者不可或缺的单元测试框架
  • NG32单片机GPIO口配置方式
  • SpringCloud-OpenFeign拓展-连接池、最佳使用方法、日志输出
  • 跨链协议中Cosmos IBC、Polkadot/XCM、Celer Network的区别以及用途
  • 电子画册制作与传统画册相比,有哪些优势?
  • postman如何导入证书
  • RocketMQ教程(八):RocketMQ的集群搭建
  • 线上观看人次2万+!「飞天技术沙龙-CentOS 迁移替换专场」北京站圆满结束
  • Docker基本架构概览-1
  • OZON云仓靠谱吗,OZON云仓垫资提货模式
  • 数据集笔记:DGraph 大规模动态图数据集
  • 一些常用的git指令总结
  • 【HarmonyOS】遇见的问题汇总
  • C# NX二次开发-获取圆弧中心点和半径
  • 鸿蒙原生应用元服务开发-位置服务地理编码转化开发
  • 【ArcGISPro SDK】构建多面体要素
  • leetcode够用之java语法
  • pdf文件怎么改变大小?在线快速压缩pdf的方法
  • inferCNV:scRNA-seq数据推断染色体拷贝数变化
  • 银河麒麟操作系统通过首批软件供应链安全能力认证
  • 【MySQL】数据库介绍|数据库分类|MySQL的基本结构|MySQL初步认识|SQL分类