/* * Tencent is pleased to support the open source community by making * Tencent GT (Version 2.4 and subsequent versions) available. * * Notwithstanding anything to the contrary herein, any previous version * of Tencent GT shall not be subject to the license hereunder. * All right, title, and interest, including all intellectual property rights, * in and to the previous version of Tencent GT (including any and all copies thereof) * shall be owned and retained by Tencent and subject to the license under the * Tencent GT End User License Agreement (http://gt.qq.com/wp-content/EULA_EN.html). * * Copyright (C) 2015 THL A29 Limited, a Tencent company. All rights reserved. * * Licensed under the MIT License (the "License"); you may not use this file * except in compliance with the License. You may obtain a copy of the License at * * http://opensource.org/licenses/MIT * * Unless required by applicable law or agreed to in writing, software distributed * under the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR * CONDITIONS OF ANY KIND, either express or implied. See the License for the * specific language governing permissions and limitations under the License. */ package com.tencent.wstt.gt.data; import java.util.concurrent.LinkedBlockingQueue; import com.tencent.wstt.gt.AidlTask; public class PerfTaskCache { // 出参入参设置任务直接送队列,TODO 后面将和本地性能合并,缓存历史数据 // 本地性能任务列表,直接送统计数据,可以异步,在完成Reduce计算后即加进来 // 全局性能任务容器,需要送计算源数据,可以异步,但要在控制台侧做支持乱时序,时间戳需要 private LinkedBlockingQueue<AidlTask> aidlPerfQueue; // TODO 日志在日志模块,暂时不移动过来,考虑做集中处理 public PerfTaskCache() { aidlPerfQueue = new LinkedBlockingQueue<AidlTask>(); } public void clear() { aidlPerfQueue.clear(); } public void add(AidlTask v) { aidlPerfQueue.offer(v); } public AidlTask take() throws InterruptedException { return aidlPerfQueue.take(); } }