可以将数字的大括号列表用作传递给可变参数函数(或构造函数)的参数吗?
Can a braced list of numbers be used as an argument passed to a variadic function (or constructor)?
数字 {0x00、0x01、0x02} 的大括号列表可以用作传递给可变参数函数(或构造函数(的参数吗?
在下面的代码中,我可以成功编译并调用它:
BlobClass blob('A', "xyz", 'B', sss, 'C');
但以下内容甚至不编译:
BlobClass blob('A', {0x00, 0x01, 0x02}, 'B', sss , 'C');
有没有办法让它与以下类一起工作?
class BlobClass
{
protected:
unsigned char data[512];
void memcpy_var(unsigned char*) // variadic memcpy terminator
{
}
template <typename... REMAINING>
void memcpy_var(unsigned char* Dest, const std::string& Peeled, const REMAINING&... RemainingArgs){ // variadic memcpy for std strings
size_t TheSize = Peeled.size();
std::memcpy(Dest, Peeled.c_str(), TheSize);
memcpy_var(Dest + TheSize, RemainingArgs...);
}
template <typename... REMAINING>
void memcpy_var(unsigned char* Dest, const char* Peeled, const REMAINING&... RemainingArgs){ // variadic memcpy for C strings
while (*Peeled != 0)
*Dest++ = *Peeled++;
memcpy_var(Dest, RemainingArgs...);
}
template <typename... REMAINING>
void memcpy_var(unsigned char* Dest, const char& Peeled, const REMAINING&... RemainingArgs){ /// variadic memcpy for single Chars
*Dest = Peeled;
memcpy_var(Dest + 1, RemainingArgs...);
}
public:
template<typename... ARGS>
BlobClass(ARGS&&... args) { //Variadic constructor
memcpy_var(&data[0], args...);
}
BlobClass();
}
int main()
{
std::string sss("str");
BlobClass blob('A', "xyz", 'B', sss, 'C'); //This works fine
BlobClass blob('A', {0x00, 0x01, 0x02}, 'B', sss , 'C'); //This does not compile with the error: "no overloaded function takes 5 arguments"
}
我尝试添加以下功能,但它不起作用:
template <typename... REMAINING>
void memcpy_var(unsigned char* Dest, const std::initializer_list<int>& Peeled, const REMAINING&... RemainingArgs){ // variadic memcpy for an entire initialier list
size_t TheSize = sizeof Peeled;
std::memcpy(Dest, &Peeled, TheSize);
memcpy_var(Dest + TheSize, RemainingArgs...);
}
附言我知道这个类有不安全的代码,因为 memcpy_var(( 会溢出数据[512] 缓冲区。 为了简洁起见,我清理了边界检查代码。
当然,但最好的方法是将您的函数专门用于std::initializer_list<T>
,因为我假设您想为这些做一些不同的事情。
可能的实现可能是以下方向
#include <initializer_list>
#include <numeric>
int memcpy_var() {
return 0;
}
template<typename T, typename ... Ts>
int memcpy_var(T val, Ts ...rest) {
return val + memcpy_var(rest...);
}
template<typename T, typename ... Ts>
int memcpy_var(std::initializer_list<T> il, Ts ...rest) {
return std::accumulate(il.begin(), il.end(), 0) + memcpy_var(rest...);
}
int main() {
return memcpy_var({1, 2, 3}, 5);
}
在行动:https://godbolt.org/g/Dx3nsm
相关文章:
- 将可变参数函数的参数封装在类实例中
- QML 使用带有参数C++函数
- 使用可变参数函数作为模板参数
- 如何在C++中伪造虚拟可变参数函数模板?
- 为什么可变参数函数不适用于模板
- C++ std::functional 中的可变参数函数模板
- 可变参数函数指针的定义对于VxWorks spyLib来说不清楚
- 使用可变参数函数覆盖具有不同函数签名的虚函数
- 考虑引用和常量的可变参数函数包装器
- 使用可变参数函数将整数和/或整数数组放入单个 int 数组中
- 在可变参数函数中转发特定范围的参数
- 通过引用传递参数;函数返回类型是否必须为 VOID?
- 使用带有一个参数函数的递归找到数字的平方
- 可变参数函数模板不能很好地使用 std::function 作为参数
- 多个可变参数函数的单个模板参数包?
- 参数数据类型未知的可变参数函数
- 可变参数函数参数包扩展
- 使用模板可变参数函数将多个参数传递给另一个函数
- 对可变参数函数的递归调用的链接器错误
- 通过像printf这样的可变参数函数传递一个带有常量字符*转换函数的类