For loop performance difference, and compiler optimization

前端 未结 7 1335
耶瑟儿~
耶瑟儿~ 2021-02-14 00:40

I chose David\'s answer because he was the only one to present a solution to the difference in the for-loops with no optimization flags. The other answers demonstrate what

7条回答
  •  隐瞒了意图╮
    2021-02-14 01:15

    Answer of first question:

    1- It makes faster after doing it once for for loops but i am not sure just commenting according to my experiment results.(experiment 1 change their names(B->A,A->B) experiment 2 run one function has for loop before time checks,experiment 3 start one for loop before time checks)

    2- First programs should work faster the reason is second function is does 2 operation when first function does 1 operation.

    I leave here updated code which explain my answer.

    Answer of second question:

    I am not sure but there can be two ways coming my mind,

    It can be formalize your function in some way and get rid of loops because the difference can be destroyed by that way(like "return end-init" or "return todo" i dunno, i'm not sure)

    It has -fauto_inc_dec and it can make that difference because these functions all about increaments and decreaments.

    I hope it can help.

    #include 
    #include 
    #include 
    
    using std::uint64_t;
    
    uint64_t superCalculationA(int init, int end)
    {
        uint64_t total = 0;
        for (int i = init; i < end; i++)
            total += i;
        return total;
    }
    uint64_t superCalculationB(int init, int todo)
    {
        uint64_t total = 0;
        for (int i = init; i < init+todo; i++)
            total += i;
        return total;
    }
    int add(int a1,int a2){printf("multiple times added\n");return a1+a2;}
    uint64_t superCalculationC(int init, int todo)
    {
        uint64_t total = 0;
        for (int i = init; i < add(init , todo); i++)
            total += i;
        return total;
    }
    
    int main()
    {
        const uint64_t answer = 500000110500000000;
    
        std::clock_t start=clock();
        double elapsed;
    
        std::printf("=====================================================\n");
    
        superCalculationA(111, 1000000111);
    
        start = clock();
        uint64_t ret1 = superCalculationA(111, 1000000111);
        elapsed = ((std::clock()-start)*1.0/CLOCKS_PER_SEC);
        std::printf("Elapsed time: %.3f s | %.3f ms | %.3f us\n", elapsed, 1e+3*elapsed,    1e+6*elapsed);
    
        start = clock();
        uint64_t ret2 = superCalculationB(111, 1000000000);
        elapsed = ((std::clock()-start)*1.0/CLOCKS_PER_SEC);
        std::printf("Elapsed time: %.3f s | %.3f ms | %.3f us\n", elapsed, 1e+3*elapsed, 1e+6*elapsed);
    
        if (ret1 == answer)
        {
            std::printf("The first method, i.e. superCalculationA, succeeded.\n");
        }
        if (ret2 == answer)
        {
            std::printf("The second method, i.e. superCalculationB, succeeded.\n");
        }
    
        std::printf("=====================================================\n");
    
        return 0;
    }
    

提交回复
热议问题