为什么我会收到此错误?无法将 {lb, ub} 从<大括号括起来的初始值设定项列表>转换为 float(**)(float*, int)
Why am I getting this error? Could not convert {lb, ub} from <brace-enclosed initializer list> to float(**)(float*, int)
我有一个返回此错误的函数原型。我还收到扩展列表的警告,用于-std=c++11
或-std=gnu++11
float lb(float* data, int y);
float ub (float* data, int y);
float operation(Stats* ptr, float* data, int y, float(*fp[])(float*, int) = {lb, ub});
数组衰减到函数声明中的指针(如果您不通过引用获取它(。你可以做的是将默认值包装在一个常量中,就像这样(请注意,如果你不将其作为额外的参数传递,你会用这种方法丢失数组大小(:
using OperationType = float(*)(float*, int);
constexpr OperationType DefaultOperations[] = {lb, ub};
float operation(Stats* ptr, float* data, int y, const OperationType* fp = DefaultOperations);
如果你总是知道编译时数组的大小,你可以使用这样的std::array
:
using OperationType = float(*)(float*, int);
template <std::size_t Size>
float operation(Stats* ptr, float* data, int y, std::array<OperationType, Size> fp = {lb, ub});
您将[]
视为数组的声明。但在函数参数中,它只声明一个指针。
试试这个:
typedef float(*fp[])(float*, int);
float operation(Stats* ptr, float* data, int y, fp pfp = (fp) {lb, ub});
而不是这种丑陋的语法,你实际上可以使用typedef'd std::functions的向量。它看起来会更好,编译得很好。
#include <functional>
#include <vector>
float lb(float* data, int y) { return 0; }
float ub(float* data, int y) { return 0; }
typedef std::function<float (float*, int)> Func;
float operation(void* ptr, float* data, int y, std::vector<Func> funcs = { lb, ub }) { return 0; }
/* didn't declare stats, so I use void here instead */
int main(int argc, char* argv[])
{
operation(nullptr, nullptr, 0);
return 0;
}
相关文章:
- Pybind11:将元组列表从Python传递到C++
- 从链接列表c++中删除一个项目
- 如何(从固定列表中)选择一个数字序列,该序列将与目标数字相加
- C++如何通过用户输入删除列表元素
- 读取文件的最后一行并输入到链接列表时出错
- 复制列表初始化的隐式转换的等级是多少
- LNK2038、MSVS2017 MAGMA的原因列表
- 不能在初始值设定项列表中将非常量表达式从类型 'int' 缩小到'unsigned long long'
- 没有为自己的结构调用列表推回方法
- 使用简单类型列表实现的指数编译时间.为什么
- 一对向量构造函数:初始值设定项列表与显式构造
- 标准是否使用多余的大括号(例如 T{{{10}}})定义列表初始化?
- 通过for循环使用用户输入填充列表
- C++:如何使函数只返回作为列表一部分的字符串
- 概念中的cv限定符需要表达式参数列表
- 下面是我为检测链接列表中的循环而制作的代码
- 建议在运行时将带有类实例的列表从c++导入qml
- 如何维护资源管理器项目视图中当前可见的项目列表
- 为什么我会收到此错误?无法将 {lb, ub} 从<大括号括起来的初始值设定项列表>转换为 float(**)(float*, int)
- 列表中的double对象和float对象的大小是相等的