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