zoukankan      html  css  js  c++  java
  • 分享一段线程队列--生产者和消费者代码

    分享一段线程队列--生产者和消费者代码,如有问题,请不吝赐教

    import com.alibaba.fastjson.JSON;
    import org.slf4j.LoggerFactory;
    import org.springframework.beans.factory.annotation.Autowired;
    import org.springframework.context.annotation.Scope;
    import org.springframework.stereotype.Component;
    import java.util.concurrent.ConcurrentLinkedQueue;
    
    @Component
    @Scope("singleton")
    public class SystemLogMqSingleton {
        private static final org.slf4j.Logger logger = LoggerFactory.getLogger(SystemLogMqSingleton.class);
    
        private final Object notifyer = new Object();
        private Thread work;
        private static ConcurrentLinkedQueue<Object> queue = new ConcurrentLinkedQueue<Object>();
        private volatile boolean cancelled = true;
    
        private SystemLogMqSingleton() throws InterruptedException {
            long timeStart = System.currentTimeMillis();
            work = new Thread(new Poll());
            work.setName("cardbag-MqSingleton");
            work.start();
            if(logger.isDebugEnabled()) {
                logger.debug("##耗时##=======cost time " + (System.currentTimeMillis() - timeStart) + "ms");
            }
        }
    
        /**
         * 生产消息
         */
        public void write(Object log) {
            queue.offer(log);
        }
    
        public void stop(){
            cancelled=false;
        }
    
        /**
         * 消费消息
         */
        class Poll implements Runnable {
            public void run() {
                while (cancelled) {
                    if (!queue.isEmpty()) {
                        try {
                            Object msg = queue.poll();
                            long startMili = System.currentTimeMillis();// 当前时间对应的毫秒数
    
                            //这里可写针对从队列里取出来的消息的处理逻辑
    
    
                            long endMili = System.currentTimeMillis();
                            if(logger.isDebugEnabled()) {
                                logger.debug("总耗时为:" + (endMili - startMili) + "毫秒");
                            }
                        } catch (Exception ex) {
                            logger.error("================#记录数据异常#=================" + ex.getMessage() + ex.getStackTrace());
                        }
                    } else {
                        try {
                            //如何没有消息可以等待2s,节约cpu资源 或 Thread.currentThread().sleep(2000)
                            synchronized (notifyer) {
                                notifyer.wait(2000);
                            }
                        } catch (InterruptedException e) {
                            logger.error("##消费异常##======>"+e.getMessage()+e.getStackTrace());
                            e.printStackTrace();
                            Thread.currentThread().interrupt();
                        }
                    }
                }
            }
        }
    
    }
  • 相关阅读:
    Sensor Fusion-based Exploration in Home Environments using Information, Driving and Localization Gains(基于传感器融合的使用信息、驾驶和定位增益在家庭环境中的探索)
    Git中从远程的分支获取最新的版本到本地
    git拉取远程分支到本地分支或者创建本地新分支
    win7下使用git
    ADAS

    struct对齐
    STL容器
    智能指针
    c++中的基本知识点
  • 原文地址:https://www.cnblogs.com/fangyuan303687320/p/7812873.html
Copyright © 2011-2022 走看看