深入理解const char*p,char const*p,char *const p,const char **p,char const**p,char *const*p,char**const p
2013-09-26 20:55
417 查看
char *const p;与 const char * p;的区别
1)前者定义P为常量,即只能单向赋值一次,P++展开为p=p+1,重复赋值给常量,出错,
例:char *const name1="John";
name1="abc"; //错误,name1指针,不能变,一个指针类型的变量,存放的是地址,所以不能把'"abc"的地址赋给name1
char * name2= name1; //可以
2)后者P为地址变量,地址变量是指向该变量的存储地址值如:4B3F6A,不能赋给一个字符值(字符相当于ascii表中对应的整数)如强制赋值,会把原地址变量P变为一个两位数的整数,造成地址指针溢出。而p++,则表示把该地址变量向下一个存储单元移动一位,如4B3F6A到4B3F6B.所以合法
const char* p : 定义一个指向字符常数的指针
char const* p : 等同于const char* p
const char * p;
p is pointer to const char;
例:const char *name1="John";
char s[]="abc"; name1=s; //正确,name1存放的地址可以改变
char * name2= name1; //不可以,因为name2 和 name1存放的是同一块地址,如果name2地址中的内容改了,则name1的内容也改了,那么name1就不再是指向常量的指针了。
char *const p
* 读成 pointer to
p is a const pointer to char
char const *p
p is pointer to const char;
char const * p; 同上因为C++里面没有const*的运算符,所以const只能属于前面的类型
C++标准规定,const关键字放在类型或变量名之前等价的。
const int n=5; //same as below
int const m=10
const int *p; //const (int)*p
int const *q;// (int)const *p
char *const *p3;
pointer to const pointer to char;
const char * const *p4;
pointer to const pointer to const char
char **const p5;
const p5 pointer to pointer to char
const char ** const p6
const pointer to pointer to const char
char * const * const p7;
const pointer to const pointer to char
const char * const * const p8;
const pointer to const pointer to const char
///////////////////////////////////////////////////////////////////////////////////////////////////
指针数组,故名思义,就是指针的数组,数组的元素是指针;
数组指针,同样,就是指向数组的指针
简单举例说明:
int *p[2]; 首先声明了一个数组,数组的元素是int型的指针。
int* a[4] 指针数组
表示:数组a中的元素都为int型指针
元素表示:*a[i] *(a[i])是一样的,因为[]优先级高于*
int (*p)[2]; 声明了一个指针,指向了一个有两个int元素的数组。
int (*a)[4] 数组指针
表示:指向数组a的指针
元素表示:(*a)[i]
示例:
int a[4] = {1,2,3,4};
int *p1[4];
int (*p2)[4];
p2 = &a;
for (int i=0;i<4;i++)
{
p1[i] = &a[i];
}
cout<<*p1[1]<<endl;//指针数组 输出2就对了
cout<<(*p2)[2]<<endl;//数组指针 输出3就对了
1)前者定义P为常量,即只能单向赋值一次,P++展开为p=p+1,重复赋值给常量,出错,
例:char *const name1="John";
name1="abc"; //错误,name1指针,不能变,一个指针类型的变量,存放的是地址,所以不能把'"abc"的地址赋给name1
char * name2= name1; //可以
2)后者P为地址变量,地址变量是指向该变量的存储地址值如:4B3F6A,不能赋给一个字符值(字符相当于ascii表中对应的整数)如强制赋值,会把原地址变量P变为一个两位数的整数,造成地址指针溢出。而p++,则表示把该地址变量向下一个存储单元移动一位,如4B3F6A到4B3F6B.所以合法
const char* p : 定义一个指向字符常数的指针
char const* p : 等同于const char* p
const char * p;
p is pointer to const char;
例:const char *name1="John";
char s[]="abc"; name1=s; //正确,name1存放的地址可以改变
char * name2= name1; //不可以,因为name2 和 name1存放的是同一块地址,如果name2地址中的内容改了,则name1的内容也改了,那么name1就不再是指向常量的指针了。
char *const p
* 读成 pointer to
p is a const pointer to char
char const *p
p is pointer to const char;
char const * p; 同上因为C++里面没有const*的运算符,所以const只能属于前面的类型
C++标准规定,const关键字放在类型或变量名之前等价的。
const int n=5; //same as below
int const m=10
const int *p; //const (int)*p
int const *q;// (int)const *p
char *const *p3;
pointer to const pointer to char;
const char * const *p4;
pointer to const pointer to const char
char **const p5;
const p5 pointer to pointer to char
const char ** const p6
const pointer to pointer to const char
char * const * const p7;
const pointer to const pointer to char
const char * const * const p8;
const pointer to const pointer to const char
///////////////////////////////////////////////////////////////////////////////////////////////////
指针数组,故名思义,就是指针的数组,数组的元素是指针;
数组指针,同样,就是指向数组的指针
简单举例说明:
int *p[2]; 首先声明了一个数组,数组的元素是int型的指针。
int* a[4] 指针数组
表示:数组a中的元素都为int型指针
元素表示:*a[i] *(a[i])是一样的,因为[]优先级高于*
int (*p)[2]; 声明了一个指针,指向了一个有两个int元素的数组。
int (*a)[4] 数组指针
表示:指向数组a的指针
元素表示:(*a)[i]
示例:
int a[4] = {1,2,3,4};
int *p1[4];
int (*p2)[4];
p2 = &a;
for (int i=0;i<4;i++)
{
p1[i] = &a[i];
}
cout<<*p1[1]<<endl;//指针数组 输出2就对了
cout<<(*p2)[2]<<endl;//数组指针 输出3就对了
相关文章推荐
- 深入理解const char*p,char const*p,char *const p,const char **p,char const**p,char *const*p,char**const p
- 【转】深入理解const char*p,char const*p,char *const p,const char **p,char const**p,char *const*p,char**const p
- 深入理解const char*p,char const*p,char *const p,const char **p,char const**p,char *const*p,char**const p
- 深入理解const char*p,char const*p,char *const p,const char **p,char const**p,char *const*p,char**const p
- 深入理解char [] 和 char * ,const char[]和 const char*--反汇编分析
- 深入理解const char*p,char const*p,char *const p,const char **p,char const**p,char *const*p,char**const p
- [ZZ]深入理解const char*p,char const*p,char *const p,const char **p,char const**p,char *const*p,char**const p
- 深入理解const char*p,char const*p,char *const p,const char **p,char const**p,char *const*p,char**const p
- 深入理解const char*p,char const*p,char *const p,const char **p,char const**p,char *const*p,char**const p
- 深入理解const char*p,char const*p,char *const p,const char **p,char const**p,char *const*p,char**const p
- 深入理解const char*p,char const*p,char *const p,const char **p,char const**p,char *const*p,char**const p
- 深入理解const char*p,char const*p,char *const p,const char **p,char const**p,char *const*p,char**const p
- 深入理解const char*p,char const*p,char *const p,const char **p,char const**p,char *const*p,char**const p
- 深入理解const char*p,char const*p,char *const p,const char **p,char const**p,char *const*p,char**const p
- 深入理解const char*p,char const*p,char *const p,const char **p,char const**p,char *const*p,char**const p
- 深入理解const char*p,char const*p,char *const p,const char **p,char const**p,char *const*p,char**const p
- 深入理解const char*p,char const*p,char *const p,const char **p,char const**p,char *const*p,char**const p
- 深入理解const char*p,char const*p,char *const p,const char **p,char const**p,char *const*p,char**const p
- 深入理解const char*p,char const*p,char *const p,const char **p,char const**p,char *const*p,char**const p
- 深入理解const char*p,char const*p,char *const p,const char **p,char const**p,char *const*p,char**const p