Post Jobs

统计问题,__cdcel和__fastcall三者的区别

[参考]__stdcall、__cdcel和__fastcall三者的区别,__stdcall__cdcel

一、概述

__stdcall、__cdecl和__fastcall是三种函数调用协议,函数调用协议会影响函数参数的入栈方式、栈内数据的清除方式、编译器函数名的修饰规则等。

 

二、调用协议常用场合 

__stdcall:Windows API默认的函数调用协议。

 __cdecl:C/C++默认的函数调用协议。 

__fastcall:适用于对性能要求较高的场合。

 

三、 函数参数入栈方式 

__stdcall:函数参数由右向左入栈。

 __cdecl:函数参数由右向左入栈。

 __fastcall:从左开始不大于4字节的参数放入CPU的ECX和EDX寄存器,其余参数从右向左入栈。

 

四、栈内数据清除方式 

__stdcall:函数调用结束后由被调用函数清除栈内数据。 

__cdecl:函数调用结束后由函数调用者清除栈内数据。 

__fastcall:函数调用结束后由被调用函数清除栈内数据。 

 

五、常见问题 

 

六、C语言编译器函数名称修饰规则 

__stdcall:编译后,函数名被修饰为”[email protected]”。 

__cdecl:编译后,函数名被修饰为”_functionname”。 

__fastcall:编译后, 函数名给修饰为”@[email protected]”。 

注:”functionname”为函数名,”number”为参数字节数。 

注:函数实现和函数定义时如果使用了不同的函数调用协议,则无法实现函数调用。 

 

七、C++语言编译器函数名称修饰规则 

__stdcall:编译后,函数名被修饰为”[email protected]@YG******@Z”。 

__cdecl:编译后,函数名被修饰为”[email protected]@YA******@Z”。 

__fastcall:编译后,函数名被修饰为”[email protected]@YI******@Z”。 

注:”******”为函数返回值类型和参数类型表。

 注:函数实现和函数定义时如果使用了不同的函数调用协议,则无法实现函数调用。 C语言和C++语言间如果不进行特殊处理,也无法实现函数的互相调用。

一、概述
__stdcall、__cdecl和__fastcall是三种函数调用协议,函数调用协议会影响函数…

procedure KillProgram(Classname : string; WindowTitle : string);
const
  PROCESS_TERMINATE = $0001;
var
  ProcessHandle : THandle;
  ProcessID: Integer;
  TheWindow : HWND;
begin
  TheWindow := FindWindow(Classname, WindowTitle);
  GetWindowThreadProcessID(TheWindow, @ProcessID);
  ProcessHandle := OpenProcess(PROCESS_TERMINATE, FALSE, ProcessId);
  TerminateProcess(ProcessHandle,4);
end;

C语言-数学-统计问题(Hdu 2563)

Problem Description 在一无限大的二维平面中,我们做如下假设:
1、 每次只能移动一格;
2、
不能向后走(假设你的目的地是“向上”,那么你可以向左走,可以向右走,也可以向上走,但是不可以向下走);
3、 走过的格子立即塌陷无法再走第二次;

求走n步不同的方案数(2种走法只要有一步不一样,即被认为是不同的方案)。

Input 首先给出一个正整数C,表示有C组测试数据
接下来的C行,每行包含一个整数n (n<=20),表示要走n步。

Output 请编程输出走n步的不同方案总数;
每组的输出占一行。

Sample Input

2
1
2

这里我们始终定义前为正方向.
我们用 a [ i ] 表示朝前走i步的种类,我们用 b [ i ]
表示朝左(右)走 i 步的种类, 显然 a [ 1 ] = 3,b [ 1 ] = 2;
然后分治的思想: 向前走 i 步(i>1)的种类相当于向前走 i-1
步的种类加上向左、向右走 i-1 步的种类. 数学式子表示就是: a [ i ] =
a [ i-1 ]+2*b [ i-1 ];
向左(向右)走 i
步(i>1)的种类相当于向前走 i-1 步的种类加上向右(向左)走 i-1 步的种类.
数学式子表示就是: b [ i ] = a [ i-1 ]+b [ i-1 ];
然后递推可得.

代码如下:

#include 
int main()
{
    int a[21]={0,3},b[21]={0,2},i;
    for(i=2;i<21;i++)
    {
        b[i]=a[i-1]+b[i-1];
        a[i]=a[i-1]+2*b[i-1];
    }
    int m,N;
    scanf("%d",&N);
    while(N--)
    {
        scanf("%d",&m);
        printf("%d\n",a[m]);
    }
    return 0;
}

2563) Problem Description
在一无限大的二维平面中,我们做如下假设: 1、 每次只能移动一格; 2、
不能向后走(假设你…

发表评论

电子邮件地址不会被公开。 必填项已用*标注

相关文章

网站地图xml地图