計(jì)算函數(shù)執(zhí)行的時(shí)間

方法1
double func_runtime(double last, char* key) {
    clock_t now = clock();
    printf("time:%fs \t key:%s \n", (last != 0) ? (double)(now - last) / CLOCKS_PER_SEC : 0, key);
    return now;
}

    double t = func_runtime(0, "");
    func_runtime(t, "end");
方法2
#ifndef NonAtomicTest_Method_h

#define NonAtomicTest_Method_h

//c函數(shù)實(shí)現(xiàn)  返回值類(lèi)型 函數(shù)名  函數(shù)參數(shù)(是一個(gè)block)

CGFloat BNRTimeBlock (void (^block)(void)) {
    mach_timebase_info_data_t info;
    if (mach_timebase_info(&info) != KERN_SUCCESS) return -1.0;
    uint64_t start = mach_absolute_time ();

    block ();

    uint64_t end = mach_absolute_time ();

    uint64_t elapsed = end - start;

    uint64_t nanos = elapsed * info.numer / info.denom;

    return (CGFloat)nanos / NSEC_PER_SEC;

} // BNRTimeBlock

#endif

    CGFloat time = 0.0 ;
    printf("begin:===========%lf\n",time);
    time = BNRTimeBlock(^{
        printf("end2:===========%lf\n",time);

        });
        printf("end1:===========%lf\n",time);

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書(shū)系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

友情鏈接更多精彩內(nèi)容