定义并初始化一个指针数组,输出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]是字符串的首地址
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 #
}
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]