C 指向数组的指针

组名本身是一个常量指针,意味着它的值是不能被改变的,一旦确定,就不能再指向其他地方。

因此,在下面的声明中:

c 复制代码
double balance[50];

balance 是一个指向 &balance[0] 的指针,即数组 balance 的第一个元素的地址。因此,下面的程序片段把 p 赋值为 balance 的第一个元素的地址:

c 复制代码
double *p;
double balance[10];

p = balance;

使用数组名作为常量指针是合法的,反之亦然。因此,*(balance + 4) 是一种访问 balance[4] 数据的合法方式。

一旦您把第一个元素的地址存储在 p 中,您就可以使用 p、(p+1)、*(p+2) 等来访问数组元素。下面的实例演示了上面讨论到的这些概念:

c 复制代码
#include <stdio.h>
 
int main ()
{
   /* 带有 5 个元素的整型数组 */
   double balance[5] = {1000.0, 2.0, 3.4, 17.0, 50.0};
   double *p;
   int i;
 
   p = balance;
 
   /* 输出数组中每个元素的值 */
   printf( "使用指针的数组值\n");
   for ( i = 0; i < 5; i++ )
   {
       printf("*(p + %d) : %f\n",  i, *(p + i) );
   }
 
   printf( "使用 balance 作为地址的数组值\n");
   for ( i = 0; i < 5; i++ )
   {
       printf("*(balance + %d) : %f\n",  i, *(balance + i) );
   }
 
   return 0;
}

当上面的代码被编译和执行时,它会产生下列结果:

c 复制代码
使用指针的数组值
*(p + 0) : 1000.000000
*(p + 1) : 2.000000
*(p + 2) : 3.400000
*(p + 3) : 17.000000
*(p + 4) : 50.000000
使用 balance 作为地址的数组值
*(balance + 0) : 1000.000000
*(balance + 1) : 2.000000
*(balance + 2) : 3.400000
*(balance + 3) : 17.000000
*(balance + 4) : 50.000000

在上面的实例中,p 是一个指向 double 型的指针,这意味着它可以存储一个 double 类型的变量。一旦我们有了 p 中的地址,*p 将给出存储在 p 中相应地址的值,正如上面实例中所演示的。

相关推荐
代码程序猿RIP3 分钟前
【Linux面经】OSI七层模型和TCP/IP四层体系结构
linux·网络·面试·面经
不穿格子的程序员4 分钟前
从零开始刷算法-二分-搜索插入位置
算法·二分查找
我什么都学不会6 分钟前
DNS主从服务器练习
linux·运维·服务器
zhugby33 分钟前
受限长度路径搜索算法
经验分享·算法·启发式算法·哈密顿问题·路径搜索算法
芋头莎莎41 分钟前
STM32利用AES加密数据、解密数据
数据结构·stm32·算法
caron41 小时前
c++ -- 循环依赖解决方案
java·c++·算法
不会kao代码的小王1 小时前
零基础也能搭博客?
linux·windows·后端
Kt&Rs1 小时前
11.11 LeetCode 题目汇总与解题思路
算法·leetcode·哈希算法
py有趣1 小时前
LeetCode算法学习之有效的字母异位词
学习·算法·leetcode
Learn Beyond Limits1 小时前
Clustering vs Classification|聚类vs分类
人工智能·算法·机器学习·ai·分类·数据挖掘·聚类