Parameters(in)、Parameters(out) and Parameters(inout)

文章介绍了C语言中函数参数的三种类型:in,out,inout,分别对应只读、只写和读写参数。in参数用于传递不变的输入信息,out参数用于接收函数的输出结果,而inout参数则兼有两者功能,允许函数读取并修改参数值。文章通过示例解释了每种参数类型的使用场景和注意事项。
摘要由CSDN通过智能技术生成

0前言

参数类型(Parameters)指的是函数参数在调用时所具有的性质,从而对函数的调用方式产生影响。在 C 语言中,存在三种不同类型的函数参数:Parameters(in)、Parameters(out) 和 Parameters(inout)

1定义

Parameters(in) 表示将参数作为输入传递给函数。这意味着函数只能读取该参数的值,但不能修改它的原始值。使用 Parameters(in) 的参数通常是用来告诉函数操作的数据或状态,以便函数可以根据这些参数执行一些操作并返回结果,而不会改变这些参数的原始值。

Parameters(out) 则表示将参数作为输出传递给函数。这意味着函数可以修改该参数的原始值,并通过该参数返回函数的计算结果或状态等信息。在调用 Parameters(out) 参数的函数之前,调用方负责初始化该参数的初始值,并确保其占用的内存足够大以容纳输出数据。

Parameters(inout) 组合了 Parameters(in) 和 Parameters(out) 的特性,表示将参数同时作为输入和输出传递给函数。这意味着函数既可以读取参数的原始值,也可以修改它的值,并将结果反馈给调用者。通常情况下,使用 Parameters(inout) 的参数需要注意,在函数执行期间不能将参数设置为 NULL 或其他无效值,否则可能会导致未定义的行为。

2举例说明

INLINE void Basetimer_setMode
(BASETIMER_MODULE* timer, Basetimer_Mode mode)

在这个函数中,mode 参数是一个 Parameters(in) 参数,因为它是一个枚举类型的值,用于告诉函数设置哪种模式的定时器。该函数只需要读取 mode 参数的值来确定应将哪种模式的设置写入对应的寄存器中。在函数内部,不会修改传递给函数的 mode 参数的原始值,而只是使用该参数的值来进行适当的配置。因此,该参数的传递方式属于 Parameters(in)。

#include <stdio.h>

int main() {
    int num;

    printf("Please enter an integer:\n");
    scanf("%d", &num);

    printf("The integer you entered is %d\n", num);
    
    return 0;
}

scanf() 函数的原型定义在头文件 stdio.h 中,其原型如下:

int scanf(const char *format, ...);

在这个示例程序中,定义了一个整数类型的变量 num 作为 Parameters(out) 参数。当调用 scanf() 函数时,它会将用户输入的整数存储到 num 中,并返回成功读取的数据项数目。

需要注意的是,在调用 scanf() 函数时,应该使用 & 运算符对变量地址进行传递,以便让 scanf() 函数能够修改变量的值。

在调用 Parameters(out) 函数之前,应该确保变量已经被初始化并分配了足够的内存空间,否则会导致未定义的行为。

void Espi_Hal_ChannelDynamicInitConfig(EspiChannelDynamicConfig *channelDynamicConfig)
{
	/* Initialize bit order, data mode, last data flag, and parity mode */
	channelDynamicConfig->bitOrder = espiBitOrderMSBFirst; /**< \brief Set bit order to MSB first */
	channelDynamicConfig->dataMode = espiMasterModeSingleShort; /**< \brief Set data mode to single transfer */
	channelDynamicConfig->lastData = false; /**< \brief Set last transfer flag to false */
	channelDynamicConfig->parityMode = espiParityModeEven; /**< \brief Set parity mode to even */
}

在这个函数中,channelDynamicConfig 是一个 Parameters(inout) 参数,因为它是一个指向 EspiChannelDynamicConfig 结构体的指针,在函数内部需要修改该参数所指向的结构体成员变量的值。在函数开始时,调用方已经初始化了 channelDynamicConfig 参数作为结构体对象的指针,并将其传递给该函数。函数在执行过程中通过该指针访问并修改结构体的成员变量,例如设置数据模式、位序等参数。由于该函数不会创建新的内存空间或释放已有的内存空间,所以该函数的参数类型是 Parameters(inout)。

3.总结

在函数参数列表中,根据函数需要使用的方式来区分这三种不同类型的参数。具体而言:

  1. Parameters(in): 表示该参数仅作为输入,并且只能在函数内部访问和读取,不能直接修改其值。
  2. Parameters(out): 表示该参数仅作为输出,并且能够在函数内部被设置或修改它的值,但在调用函数时必须确保变量已经被初始化并分配了足够的内存空间,因为函数将使用该内存空间来存储计算结果。
  3. Parameters(inout): 表示既可以作为输入,也可以作为输出,因此需要在函数开始时确保传递给函数的参数具有合适的初始值,并提供足够的内存空间以存储计算结果。在函数内部,可以对其进行读取和更改。
  • 2
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值