C++指针数组不同格式的输出含义?

定义并初始化一个指针数组,输出p[i]不应该是地址量吗,反而输出了指针数组的元素;*p[i]输出的为元素的第一个字符可以理解为指针指向数组的首地址;&p[i]输出的是好像才是地址量,这三个有点分不清楚,是因为指针数组的相关定义不一样吗?


#include <iostream>
using namespace std;


int main()
{
    const char *p[5] = { "abc","def","ghi","jkl","mno"};
    cout << "初始化输出字符串:" << endl;
    for (int i = 0; i < 5; i++)
    {
        cout << *p[i] << endl;
        cout << &p[i] << endl;
        cout << p[i] << endl;
    }
    return 0;
}



初始化输出字符串:
a
00D7FBB0
abc
d
00D7FBB4
def
g
00D7FBB8
ghi
j
00D7FBBC
jkl
m
00D7FBC0
mno


#include <iostream>
using namespace std;


int main()
{
    const char *p[5] = { "abc","def","ghi","jkl","mno" };
    cout << "初始化输出字符串:" << endl;
    for (int i = 0; i < 5; i++)
    {
        cout << *p[i] << endl; // 数组的第一个字符
        cout << &p[i] << endl; // 数组的整块地址,如"abc" 的地址
        cout << p[i] << endl; // 数组地址,输出遇到 \0结束
    }
    return 0;
}

p[i]是字符串,*p[i]是字符串的某个字符,&p[i]是字符串的首地址

img


大概这种感觉

char buf[10] = "abcde";
cout << but << endl;
这段代码输出什么?是不是输出abced
buf也相当于一个char *类型啊,为什么不输出地址呢?
这说明,cout在打印char*类型的时候,相当于C中printf("%s",buf);


你把char类型换成int看看打印什么东西。

int* p[5];
    int a[5] = {1,2,3,4,5};
    for(int i = 0;i<5;i++)
        p[i] = &a[i];
    cout << "初始化输出字符串:" << endl;
    for (int i = 0; i < 5; i++)
    {
        cout << *p[i] << endl;
        cout << &p[i] << endl;
        cout << p[i] << endl;
    }

以你程序中的 const char *p[5] = { "abc","def","ghi","jkl","mno"}; 这个为例
这个p相当于一个二级指针变量, p[0]: 这个表示“abc”这个字符串的首地址, *p[0]表示字符‘a’, &p[0]这个还是首地址和p(p[0])的值是一样的
p[1]: 这个表示“def”这个字符串的首地址, *p[1]表示字符‘d’, &p[1] 这个是"def"的首地址和p[1]的值是一样的

p --> | a | b | c | /0 | /0 |
p[1] | d | e | f | /0 | /0 |
p[2] | g | h | i | /0 | /0 |
| j | k | l | /0 | /0 |
| m | n | o| /0 | /0 |

理解和讨论之前请先学会如何观察。
参考下面:

//char (*(*x[3])())[5];//x是什么类型的变量?
//
//分析C语言声明,关键是搞清楚这个变量是个什么东西(函数、指针、数组),
//是函数那么剩下的就是他的参数和返回值,
//是指针那剩下部分是说明他指向什么,
//是数组剩下的部分就是说明数组的成员是什么类型。
//解析C语言声明规则:
//从左侧第一个标识符开始,按照优先级进行结合。*表示是..的指针,const表示只读的,volatile表示可变的,[]表示是数组,()表示是函数。
//
//x和[3]结合说明是一个大小为3的数组,该数组的每个元素为一类指针,该类指针指向一类函数,该类函数无参数,返回一类指针,该类指针指向一个大小为5的char型数组
#include <stdio.h>
#include <typeinfo.h>
char num[5];
char (*x00())[5] {
    return &num;
}
int main() {
    char (*(*x[3])())[5];//是个数组,大小为3
    char (*(*x0  )())[5];//数组的元素,是个函数指针
    char (*( x00 )())[5];//函数原型,参数为空,返回值为指针
    char (*  x000   )[5];//返回值

    x0 = x00;
    x[0] = x0;
    x[1] = x0;
    x[2] = x0;
    printf("typeid(x).name() is %s\n",typeid(x).name());
    return 0;
}
//typeid(x).name() is char (* (__cdecl**)(void))[5]