new utility class tbStopWatch added to improve performance measurement experience
This commit is contained in:
		
							parent
							
								
									16a55b16e4
								
							
						
					
					
						commit
						24eca34576
					
				@ -36,6 +36,11 @@
 | 
			
		||||
    </properties>
 | 
			
		||||
 | 
			
		||||
    <dependencies>
 | 
			
		||||
        <dependency>
 | 
			
		||||
            <groupId>org.springframework</groupId>
 | 
			
		||||
            <artifactId>spring-core</artifactId>
 | 
			
		||||
            <version>${spring.version}</version>
 | 
			
		||||
        </dependency>
 | 
			
		||||
        <dependency>
 | 
			
		||||
            <groupId>com.google.guava</groupId>
 | 
			
		||||
            <artifactId>guava</artifactId>
 | 
			
		||||
 | 
			
		||||
@ -0,0 +1,62 @@
 | 
			
		||||
/**
 | 
			
		||||
 * ThingsBoard, Inc. ("COMPANY") CONFIDENTIAL
 | 
			
		||||
 *
 | 
			
		||||
 * Copyright © 2016-2021 ThingsBoard, Inc. All Rights Reserved.
 | 
			
		||||
 *
 | 
			
		||||
 * NOTICE: All information contained herein is, and remains
 | 
			
		||||
 * the property of ThingsBoard, Inc. and its suppliers,
 | 
			
		||||
 * if any.  The intellectual and technical concepts contained
 | 
			
		||||
 * herein are proprietary to ThingsBoard, Inc.
 | 
			
		||||
 * and its suppliers and may be covered by U.S. and Foreign Patents,
 | 
			
		||||
 * patents in process, and are protected by trade secret or copyright law.
 | 
			
		||||
 *
 | 
			
		||||
 * Dissemination of this information or reproduction of this material is strictly forbidden
 | 
			
		||||
 * unless prior written permission is obtained from COMPANY.
 | 
			
		||||
 *
 | 
			
		||||
 * Access to the source code contained herein is hereby forbidden to anyone except current COMPANY employees,
 | 
			
		||||
 * managers or contractors who have executed Confidentiality and Non-disclosure agreements
 | 
			
		||||
 * explicitly covering such access.
 | 
			
		||||
 *
 | 
			
		||||
 * The copyright notice above does not evidence any actual or intended publication
 | 
			
		||||
 * or disclosure  of  this source code, which includes
 | 
			
		||||
 * information that is confidential and/or proprietary, and is a trade secret, of  COMPANY.
 | 
			
		||||
 * ANY REPRODUCTION, MODIFICATION, DISTRIBUTION, PUBLIC  PERFORMANCE,
 | 
			
		||||
 * OR PUBLIC DISPLAY OF OR THROUGH USE  OF THIS  SOURCE CODE  WITHOUT
 | 
			
		||||
 * THE EXPRESS WRITTEN CONSENT OF COMPANY IS STRICTLY PROHIBITED,
 | 
			
		||||
 * AND IN VIOLATION OF APPLICABLE LAWS AND INTERNATIONAL TREATIES.
 | 
			
		||||
 * THE RECEIPT OR POSSESSION OF THIS SOURCE CODE AND/OR RELATED INFORMATION
 | 
			
		||||
 * DOES NOT CONVEY OR IMPLY ANY RIGHTS TO REPRODUCE, DISCLOSE OR DISTRIBUTE ITS CONTENTS,
 | 
			
		||||
 * OR TO MANUFACTURE, USE, OR SELL ANYTHING THAT IT  MAY DESCRIBE, IN WHOLE OR IN PART.
 | 
			
		||||
 */
 | 
			
		||||
package org.thingsboard.common.util;
 | 
			
		||||
 | 
			
		||||
import org.springframework.util.StopWatch;
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
 * Utility method that extends Spring Framework StopWatch
 | 
			
		||||
 * It is a MONOTONIC time stopwatch.
 | 
			
		||||
 * It is a replacement for any measurements with a wall-clock like System.currentTimeMillis()
 | 
			
		||||
 * It is not affected by leap second, day-light saving and wall-clock adjustments by manual or network time synchronization
 | 
			
		||||
 * The main features is a single call for common use cases:
 | 
			
		||||
 *  - create and start: TbStopWatch sw = TbStopWatch.startNew()
 | 
			
		||||
 *  - stop and get: sw.stopAndGetTotalTimeMillis() or sw.stopAndGetLastTaskTimeMillis()
 | 
			
		||||
 * */
 | 
			
		||||
public class TbStopWatch extends StopWatch {
 | 
			
		||||
 | 
			
		||||
    public static TbStopWatch startNew(){
 | 
			
		||||
        TbStopWatch stopWatch = new TbStopWatch();
 | 
			
		||||
        stopWatch.start();
 | 
			
		||||
        return stopWatch;
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    public long stopAndGetTotalTimeMillis(){
 | 
			
		||||
        stop();
 | 
			
		||||
        return getTotalTimeMillis();
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    public long stopAndGetLastTaskTimeMillis(){
 | 
			
		||||
        stop();
 | 
			
		||||
        return getLastTaskTimeMillis();
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
}
 | 
			
		||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user