Chinaunix首页 | 论坛 | 博客
  • 博客访问: 103118328
  • 博文数量: 19283
  • 博客积分: 9968
  • 博客等级: 上将
  • 技术积分: 196062
  • 用 户 组: 普通用户
  • 注册时间: 2007-02-07 14:28
文章分类

全部博文(19283)

文章存档

2011年(1)

2009年(125)

2008年(19094)

2007年(63)

分类: C/C++

2008-04-15 19:05:26

     来源:ChinaITLab    

指向指针的指针,很早以前在说指针的时候说过,但后来发现很多人还是比较难以理解,这一次我们再次仔细说一说指向指针的指针。先看下面的代码,注意看代码中的注解:

#include 
  #include 
  using namespace std;
void print_char(char* array[],int len);
//函数原形声明
void main(void)
{
//---------------------
--------段1----------
char *a[]={"abc","cde","fgh"};
//字符指针数组
char* *b=a;
//定义一个指向指针的指针,
并赋予指针数组首地址所指向的第一个字符串的
地址也就是abc\0字符串的首地址
cout<<*b<<"|"<<*(b+1)
<<"|"<<*(b+2)<
  

结果是

abc
cde
fgh

可以看出每一次内存地址的+1操作事实上是一次加sizeof(char*)的操作,我们在32位的系统中sizeof(char*)的长度是4,所以每加1也就是+4,实际上是*a[]内部三个位置的+1,所以*(b+1)的结果自然就是cde了,我们这时候可能会问,为什么输出是cde而不是c一个呢?答案是这样的,在c++中,输出字符指针就是输出字符串,程序会自动在遇到\0后停止。

我们最后分析一下段2中的代码,段2中我们调用了print_array()这个函数,这个函数中形式参数是char *array[]和代码中的char *test[]一样,同为字符指针,当你把参数传递过来的时候,事实上不是把数组内容传递过来,test的首地址传递了进来,由于array是指针,所以在内存中它在栈区,具有变量一样的性质,可以为左值,所以我们输出写成了:

cout<<*array++<

当然我们也可以改写为:

cout<

这里在循环中的每次加1操作和段1代码总的道理是一样的,注意看下面的图!

到这里这两个非常重要的知识点我们都说完了,说归说,要想透彻理解希望读者多动手,多观察,熟能生巧。下面是内存结构示意图:

阅读(206) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~