- C 标准库
- C 库 - 首页
- C 库 - <assert.h>
- C 库 - <complex.h>
- C 库 - <ctype.h>
- C 库 - <errno.h>
- C 库 - <fenv.h>
- C 库 - <float.h>
- C 库 - <inttypes.h>
- C 库 - <iso646.h>
- C 库 - <limits.h>
- C 库 - <locale.h>
- C 库 - <math.h>
- C 库 - <setjmp.h>
- C 库 - <signal.h>
- C 库 - <stdalign.h>
- C 库 - <stdarg.h>
- C 库 - <stdbool.h>
- C 库 - <stddef.h>
- C 库 - <stdio.h>
- C 库 - <stdlib.h>
- C 库 - <string.h>
- C 库 - <tgmath.h>
- C 库 - <time.h>
- C 库 - <wctype.h>
- C 标准库资源
- C 库 - 快速指南
- C 库 - 有用资源
- C 库 - 讨论
C 库 - va_copy() 宏
C 的stdarg 库 va_copy() 宏用于将一个 va_list 变量(src)的状态复制到另一个(dest)va_list 变量。
在函数返回之前或在 'dest' 使用 va_start 或 va_copy 重新初始化之前,应该对 'dest' 调用 va_end。
当在同一个函数中需要多次迭代同一个参数列表时,此宏非常有用。
语法
以下是 C 库 va_copy() 宏的语法:
void va_copy( va_list dest, va_list src )
参数
此宏接受以下参数:
-
dest - 它表示将接收状态副本的 va_list 变量的一个实例。
src - 它表示要复制的源 va_list 变量。
返回值
此宏不返回任何值。
示例 1:计算总和和平均值
以下是演示 va_copy() 用法的基本 C 示例。
#include <stdio.h>
#include <stdarg.h>
void sum_and_average(int count, ...) {
va_list args, args_copy;
int sum = 0;
// Initialize the va_list
va_start(args, count);
// Make a copy of the va_list
va_copy(args_copy, args);
// Calculate the sum using the original va_list
for (int i = 0; i < count; i++) {
sum += va_arg(args, int);
}
printf("Sum: %d\n", sum);
// Calculate the average using the copied va_list
double average = 0.0;
if (count > 0) {
for (int i = 0; i < count; i++) {
average += va_arg(args_copy, int);
}
average = average/count;
}
printf("Average: %.2f\n", average);
// Clean up both va_list variables
va_end(args);
va_end(args_copy);
}
int main() {
printf("Calculating for 3 numbers:\n");
sum_and_average(3, 10, 20, 30);
printf("\nCalculating for 5 numbers:\n");
sum_and_average(5, 1, 2, 3, 4, 5);
return 0;
}
输出
以下是输出:
Calculating for 3 numbers: Sum: 60 Average: 20.00 Calculating for 5 numbers: Sum: 15 Average: 3.00
示例 2:计算标准差
以下 C 示例使用 va_copy() 将 'src' va_list 复制到 'dest' 并计算标准差。
#include <stdio.h>
#include <stdarg.h>
#include <math.h>
double ComputeMean(int count, ...) {
va_list args1, args2;
va_start(args1, count);
// Make a copy of args1
va_copy(args2, args1);
double sum = 0;
for (int i = 0; i < count; ++i) {
double num = va_arg(args1, double);
sum = sum + num;
}
va_end(args1);
double mean = sum / count;
// calculate standard deviation
// use the copied va_list (args2)
double sum_sq_diff = 0;
for (int i = 0; i < count; ++i) {
double num = va_arg(args2, double);
sum_sq_diff += (num - mean) * (num - mean);
}
va_end(args2);
return sqrt(sum_sq_diff / count);
}
int main() {
printf("Standard deviation: %lf", ComputeMean(4, 1.0, 2.0, 3.0, 4.0));
return 0;
}
输出
以下是输出:
Standard deviation: 1.118034
广告