在以下C程序中_AX = 1000的含义是什么?

May*_*ari 20 c function

我是C编程语言的初学者,最近我开始学习函数,我研究过函数使用关键字return来返回调用函数中的值.例如以下程序.

int getVal(){
 return 1000;
}

int main(){
int x = getVal();
printf("x = %d",x);
return 0;
}
Run Code Online (Sandbox Code Playgroud)

将打印x = 1000

但我很困惑(在turbo C编译器32位下)为什么以下程序也产生x = 1000的输出.请解释.

int get_val(){
 _AX = 1000;
}

int main(){
int x = get_val();
printf("x = %d",x);
return 0;
}
Run Code Online (Sandbox Code Playgroud)

Mat*_*son 25

在大多数x86系统中,"返回值"在特定寄存器中返回(由"ABI"定义,应用程序二进制接口,描述编译器应如何生成其代码),即EAX(32位)或AX(16) bit)[不是说_AX内部实际上不是EAX].

这个编译器显然支持通过命名它来直接使用"寄存器"_AX.因此,通过使用值加载[E] AX寄存器,我们基本上返回此值.

这绝对不会在任何其他编译器中工作,尽管内联汇编程序可以实现相同的功能.


小智 11

在C中,_AX是伪寄存器.当你这样做时AX=1000,这个值1000来自累加器

但它可能无法在GCC编译器中按预期工作

在Turbo C中编译并运行以下程序,您将获得35作为输出.它可能在其他编译器中不起作用.

#include<stdio.h>  
int main()  
{
    int a = 0;  
    a = 35;  
    printf("%d");  
    return 0;
}  
Run Code Online (Sandbox Code Playgroud)

假设a = 1200的地址.假设视频存储器的地址= 5500;

MOV AH, 35  
MOV [1200], AH  
MOV [5500], AH // prints on the screen.  
Run Code Online (Sandbox Code Playgroud)

这是执行的方式.在将值35复制到位置1200之后,AH保留值35.

然后printf("%d")尝试从AH获取值并发送到视频内存以在屏幕上显示它.

如果我们使用printf("%d %d", age, salary),在使用该值发送到视频内存之前,年龄值会转移到AH.然后将薪水值移至AH,然后发送至视频内存.

假设,年龄地址= 1200; 工资地址= 1202; 视频内存地址= XXXX; (它会根据屏幕上打印的字符数改变,不要太在意这个地址值)

MOV AH, [1200]
MOV [XXXX], AH
MOV AH, [1202]
MOV [XXXX], AH
Run Code Online (Sandbox Code Playgroud)

我希望这有助于理解给定程序的解决方案.


May*_*ari 7

根据TC编译器(32位),函数的返回值存储在累加器(AC)中,可以使用_AX在TC编译器中访问,所以当你写:

_AX = 1000;
Run Code Online (Sandbox Code Playgroud)

表示您将值1000置于累加器中,并且当该函数完成其执行并且控件到达调用函数时,则检查累加器的值,在这种情况下,该值将存储在x中.

这里的声明

x = get_val();
Run Code Online (Sandbox Code Playgroud)

会很简单

x = 1000;
Run Code Online (Sandbox Code Playgroud)

但这只是在你的情况下,意味着(TC 32位Windows编译器),它可能或可能不适用于其他编译器.