- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
我正在尝试创建一个函数,该函数在参数中采用可变数量的矩阵并将这些矩阵乘以第一个。我可以使用 va_arg
读取第一个,但下一次调用 va_arg
将导致访问冲突。
这是我声明方法的方式:
template<class MType>
static CMatrice<MType> COperationsComplexesMatricesPassages::OCPChangementDeBase
(CMatrice<MType> & MATVecteur, unsigned int uiNbMatricesPassages,
CMatricePassage<MType> MAPMatrices...)
我是这样调用它的:
COperationsComplexesMatricesPassages::OCPChangementDeBase(mat1, 2, matP1, matP2)
异常出现在我的方法主体中 for(...)
的第一个 va_arg
上。这是我的方法的代码:
unsigned int uiIndice;
unsigned int uiBaseArriveePrecedente;
va_list args;
va_start(args, MAPMatrices);
CMatrice<MType> MATResult(MATVecteur);
CMatricePassage<MType> MAPMatricePass = va_arg(args, CMatricePassage<MType>);
MATResult = MATResult * MAPMatricePass;
uiBaseArriveePrecedente = MAPMatricePass.MAPGetBaseArrivee();
for (uiIndice = 1; uiIndice < uiNbMatricesPassages; uiIndice++) {
CMatricePassage<MType> MAPMatricePass2 = va_arg(args, CMatricePassage<MType>);
if (uiBaseArriveePrecedente != MAPMatricePass2.MAPGetBaseDepart()) {
CException EXCError(EXC_ChangementImpossible);
throw EXCError;
}
uiBaseArriveePrecedente = MAPMatricePass2.MAPGetBaseArrivee();
MATResult = MATResult * MAPMatricePass2;
}
return MATResult;
最佳答案
我不明白你到底想从你的 OCPChangementDeBase()
得到什么方法,无论如何......也许我错了......但在我看来,关于可变参数函数,有几个重要的点你不知道。
(1) 旧的 C 变量语法
void foo (int a, int b...)
并不意味着 b
是整数的可变列表。
该声明等同于(最后一个逗号是可选的)
void foo (int a, int b, ...)
所以,对于这两个声明,您有一个 b
整数(单个 b
整数)和可变参数的未命名列表。
所以给你方法
template<class MType>
static CMatrice<MType>
COperationsComplexesMatricesPassages::OCPChangementDeBase
(CMatrice<MType> & MATVecteur, unsigned int uiNbMatricesPassages,
CMatricePassage<MType> MAPMatrices...)
并调用它
COperationsComplexesMatricesPassages::OCPChangementDeBase(mat1, 2, matP1, matP2)
你有那个
MATVecteur
成为mat1
uiNbMatricesPassages
成为2
MAPMatrices
成为matP1
...
成为matP2
因此,如果您期望在未命名的可变参数列表中有两个参数,那么您只有一个,我对“下一次调用 va_arg 将导致访问冲突”并不感到惊讶。
(2) 旧的 C 可变参数语法(基于 va_list
、va_arg
、va_start
)在 C++ 中仍然可用,但据我所知,它仅适用于 POD(普通旧数据)类型。
因此,据我所知,您的代码是 UB(未定义的行为),因为 matP2
(我想)不是 POD。
幸运的是,C++(从 C++11 开始)引入了与非 POD 类型兼容的可变参数模板。
所以,我想,你算把你的方法写成如下或类似的东西
template <typename MType, typename ... MTs>
static auto COperationsComplexesMatricesPassages::OCPChangementDeBase
(CMatrice<MType> & MATVecteur, MTs ... MAPMatrices)
{
auto MatResult { MatVectour };
( MatResult *= MapMatrices, ... ); // template folding; only from C++17
return MatResult;
}
您还可以添加一些约束(查找 SFINAE)来强加 MTs...
类型完全是(或者,也许更好,可转换为)CMatricePassage<MType>
(或其他类型,如果需要的话)。
关于c++ - va_arg 上的访问冲突,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/56405996/
我有以下函数将传递的参数写入二进制文件。 void writeFile(FILE *fp, const int numOfChars, ...) { va_list ap; va_star
我正在制作一个类似于 printf 的函数,它需要接受一个字符串和参数,例如: form("整数 %d, 字符串 %s", 54, "STRING"); 并创建一个字符串“Integer 54,Str
为什么下面的代码给出EXC_BAD_ACCESS, could not access memory ? int combine_strings(char **outputStr,...) {
我的打印函数使用 va_arg 函数打印随机字符。我不明白为什么它不起作用。提前感谢您的帮助! #include #include #include int myprint(const char
在 main.c 中,我调用 function(2, "string", "yes") 哪里 void function(UINT16 id, const char *ptr_argDescr,
我想用这种方式编写一个带有可变参数的函数: static void configElement(U32 localFaultId, char* na
我正在研究可变函数和参数。 我注意到 va_arg 能够将对象转换为其他对象。例如,当下一个参数是 char 时,但您正在使用 va_arg 就像它应该是 int 一样,它会转换 char 到 int
我可以将类型转换为 va_arg 返回示例吗?据我所知,va_arg 无法读取返回 char/short int 类型 if (flags->size == 0) u->s = (char)v
我正在尝试编写一个带有格式字符串和一些可变数字参数的小函数。格式字符串采用表示不同数字类型的各种字符(c 表示 char,i 表示 int,d 表示 double 等),然后字符串中的每个字符采用该类
我是第一次尝试编写自己的 va_args 函数,但我遇到了一个问题,即大整数(仍在 int 范围内)被截断为 3 位数字,并且乱序! 这里是实现 void __sprintf(char * _stri
如果我调用 va_arg 的次数少于可变参数函数中传递的参数数量,是否会出现未定义的行为? 例如: #include void foo(unsigned n, ...) { va_list
全部, 我正在编写一个小型 C++ 应用程序,但一直被这个问题难倒。如果元素类型不是预期的,是否有一种方法可以在使用 va_arg 从 va_list 宏访问元素时创建(并稍后捕获)错误。例如:- c
使用以下代码,va_arg 将在第二次和第三次通过 vProcessType 时返回垃圾。 // va_list_test.cpp : Defines the entry point for the
我正在尝试创建一个函数,该函数在参数中采用可变数量的矩阵并将这些矩阵乘以第一个。我可以使用 va_arg 读取第一个,但下一次调用 va_arg 将导致访问冲突。 这是我声明方法的方式: templa
我做了一个简单的测试用例: static void va_test(char* str_arg, ...) { va_list ap; va_start(ap, str_arg); for
我想像这样用指针参数初始化一个链表: /* * Initialize a linked list using variadic arguments * Returns the number of
mystruct_t v = va_arg(a_list, mystruct_t); 就 C 规范而言,这可以吗(使用大于等于 int 大小的自定义数据类型)? 最佳答案 C 标准中没有关于将结构类型
我正在阅读一个 stdarg.h(下面的链接)头文件,它定义了 va_arg 宏,如下所示 /* * Increment ap to the next argument in the list wh
我知道如果我将像 void (*func)(void *) 这样的参数传递给可变参数函数,我可以像这样检索参数: void (*func)(void *) = va_arg( args, void (
这个问题不太可能对任何 future 的访客有帮助;它只与一个小的地理区域、一个特定的时间点或一个非常狭窄的情况相关,通常不适用于互联网的全局受众。如需帮助使这个问题更广泛适用,visit the h
我是一名优秀的程序员,十分优秀!