1800b99b8Sopenharmony_ci/* 2800b99b8Sopenharmony_ci * Copyright (c) 2022-2023 Huawei Device Co., Ltd. 3800b99b8Sopenharmony_ci * Licensed under the Apache License, Version 2.0 (the "License"); 4800b99b8Sopenharmony_ci * you may not use this file except in compliance with the License. 5800b99b8Sopenharmony_ci * You may obtain a copy of the License at 6800b99b8Sopenharmony_ci * 7800b99b8Sopenharmony_ci * http://www.apache.org/licenses/LICENSE-2.0 8800b99b8Sopenharmony_ci * 9800b99b8Sopenharmony_ci * Unless required by applicable law or agreed to in writing, software 10800b99b8Sopenharmony_ci * distributed under the License is distributed on an "AS IS" BASIS, 11800b99b8Sopenharmony_ci * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 12800b99b8Sopenharmony_ci * See the License for the specific language governing permissions and 13800b99b8Sopenharmony_ci * limitations under the License. 14800b99b8Sopenharmony_ci */ 15800b99b8Sopenharmony_ci 16800b99b8Sopenharmony_ci#ifndef ELAPSED_TIME_H 17800b99b8Sopenharmony_ci#define ELAPSED_TIME_H 18800b99b8Sopenharmony_ci 19800b99b8Sopenharmony_ci#include <chrono> 20800b99b8Sopenharmony_ci#include "dfx_log.h" 21800b99b8Sopenharmony_cinamespace OHOS { 22800b99b8Sopenharmony_cinamespace HiviewDFX { 23800b99b8Sopenharmony_ciclass ElapsedTime { 24800b99b8Sopenharmony_cipublic: 25800b99b8Sopenharmony_ci ElapsedTime() 26800b99b8Sopenharmony_ci { 27800b99b8Sopenharmony_ci begin_ = std::chrono::high_resolution_clock::now(); 28800b99b8Sopenharmony_ci }; 29800b99b8Sopenharmony_ci 30800b99b8Sopenharmony_ci ElapsedTime(std::string printContent, time_t limitCostMilliseconds) 31800b99b8Sopenharmony_ci : limitCostMilliseconds_(limitCostMilliseconds), printContent_(std::move(printContent)) 32800b99b8Sopenharmony_ci { 33800b99b8Sopenharmony_ci Reset(); 34800b99b8Sopenharmony_ci } 35800b99b8Sopenharmony_ci 36800b99b8Sopenharmony_ci ~ElapsedTime() 37800b99b8Sopenharmony_ci { 38800b99b8Sopenharmony_ci if (limitCostMilliseconds_ != 0) { 39800b99b8Sopenharmony_ci time_t costTime = Elapsed<std::chrono::milliseconds>(); 40800b99b8Sopenharmony_ci if (costTime > limitCostMilliseconds_) { 41800b99b8Sopenharmony_ci DFXLOGW("%{public}s running %{public}" PRId64 " ms", printContent_.c_str(), costTime); 42800b99b8Sopenharmony_ci } 43800b99b8Sopenharmony_ci } 44800b99b8Sopenharmony_ci } 45800b99b8Sopenharmony_ci 46800b99b8Sopenharmony_ci void Reset() 47800b99b8Sopenharmony_ci { 48800b99b8Sopenharmony_ci begin_ = std::chrono::high_resolution_clock::now(); 49800b99b8Sopenharmony_ci }; 50800b99b8Sopenharmony_ci 51800b99b8Sopenharmony_ci template<typename Duration=std::chrono::nanoseconds> 52800b99b8Sopenharmony_ci time_t Elapsed() const 53800b99b8Sopenharmony_ci { 54800b99b8Sopenharmony_ci return std::chrono::duration_cast<Duration>(std::chrono::high_resolution_clock::now() - begin_).count(); 55800b99b8Sopenharmony_ci }; 56800b99b8Sopenharmony_ci 57800b99b8Sopenharmony_ciprivate: 58800b99b8Sopenharmony_ci std::chrono::time_point<std::chrono::high_resolution_clock> begin_; 59800b99b8Sopenharmony_ci time_t limitCostMilliseconds_ = 0; 60800b99b8Sopenharmony_ci std::string printContent_ = ""; 61800b99b8Sopenharmony_ci}; 62800b99b8Sopenharmony_ci} 63800b99b8Sopenharmony_ci} 64800b99b8Sopenharmony_ci#endif 65