6.3w+
社区成员
#include <stdarg.h>
float sum(int c, ...)
{
va_list ap;
va_start(ap,c);
int i;
float result =0;
for(i=0; i < c; i++)
{
result += va_arg(ap,float);
}
return result;
}
int main(int argc, char* argv[])
{
float a = sum(3,1.1,2.3,3.8);
return 0;
}
; Listing generated by Microsoft (R) Optimizing Compiler Version 15.00.21022.08
TITLE C:\Documents and Settings\hwp\桌面\x.c
.686P
.XMM
include listing.inc
.model flat
INCLUDELIB LIBCMT
INCLUDELIB OLDNAMES
PUBLIC __real@00000000
PUBLIC _sum
EXTRN __fltused:DWORD
; COMDAT __real@00000000
; File c:\documents and settings\hwp\桌面\x.c
CONST SEGMENT
__real@00000000 DD 000000000r ; 0
; Function compile flags: /Odtp
CONST ENDS
_TEXT SEGMENT
_ap$ = -12 ; size = 4
_result$ = -8 ; size = 4
_i$ = -4 ; size = 4
_c$ = 8 ; size = 4
_sum PROC
; Line 4
push ebp
mov ebp, esp
sub esp, 12 ; 0000000cH
; Line 6
fldz
fstp DWORD PTR _result$[ebp]
; Line 8
lea eax, DWORD PTR _c$[ebp+4]
mov DWORD PTR _ap$[ebp], eax
; Line 9
mov DWORD PTR _i$[ebp], 0
jmp SHORT $LN3@sum
$LN2@sum:
mov ecx, DWORD PTR _i$[ebp]
add ecx, 1
mov DWORD PTR _i$[ebp], ecx
$LN3@sum:
mov edx, DWORD PTR _i$[ebp]
cmp edx, DWORD PTR _c$[ebp]
jge SHORT $LN1@sum
; Line 11
mov eax, DWORD PTR _ap$[ebp]
add eax, 4
mov DWORD PTR _ap$[ebp], eax
mov ecx, DWORD PTR _ap$[ebp]
fld DWORD PTR [ecx-4]
fadd DWORD PTR _result$[ebp]
fstp DWORD PTR _result$[ebp]
; Line 12
jmp SHORT $LN2@sum
$LN1@sum:
; Line 13
fld DWORD PTR _result$[ebp]
; Line 14
mov esp, ebp
pop ebp
ret 0
_sum ENDP
_TEXT ENDS
PUBLIC __real@40733333
PUBLIC __real@400ccccd
PUBLIC __real@3f8ccccd
PUBLIC _main
; COMDAT __real@40733333
CONST SEGMENT
__real@40733333 DD 040733333r ; 3.8
CONST ENDS
; COMDAT __real@400ccccd
CONST SEGMENT
__real@400ccccd DD 0400ccccdr ; 2.2
CONST ENDS
; COMDAT __real@3f8ccccd
CONST SEGMENT
__real@3f8ccccd DD 03f8ccccdr ; 1.1
; Function compile flags: /Odtp
CONST ENDS
_TEXT SEGMENT
_a2$ = -16 ; size = 4
_a3$ = -12 ; size = 4
_a1$ = -8 ; size = 4
_a$ = -4 ; size = 4
_argc$ = 8 ; size = 4
_argv$ = 12 ; size = 4
_main PROC
; Line 16
push ebp
mov ebp, esp
sub esp, 16 ; 00000010H
; Line 17
fld DWORD PTR __real@3f8ccccd
fstp DWORD PTR _a1$[ebp]
; Line 18
fld DWORD PTR __real@400ccccd
fstp DWORD PTR _a2$[ebp]
; Line 19
fld DWORD PTR __real@40733333
fstp DWORD PTR _a3$[ebp]
; Line 20
fld DWORD PTR _a3$[ebp]
sub esp, 8
fstp QWORD PTR [esp]
fld DWORD PTR _a2$[ebp]
sub esp, 8
fstp QWORD PTR [esp]
fld DWORD PTR _a1$[ebp]
sub esp, 8
fstp QWORD PTR [esp]
push 3
call _sum
add esp, 28 ; 0000001cH
fstp DWORD PTR _a$[ebp]
; Line 21
xor eax, eax
; Line 22
mov esp, ebp
pop ebp
ret 0
_main ENDP
_TEXT ENDS
END
#include <stdarg.h>
float sum(int c, ...)
{
va_list ap;
va_start(ap,c);
int i;
float result =0;
for(i=0; i < c; i++)
{
result += va_arg(ap,float);
}
return result;
}
int main(int argc, char* argv[])
{
float a1=1.1;
float a2=2.2;
float a3=3.8;
float a = sum(3,a1,a2,a3);
return 0;
}
result += va_arg(ap,float);
====>
result += va_arg(ap,double);