我需要处理一个数据类型为 float64_t 或 uint32_t 的数组。我想创建一个函数,以便可以通过这种方式将指向给定数组的指针作为函数的参数:
void func_name(array_type* ptr_name, int count, data_type x)
//x can be float64_t or uint32_t
如您所见,事先我不知道指针的数据类型。我如何在 C++ 中解决这个问题?
最佳答案
你可以重载函数:
void func(float64_t* ptr, int count);
void func(uint32_t* ptr, int count);
或者做一个函数模板:
template<typename T>
void func(T* ptr, int count);
数组(和指针)的“数据类型”(原文如此)是其类型的一部分,您不需要做任何特殊的事情。无论您决定采用哪种方法,编译器都会为您确定调用哪个函数(或者在实例化模板时 T 是什么)。
template<typename T>
void func(T* ptr, int count) { }
int main()
{
float f_arr[42] = {};
int i_arr[84] = {};
func(f_arr, 42); // instantiates func with T = float
func(i_arr, 84); // instantiates func with T = int
}
关于c++ - 将指针及其数据类型作为参数,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/22325519/