C++函数返回值是如何传出规则

本文详细解释了C++函数返回值的三种传出规则:4字节通过寄存器,8字节以上使用临时变量。并提供了sum和结构体相关的函数示例以及对应的汇编代码实现。

C++函数返回值是如何传出规则

C++函数返回值是如何传出规则

1、返回值<=4字节,通过一个寄存器返回;
2、返回值>4 且<=8字节,通过两个寄存器返回;
3、返回值>8 字节,主调函数通过生成临时变量然后被调用函数将返回值写进临时变量;

代码示例

#include<stdio.h>
typedef struct NODE2
{
	int a[2];
}NODE2;
typedef struct NODE10
{
	int a[20];
}NODE10;

int sum(int a, int b)
{
	return a + b;
}


NODE2 func2(NODE2 mm)
{
	NODE2 mm1 = {0};
	return mm1;
}

NODE10 func10(NODE10 mm)
{
	NODE10 mm1 = { 0 };
	return mm1;
}

int main()
{
	int s = sum(10, 20);

	NODE2 s1;
	s1.a[0] = 0;
	NODE2 m = func2(s1);

	NODE10 s10;
	s10.a[0] = 0;
	NODE10 m = func10(s10);
}

汇编

	int s = sum(10, 20);
00EB1888  push        14h  
00EB188A  push        0Ah  
00EB188C  call        _sum (0EB1294h)  
00EB1891  add         esp,8  
00EB1894  mov         dword ptr [s],eax  //通过eax 传给s


	NODE2 m2 = func2(s1);
00EB18A7  mov         eax,dword ptr [ebp-14h]  
00EB18AA  push        eax  
00EB18AB  mov         ecx,dword ptr [s1]  
00EB18AE  push        ecx  
00EB18AF  call        _func2 (0EB10A0h)  
00EB18B4  add         esp,8  
00EB18B7  mov         dword ptr [m2],eax  
00EB18BA  mov         dword ptr [ebp-24h],edx  //通过eax edx返回

	NODE10 m10 = func10(s10);
00EB18CD  sub         esp,50h  
00EB18D0  mov         ecx,14h  
00EB18D5  lea         esi,[s10]  
00EB18D8  mov         edi,esp  
00EB18DA  rep movs    dword ptr es:[edi],dword ptr [esi]  
00EB18DC  lea         eax,[ebp-1F0h]  
00EB18E2  push        eax  
00EB18E3  call        _func10 (0EB13B1h)  
00EB18E8  add         esp,54h  
00EB18EB  mov         ecx,14h  
00EB18F0  mov         esi,eax  
00EB18F2  lea         edi,[m10]  
00EB18F8  rep movs    dword ptr es:[edi],dword ptr [esi]  //将返回值拷贝给临时量
内容概要:本文介绍了一个关于超声谐波成像中幅度调制聚焦超声所引起全场位移和应变的分析模型,并提供了基于Matlab的代码实现。该模型旨在精确模拟和分析在超声谐波成像过程中,由于幅度调制聚焦超声作用于生物组织时产生的力学效应,包括全场的位移与应变分布,从而为医学成像和治疗提供理论支持和技术超声谐波成像中幅度调制聚焦超声引起的全场位移和应变的分析模型(Matlab代码实现)手段。文中详细阐述了模型构建的物理基础、数学推导过程以及Matlab仿真流程,具有较强的理论深度与工程应用价值。; 适合人群:具备一定声学、生物医学工程或力学背景,熟悉Matlab编程,从事医学成像、超声技术或相关领域研究的研究生、科研人员及工程技术人员。; 使用场景及目标:①用于超声弹性成像中的力学建模与仿真分析;②支持高强度聚焦超声(HIFU)治疗中的组织响应预测;③作为教学案例帮助理解超声与组织相互作用的物理机制;④为相关科研项目提供可复用的Matlab代码框架。; 阅读建议:建议读者结合超声物理和连续介质力学基础知识进行学习,重点关注模型假设、偏微分方程的数值求解方法及Matlab实现细节,建议动手运行并修改代码以加深理解,同时可拓展应用于其他超声成像或治疗场景的仿真研究。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值