从0开始学习C++ 第十课:指针与数组关系及指针偏移量

第十课:指针与数组关系及指针偏移量

学习目标:

  • 理解数组名作为指针的本质。
  • 学会使用指针进行数组索引。
  • 掌握通过指针偏移量访问数组元素的方法。

学习内容:

  1. 数组名作为指针

    • 概念: 在C++中,数组名代表的是数组首元素的地址,它可以被视为指向该类型的指针。
    • 代码示例:
      #include <iostream>
      
      int main() {
          int numbers[] = {5, 10, 15};
          int* p = numbers; // 'p' 现在指向数组的第一个元素
      
          std::cout << "First element: " << *p; // 解引用指针访问第一个元素
          return 0;
      }
      
    • 预计输出效果:
      First element: 5
      
    • 使用场景: 当需要直接通过内存地址访问数组元素时,可以使用数组名作为指针。
  2. 使用指针进行数组索引

    • 概念: 指针加上一个整数会产生一个新的指针,该指针指向原来指针指向元素的后面第n个元素的位置。
    • 代码示例:
      #include <iostream>
      
      int main() {
          int numbers[] = {5, 10, 15};
          int* p = numbers;
      
          std::cout << "Second element: " << *(p + 1); // 使用指针偏移访问第二个元素
          return 0;
      }
      
    • 预计输出效果:
      Second element: 10
      
    • 使用场景: 当需要遍历一个数组,但不想用数组索引时,可以使用指针偏移来访问。
  3. 指针偏移量访问数组元素

    • 概念: 对指针进行加法或减法运算,可以移动指针在数组中的位置,这称为指针偏移。
    • 代码示例:
      #include <iostream>
      
      int main() {
          int numbers[] = {5, 10, 15, 20, 25};
          int* p = numbers;
      
          for (int i = 0; i < 5; ++i) {
              std::cout << "Element at position " << i << ": " << *(p + i) << std::endl;
          }
          return 0;
      }
      
    • 预计输出效果:
      Element at position 0: 5
      Element at position 1: 10
      Element at position 2: 15
      Element at position 3: 20
      Element at position 4: 25
      
    • 使用场景: 当需要在数组中移动到不同的元素位置,可以使用指针偏移来简化代码。

练习题: 编写一个C++程序,定义一个整型数组包含5个元素。使用指针变量遍历这个数组,并打印出每个元素的地址和值。

答案:

#include <iostream>

int main() {
    int numbers[] = {10, 20, 30, 40, 50};
    int* p = numbers; // 指针指向数组的第一个元素

    for (int i = 0; i < 5; ++i) {
        std::cout << "Address of element " << i << ": " << (p + i) << std::endl;
        std::cout << "Value of element " << i << ": " << *(p + i) << std::endl;
    }

    return 0;
}

预计输出效果:

Address of element 0: [address]
Value of element 0: 10
Address of element 1: [address]
Value of element 1: 20
Address of element 2: [address]
Value of element 2: 30
Address of element 3: [address]
Value of element 3: 40
Address of element 4: [address]
Value of element 4: 50

*注:实际输出的地址会依据系统和运行环境不同而有所不同。

使用场景: 适用于需要检查数组中各个元素的内存布局,或者是进行底层内存操作的情况。

目录
第十一课:常量

  • 8
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
C++ 中,我们可以使用二维数组指针来表示一个二维数组。 1. 二维数组 二维数组是一个由多个一维数组组成的数组。它可以看做是一个表格,其中每个元素都有两个下标,表示在表格中的行和列。定义一个二维数组可以使用以下语法: ```c++ int arr[n][m]; // 定义一个 n 行 m 列的二维数组 ``` 其中,n 和 m 分别表示二维数组的行数和列数。我们可以使用两层循环来遍历二维数组: ```c++ for(int i = 0; i < n; i++) { for(int j = 0; j < m; j++) { // 处理 arr[i][j] } } ``` 2. 指针 指针是一个变量,它存储了一个地址,这个地址指向了内存中的一个位置。我们可以使用指针来访问这个位置的值。定义一个指针可以使用以下语法: ```c++ int *ptr; // 定义一个指向 int 类型变量的指针 ``` 我们可以使用指针来访问一个变量的值: ```c++ int a = 10; int *ptr = &a; // 将指针 ptr 指向变量 a 的地址 cout << *ptr; // 输出变量 a 的值 10 ``` 3. 二维数组指针关系 二维数组在内存中是连续存储的,我们可以使用指针来访问二维数组中的元素。定义一个指向二维数组指针可以使用以下语法: ```c++ int (*ptr)[m]; // 定义一个指向 n 行 m 列的二维数组指针 ``` 其中,括号是必须的,因为 `*` 的优先级比 `[]` 低。我们可以使用指针来遍历二维数组: ```c++ int arr[n][m]; int (*ptr)[m] = arr; // 将指针 ptr 指向二维数组 arr 的首地址 for(int i = 0; i < n; i++) { for(int j = 0; j < m; j++) { // 处理 ptr[i][j] cout << ptr[i][j] << " "; } cout << endl; } ``` 上述代码中,`ptr[i][j]` 实际上等价于 `*(*(ptr + i) + j)`,即指针加上偏移量再取值。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值