当前位置: 首页 > news >正文

指针数组和指向指针的指针

一、指针数组的概念

如果一个数组,其元素均为指针类型数据,该数组称为指针数组,也就是说,指针数组中的每一个元素相当于一个指针变量,它的值都是地址。一维指针数组的定义形式为
   类型名*数组名[数组长度];

例如
int *p[4];
可以用指针数组中各个元素分别指向若干个字符串,使字符串处理更加方便灵活。

例6.15 若干字符串按字母顺序(由小到大)输出。
#include <iostream>
using namespace std;
int main( )
{
   void sort(char *name[],int n);                //声明函数
   void print(char *name[],int n);               //声明函数
   char *name[]={″BASIC″,″FORTRAN″,″C++″,″Pascal″,″COBOL″};  //定义指针数组
   int n=5;
   sort(name,n);
   print(name,n);
   return 0;
}
void sort(char *name[],int n)
{
   char *temp;
   int i,j,k;
   for(i=0;i<n-1;i++)
   {
      k=i;
      for(j=i+1;j<n;j++)
         if(strcmp(name[k],name[j])>0) k=j;
         if(k!=i)
            { temp=name[i];name[i]=name[k];name[k]=temp;}
   }
}

void print(char *name[],int n)
{
   int i;
   for(i=0;i<n;i++)
      cout<<name[i]<<endl;
}
运行结果为
BASIC
COBOL
C++
FORTRAN
Pascal



图6.21                        图6.22


print函数的作用是输出各字符串。name[0]~name[4]分别是各字符串的首地址。print函数也可改写为以下形式:
void print(char *name[],int n)
{
   int i=0
   char *p;
   p=name[0];
   while(i<n)
   {
      p=*(name+i++);
      cout<<p<<endl;
   }
}
其中“*(name+i++)”表示先求*(name+i)的值,即name[i](它是一个地址)。将它赋给p,然后i加1。最后输出以p地址开始的字符串。

二、指向指针的指针

在掌握了指针数组的概念的基础上,下面介绍指向指针数据的指针,简称为指向指针的指针。从图6.22可以看到,name是一个指针数组,它的每一个元素是一个指针型数据(其值为地址),分别指向不同的字符串。数组名name代表该指针数组首元素的地址。name+i是name[i]的地址。由于name[i]的值是地址(即指针),因此name+i就是指向指针型数据的指针。还可以设置一个指针变量p,它指向指针数组的元素(见图6.23)。p就是指向指针型数据的指针变量。


图6.23


怎样定义一个指向指针数据的指针变量呢?如下:
   char *(*p);
从附录B可以知道,*运算符的结合性是从右到左,因此“char *(*p);”可写成
   char **p;

例6.16 指向字符型数据的指针变量。
#include <iostream>
using namespace std;
int main( )
{
   char **p;                //定义指向字符指针数据的指针变量p
   char *name[]={″BASIC″,″FORTRAN″,″C++″,″Pascal″,″COBOL″};
   p=name+2;                //见图6.23中p的指向
   cout<<*p<<endl;          //输出name[2]指向的字符串
   cout<<**p<<endl;         //输出name[2]指向的字符串中的第一个字符
}
运行结果为
C++
C
指针数组的元素也可以不指向字符串,而指向整型数据或单精度型数据等。

在本章开头已经提到了“间接访问”一个变量的方式。利用指针变量访问另一个变量就是“间接访问”。如果在一个指针变量中存放一个目标变量的地址,这就是“单级间址”,见图6.24(a)。指向指针的指针用的是“二级间址”方法。见图6.24(b)。从理论上说,间址方法可以延伸到更多的级,见图6.24(c)。但实际上在程序中很少有超过二级间址的。


图6.24

转载于:https://www.cnblogs.com/Xiegg/p/3661067.html

相关文章:

  • 破碎吧,
  • Permission denied You (root) are not allowed to access to (crontab) because of pam configuration.
  • PAT 1064
  • 最大堆最小堆总结
  • Windows Server 2012 R2工作文件夹⑨:自动发现设置
  • linux下ntp时间服务器搭建
  • 5.10-17项目经理考试圆梦提分现场面授行动
  • 长文章手动分页显示代码
  • 【高德地图API】从零开始学高德JS API(一)地图展现——仙剑地图,麻点图,街景,室内图...
  • MQ:Introducing Advanced Messaging
  • Git详解之三 Git分支(第二部分)
  • [转]oracle 同义词 synonym
  • 编写一个简单的Jquery插件
  • XSS零碎指南
  • 自定义标签例子
  • 收藏网友的 源程序下载网
  • ECMAScript6(0):ES6简明参考手册
  • es6
  • HTML-表单
  • Iterator 和 for...of 循环
  • JavaScript工作原理(五):深入了解WebSockets,HTTP/2和SSE,以及如何选择
  • Laravel Mix运行时关于es2015报错解决方案
  • Netty+SpringBoot+FastDFS+Html5实现聊天App(六)
  • PyCharm搭建GO开发环境(GO语言学习第1课)
  • python 学习笔记 - Queue Pipes,进程间通讯
  • quasar-framework cnodejs社区
  • Spring Cloud(3) - 服务治理: Spring Cloud Eureka
  • 不上全站https的网站你们就等着被恶心死吧
  • 缓存与缓冲
  • 基于 Ueditor 的现代化编辑器 Neditor 1.5.4 发布
  • 前端_面试
  • 为物联网而生:高性能时间序列数据库HiTSDB商业化首发!
  • 系统认识JavaScript正则表达式
  • 一些css基础学习笔记
  • 优秀架构师必须掌握的架构思维
  • # Python csv、xlsx、json、二进制(MP3) 文件读写基本使用
  • #Linux(权限管理)
  • #控制台大学课堂点名问题_课堂随机点名
  • (1)常见O(n^2)排序算法解析
  • (二)基于wpr_simulation 的Ros机器人运动控制,gazebo仿真
  • (附源码)springboot学生选课系统 毕业设计 612555
  • (欧拉)openEuler系统添加网卡文件配置流程、(欧拉)openEuler系统手动配置ipv6地址流程、(欧拉)openEuler系统网络管理说明
  • (十六)一篇文章学会Java的常用API
  • (十五)使用Nexus创建Maven私服
  • (四)搭建容器云管理平台笔记—安装ETCD(不使用证书)
  • (转)Android学习笔记 --- android任务栈和启动模式
  • (转)程序员技术练级攻略
  • (自用)learnOpenGL学习总结-高级OpenGL-抗锯齿
  • ***linux下安装xampp,XAMPP目录结构(阿里云安装xampp)
  • .babyk勒索病毒解析:恶意更新如何威胁您的数据安全
  • .NET 4.0中的泛型协变和反变
  • .NET MVC 验证码
  • .Net Web窗口页属性
  • .NET/C# 异常处理:写一个空的 try 块代码,而把重要代码写到 finally 中(Constrained Execution Regions)
  • .NET企业级应用架构设计系列之开场白