3 CPP一维数组用于函数的参数

1)指针的数组表示

在C++内部,用指针来处理数组。

C++编译器把 数组名[下标] 解释为 *(数组首地址+下标)

C++编译器把 地址[下标] 解释为 *(地址+下标)

#include "iostream"
using namespace std;

void test()
{
    int a[5] = {1, 2, 3, 4, 5};
    //用数组表示法操作数组
    for (int i = 0; i < 5; i++)
    {
        cout << "a[" << i << "]=" << a[i] << endl;
    }
    //用指针表示法操作数组
    int *p = a;
    for (int i = 0; i < 5; i++)
    {
        //数组名[下标] 解释为 *(数组首地址+下标)
        cout << "*(p+" << i << ")value is:" << *(p + i) << endl;
        //地址[下标] 解释为 *(地址+下标)
        cout << "p[" << i << "]  value is:" << p[i] << endl;
    }
}
int main()
{
    test();
    return 0;
}
a[0]=1
a[1]=2
a[2]=3
a[3]=4
a[4]=5
*(p+0)value is:1
p[0]  value is:1
*(p+1)value is:2
p[1]  value is:2
*(p+2)value is:3
p[2]  value is:3
*(p+3)value is:4
p[3]  value is:4
*(p+4)value is:5
p[4]  value is:5

 

可以这么理解

int a[5] = {1, 2, 3, 4, 5};这里的a就是个地址,能都a[i]这样访问。

这样可以的话,那p是地址,p[i]应该也可以访问。

这里不要把p理解为数组,用这句话来解释就行(地址[下标] 解释为 *(地址+下标))

#include "iostream"
using namespace std;

void test()
{
    int a[5] = {1, 2, 3, 4, 5};
    //用数组表示法操作数组
    for (int i = 0; i < 5; i++)
    {
        cout << "a[" << i << "]=" << a[i] << endl;
    }
    //骚操作 1
    cout << a[2] << endl;       // 3
    cout << &a[2] << endl;      // 0x61fdd8  是一个地址
    cout << (&a[2]) << endl;    // 0x61fdd8  是一个地址
    cout << (&a[2])[0] << endl; // 3   第二个元素的地址[0] 被解释为 *(第二个元素地址+0)
    cout << (&a[2])[1] << endl; // 4   第二个元素的地址[1] 被解释为 *(第二个元素地址+1)
    cout << (&a[2])[2] << endl; // 5   第二个元素的地址[2] 被解释为 *(第二个元素地址+2)

    //骚操作 2
    char ch[20];          // char占1个字节 20个元素就是20个字节
    int *cp = (int *)&ch; // int占4个字节 20个字节也就是能放5个int元素
    for (int i = 0; i < 5; i++)
    {
        cp[i] = i + 100;
    }
    for (int i = 0; i < 5; i++)
    {
        cout << "*(cp+" << i << ") value is " << *(cp + i) << endl;
    }
    //上面代码,内存空间本质就是一块存储空间,对C++来说,操作内存的时候,变量的数据类型决定了操作内存的方法,
    //一般来说声明变量的时候,指定数据类型就是指定了操作内存的方法,但是我们也可以中途修改操作内存的方法.
    //上面的例子,声明ch数组的时候,申请了一块20字节的内存,本来打算存放字符型数据,后来,把这20个字节挪用了,改为
    //存放整型数据,这种需求完全合理
    //上面实例,可以让我们对内存/指针和数组有更深的认识
}
int main()
{
    test();
    return 0;
}
a[0]=1
a[1]=2
a[2]=3
a[3]=4
a[4]=5
3
0x61fdc8
0x61fdc8
3
4
5
*(cp+0) value is 100
*(cp+1) value is 101
*(cp+2) value is 102
*(cp+3) value is 103
*(cp+4) value is 104
*(cp+5) value is 0

2)一维数组用于函数的参数

一维数组用于函数的参数时,只能传输组的地址,并且必须把数组长度传进去(刚开始学习的时候,这里我不太理解,大部分语言,都不需要传)除非数组中有最后一个元素的标志。

书写方法有两种:

void func(int * arr,int len);

void func(int arr[],int len);

注意:

在函数中,可以用数组表示法,也可以用指针表示法。

在函数中,不要对指针名用sizeof运算符,它不是函数名。

下面是<<C++ Primer Plus>>中的原话

 

#include "iostream"
using namespace std;

void wrongFunc(int arr[])
{
    for (int i = 0; i < sizeof(arr) / sizeof(int); i++)
    {
        cout << arr[i] << " ";
    }
    cout << endl;
}
void func(int *arr, int len)
{
    for (int i = 0; i < len; i++)
    {
        cout << arr[i] << " ";
    }
    cout << endl;
}
void test()
{
    int a[5] = {1, 2, 3, 4, 5};
    func(a, 5);
    wrongFunc(a);
}
int main()
{
    test();
    return 0;
}

main.cpp: In function 'void wrongFunc(int*)':
main.cpp:6:35: warning: 'sizeof' on array function parameter 'arr' will return size of 'int*' [-Wsizeof-array-argument]
     for (int i = 0; i < sizeof(arr) / sizeof(int); i++)
                                   ^
main.cpp:4:20: note: declared here
 void wrongFunc(int arr[])
                ~~~~^~~~~
1 2 3 4 5 
1 2 

上面代码,一个是传了长度,一个是没有传长度,没有传数组长度的,编译的时候有上面的提示

被认为是int* 在64位操作系统下,也就是8个字节,然后除以int类型占用的4个字节,也就是2,所以打印出来1 和 2

#include "iostream"
using namespace std;

void wrongFunc(int arr[])
{
    cout << "sizeof(arr)=" << sizeof(arr) << endl;
    for (int i = 0; i < sizeof(arr) / sizeof(int); i++)
    {
        cout << arr[i] << " ";
    }
    cout << endl;
}
void func(int *arr, int len)
{
    for (int i = 0; i < len; i++)
    {
        cout << arr[i] << " ";
    }
    cout << endl;
}
void test()
{
    int a[5] = {1, 2, 3, 4, 5};
    cout << "sizeof(a)=" << sizeof(a) << endl;
    func(a, 5);
    wrongFunc(a);
}
int main()
{
    test();
    return 0;
}
main.cpp: In function 'void wrongFunc(int*)':
main.cpp:6:41: warning: 'sizeof' on array function parameter 'arr' will return size of 'int*' [-Wsizeof-array-argument]
     cout << "sizeof(arr)=" << sizeof(arr) << endl;
                                         ^
main.cpp:4:20: note: declared here
 void wrongFunc(int arr[])
                ~~~~^~~~~
main.cpp:7:35: warning: 'sizeof' on array function parameter 'arr' will return size of 'int*' [-Wsizeof-array-argument]
     for (int i = 0; i < sizeof(arr) / sizeof(int); i++)
                                   ^
main.cpp:4:20: note: declared here
 void wrongFunc(int arr[])
                ~~~~^~~~~
sizeof(a)=20
1 2 3 4 5 
sizeof(arr)=8
1 2

可以看到,在test函数中,a是数组名,对数组名用sizeof运算不会把它解析为 地址,sizeof返回的是整个数组a占用的内存空间的大小。

在wrongFunc函数中,arr是指针,堆指针用sizeof运算返回的结果是8(64位操作系统)

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值