Chinaunix首页 | 论坛 | 博客
  • 博客访问: 383261
  • 博文数量: 87
  • 博客积分: 983
  • 博客等级: 准尉
  • 技术积分: 685
  • 用 户 组: 普通用户
  • 注册时间: 2012-06-25 07:20
文章分类

全部博文(87)

文章存档

2016年(1)

2015年(3)

2014年(55)

2013年(13)

2012年(15)

分类: C/C++

2014-03-24 14:22:59

通过一个例子的结果来分析:

点击(此处)折叠或打开

  1. #include<stdio.h>

  2. int main(void)
  3. {
  4.     char a[2] = {1,2};
  5.     char *p1_1 = a;
  6.     char (*p1_2)[2] = &a;    //char *p1=&a 会报警告 ,因为指向的类型不一样
  7.     
  8.     char *p2_1 = "abcd";
  9.     
  10.     char arry[5] = "abcd";
  11.     
  12.     printf(" %p\n %p\n %p\n %p\n %p\n %p\n %p\n %p\n", \
  13.             p1_1, p1_2, p2_1, &p2_1, arry, &arry, "abcd", &"abcd");
  14.             
  15.     return 0;
  16. }
结果为:

数组名:数组名表达的含义:1. 数组元素的首地址,即&arry[0]。2. 数组名,就是单纯的数组名,就像char n = 10; 里的n,只不过名为arry的这个变量所占用的存储空间大小和n不一样而已。可以取地址&a,对比&n,就是取其整个数组的地址代码中a与&a的地址值一样,但是等级不一样,arry是“乡政府”,&arry是“市政府”。
字符串:可以和普通常量对比,"abcd" 和 普通常量 12 类似,都存储在常量区。"abcd"又更像一个数组名。代码如下:

点击(此处)折叠或打开

  1. #include<stdio.h>

  2. int main(void)
  3. {
  4.     printf("%c\n", *("abcd"+1));
  5.             
  6.     return 0;
  7. }
运行结果为 b

可以看出字符串"abcd"和数组名arry很类似,操作也几乎一样。只不过arry的内容在栈区,"abcd"在常量区(只读)。
阅读(718) | 评论(0) | 转发(0) |
0

上一篇:字节对齐的位运算

下一篇:ldd学习准备

给主人留下些什么吧!~~