我正在尝试使用变量参数列表创建泛型函数.设计的一部分是这些功能中的一些相互调用.不幸的是它似乎不起作用.如您所见,如果您运行下面的简单代码,对command()的调用总是失败,但是直接调用marshal_size()会根据格式字符串"FORMAT_STRING"成功解码两个字符串"FIRST_STR_ARG"和"SECOND_STR_ARG" .
我的推理有什么问题?
示例代码与"g ++ main.cpp"或"gcc main.c"编译良好.
谢谢,
朱尔斯
#include <stdarg.h>
#include <stdio.h>
#include <inttypes.h>
#include <string.h>
#include <stdlib.h>
#define MARSHAL_FORMAT "%s%s"
#define FIRST_STR_ARG "THIS_IS_ARG_ONE"
#define SECOND_STR_ARG "THIS_IS_ARG_TWO"
#define d(msg__, ...) do { printf("%s@%d: "msg__"\n", __FILE__, __LINE__, ## __VA_ARGS__); } while (0)
static uint32_t
marshal_size(const char *format, ...)
{
uint32_t retv = 0;
uint8_t ub;
uint16_t uw;
uint32_t ul;
char *s;
va_list ap;
if (!format || !strlen(format))
return 0;
d("format = %s \n", format);
va_start(ap, format);
for (; '\0' != *format; format++) {
d("*format = %c \n", *format);
if ('%' == *format) {
format++;
if ('u' == *format)
format++;
} else {
d("FORMAT ERROR\n");
continue;
}
d("*format = %c \n", *format);
switch (*format) {
case 's':
s = va_arg(ap, char*);
d("va_arg = %s\n", (s ? s : "NULL"));
if (s)
retv += strlen(s) + 1;
break;
case 'l':
ul = va_arg(ap, uint32_t);
retv += sizeof(uint32_t);
break;
case 'w':
uw = (uint16_t)va_arg(ap, int);
retv += sizeof(uint16_t);
break;
case 'b':
ub = (uint8_t)va_arg(ap, int);
retv += sizeof(uint8_t);
break;
default:
goto exit;
}
continue;
exit:
break;
}
va_end(ap);
return retv;
}
static uint32_t
command(const char * const format,
...)
{
uint32_t retv;
va_list ap;
va_start(ap, format);
retv = marshal_size(format, ap);
va_end(ap);
return retv;
}
int
main(int argc, char *argv)
{
uint32_t size;
size = command(MARSHAL_FORMAT, FIRST_STR_ARG, SECOND_STR_ARG);
d("size = %d", size);
size = marshal_size(MARSHAL_FORMAT, FIRST_STR_ARG, SECOND_STR_ARG);
d("size = %d", size);
return EXIT_SUCCESS;
}
Run Code Online (Sandbox Code Playgroud)