问题描述
最近在关于数组的编程中发现这样一个问题:我想写一个函数模板以实现一个数组的排序,其中数组的大小是不确定的。我最开始的写法是:
// A code block
void sort(T arr[])
{
int len;
len = sizeof(arr) / sizeof(arr[0]);
...}
运行后发现只有数组的第一个元素输出。cout len后发现其值为4,是一个数据的长度。
问题原因
查阅了一些博客和网站后,发现其主要原因是
- sizeof 是在编译的时候求值的,所以不能能够动态的确定一个变量的值。
- 数组作为参数传入函数是以指针的形式(首地址),所以系统是不知道该数组是在哪里截止的,因此不会得到数组的长度,sizeof(arr) / sizeof(arr[0])的输出必然是1
解决方案
博客上说可以使用动态分配内存,使用malloc或者new进行动态管理,可以实现传入数组在函数体内得到其长度。但是由于我还不是特别懂动态分配的内容,所以我采用了第二种方法:将数组的长度作为第二个参数传入函数,即:
//用函数模板实现对n个数据进行从小到大排序,数据类型可以是整型、单精度型、双精度型。
#include <iostream>
#include <string>
using namespace std;
//函数模板实现排序
template <typename T>
void sort(T arr[