C语言中临时变量的意思,c 中的临时变量和性能

您可以通过编译汇编语言(当然还有优化)并检查输出来自己回答这样的问题.如果我把你的榜样变成一个完整的,可编辑的程序……

extern int f();

extern int g();

int direct()

{

return f() + g();

}

int indirect()

{

int F = f();

int G = g();

return F + G;

}

并编译它(g -S -O2 -fomit-frame-pointer -fno-exceptions test.cc;最后两个开关消除了输出中的一堆干扰),我得到了这个(进一步的干扰被删除):

__Z8indirectv:

pushq %rbx

call __Z1fv

movl %eax, %ebx

call __Z1gv

addl %ebx, %eax

popq %rbx

ret

__Z6directv:

pushq %rbx

call __Z1fv

movl %eax, %ebx

call __Z1gv

addl %ebx, %eax

popq %rbx

ret

如您所见,为这两个函数生成的代码是相同的,因此您的问题的答案是否定的,没有性能差异.现在让我们看看复数 – 相同的代码,但是s / int / std :: complex< double> / g贯穿始终和#include< complex>在顶部;相同的编译开关 –

__Z8indirectv:

subq $72, %rsp

call __Z1fv

movsd %xmm0, (%rsp)

movsd %xmm1, 8(%rsp)

movq (%rsp), %rax

movq %rax, 48(%rsp)

movq 8(%rsp), %rax

movq %rax, 56(%rsp)

call __Z1gv

movsd %xmm0, (%rsp)

movsd %xmm1, 8(%rsp)

movq (%rsp), %rax

movq %rax, 32(%rsp)

movq 8(%rsp), %rax

movq %rax, 40(%rsp)

movsd 48(%rsp), %xmm0

addsd 32(%rsp), %xmm0

movsd 56(%rsp), %xmm1

addsd 40(%rsp), %xmm1

addq $72, %rsp

ret

__Z6directv:

subq $72, %rsp

call __Z1gv

movsd %xmm0, (%rsp)

movsd %xmm1, 8(%rsp)

movq (%rsp), %rax

movq %rax, 32(%rsp)

movq 8(%rsp), %rax

movq %rax, 40(%rsp)

call __Z1fv

movsd %xmm0, (%rsp)

movsd %xmm1, 8(%rsp)

movq (%rsp), %rax

movq %rax, 48(%rsp)

movq 8(%rsp), %rax

movq %rax, 56(%rsp)

movsd 48(%rsp), %xmm0

addsd 32(%rsp), %xmm0

movsd 56(%rsp), %xmm1

addsd 40(%rsp), %xmm1

addq $72, %rsp

ret

这是更多的指令,编译器没有做一个完美的优化工作,它看起来像,但尽管如此,为这两个函数生成的代码是相同的.

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值