下面的函数是用于测试,改变子函数中数组的数值,是否会改变主函数的值的两种方法。
#include<iostream>
#include<cstdio>
using namespace std;
//下面用的是冒泡排序方法,利用指针的方式传值
void insertsortnew(int *p, int n)
{
int j = 0;//下标为0的用于临时存储的变量
int tmp = 0;
for (int i = 2; i < n+1; i++)
{
if (*(p+i) < *(p+i-1))//找到较小的值
{
tmp = *(p + i);
//从前到后进行从小到达的排序
for (j = i - 1; tmp < *(p + j); j--)
{
*(p + j + 1) = *(p + j);
}
*(p + j + 1) = tmp;
}
}
for (int i = 1; i < n + 1; i++)
{
cout << *(p + i) << endl;
}
}
//下面用的是冒泡排序方法,直接使用数组传值
void insertsort(int arr[], int n)
{
int j = 0;//下标为0的用于临时存储的变量
for (int i = 2; i < n+1; i++)
{
if (arr[i] < arr[i - 1])//找到较小的值
{
arr[0] = arr[i];
//从前到后进行从小到达的排序
for (j = i - 1; arr[0] < arr[j]; j--)
{
arr[j + 1] = arr[j];
}
arr[j + 1] = arr[0];
}
}
}
int main(){
int n, a; //n代表输入参数的个数
int A[100];
cin >> n ;
cout << n << endl;
int tmp = 0;
while (tmp<n)
{
int x; scanf_s("%d", &x);
A[tmp+1] = x;
tmp++;
}
int B[10];
//这里创建一个新的数组,备份A数组的值
for (int i = 0; i < n + 1;i++)
{
B[i] = A[i];
}
cout << "用指针方式进行传值" << endl;
insertsortnew(A, n);
cout << "直接传递数组" << endl;
insertsort(B, n);
for (int i = 1; i < n+1; i++)
{
cout << B[i] << endl;
}
system("pause");
return 0;
}
总结:虽然上述两种方法都可以改变主函数中数组的值,但是采用指针的方式不需要在子函数中copy新的数组,效率会比较高一些。
从结果可以看出,两种方法都改变了主函数中数组的值。但是我们还是要区分一下数组和指针:
1、数组不是指针,数组中有数组长度信息,指针没有;
2、作为函数参数时,数组会被看成指针。