/* * 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.control; import com.tencent.wstt.gt.AidlTask; import com.tencent.wstt.gt.BooleanEntry; import com.tencent.wstt.gt.Functions; import com.tencent.wstt.gt.IService; import com.tencent.wstt.gt.InPara; import com.tencent.wstt.gt.OutPara; import com.tencent.wstt.gt.PerfDigitalEntry; import com.tencent.wstt.gt.QueryPerfEntry; public class ParaTaskConsumer { private Thread thread; boolean flag; public ParaTaskConsumer(final IService gtService, final DataCacheController dataCacheController) { thread = new Thread(new Runnable() { @Override public void run() { try { while (flag) { AidlTask task = dataCacheController.takeParaTask(); if (null != task) { if (task instanceof InPara) { InPara para = (InPara)task; // 注册的入参,可能包括set入参的怨念 if (para.isRegistering()) { if (para.isGlobal()) { gtService.registerGlobalInPara(para); } else { gtService.registerInPara(para); } } // 单独的设置入参值的任务 else { if (null != para.getValues() && para.getValues().size() > 0) { if (para.isGlobal()) { gtService.setGlobalInPara(para.getKey(), para.getValues().get(0)); } else { gtService.setInPara(para.getKey(), para.getValues().get(0)); } } } } else if (task instanceof OutPara) { OutPara para = (OutPara)task; // 注册的出参,可能包括本地set出参的历史记录 if (para.isRegistering()) { if (para.isGlobal()) { gtService.registerGlobalOutPara(para); } else { gtService.registerOutPara(para); } } else { if (null != para.getValue()) { if (para.isGlobal()) { gtService.setGlobalOutPara(para.getKey(), para.getValue()); } else { gtService.setOutPara(para.getKey(), para.getValue()); } } } } else if (task instanceof BooleanEntry) { gtService.setBooleanEntry((BooleanEntry) task); } } } } catch (Exception e) { e.printStackTrace(); } } }, ParaTaskConsumer.this.getClass().getSimpleName()); } public void start() { flag = true; thread.setPriority(Thread.MIN_PRIORITY + 2); // 比性能优先级高点 thread.start(); } public void stop(final DataCacheController dataCacheController) { flag = false; /* * stop时,如果日志队列为空,那会始终使线程卡在takeTask上使flag没机会生效, * 所以这里取巧放一个task,使线程运转起来 */ QueryPerfEntry queryPerfEntry = new QueryPerfEntry("GTsys", "startStopTaskConsumer", 0, 0); PerfDigitalEntry entry = new PerfDigitalEntry(); entry.setFunctionId(Functions.PERF_END_TIME_GLOBAL); // 用endTime,这样不会在控制台侧积压 entry.setQueryEntry(queryPerfEntry); entry.setLogTime(System.currentTimeMillis()); entry.setData(System.nanoTime()); dataCacheController.putParaTask(entry); thread = null; } }