C 库 - va_copy() 宏



C 的stdargva_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
广告

© . All rights reserved.