我需要处理一个数组类型为float64_t或uint32_t的数组.我想创建一个函数,以便以这种方式将指向给定数组的指针作为函数的参数:
void func_name(array_type* ptr_name, int count, data_type x)
//x can be float64_t or uint32_t
Run Code Online (Sandbox Code Playgroud)
如您所见,事先我不知道指针的数据类型.我如何在C++中解决这个问题?
你可以重载函数:
void func(float64_t* ptr, int count);
void func(uint32_t* ptr, int count);
Run Code Online (Sandbox Code Playgroud)
或制作功能模板:
template<typename T>
void func(T* ptr, int count);
Run Code Online (Sandbox Code Playgroud)
数组(和指针)的"数据类型"(原文如此)是其类型的一部分,您不需要做任何特殊的事情.无论您决定采用哪种方法,编译器都会为您确定要调用的函数(或实例化模板时的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
}
Run Code Online (Sandbox Code Playgroud)