指针 段错误 segament fault
来源:互联网 发布:剑网三道长捏脸数据库 编辑:程序博客网 时间:2024/05/21 14:55
http://blog.chinaunix.net/space.php?uid=21830881&do=blog&id=1813978
下列,例程序:
#include <stdio.h>
int main(int argc,char ** argv){
char * p ;
//p = '\0';
//p = "abcdefg";
//*p = "abcdefg"[5];//segament fault //段错误
*p = "abcdefg";//segament fault //段错误
//p = &("abcdefg" [5]);
printf("%s\n",p);
return 0;
}
段错误的,两行,是因为指针变量p,是野指针。
(就是说 p 的内存空间内没有 地址值 ,所以系统不知道 *p 指向的是哪里。)
①
char * p ;
p = '\0';
char * p;
定义了一个指针变量。
(系统为 p 分配了一个地址(例:0xaaaa);该地址空间内的值,应该也是个地址(暂时是NULL或不知道是啥)。)
(“不知道是啥”也就是定义了个 int i;不给i值,直接打印 i, 那打印结果指不定是啥,i 下的整形数据随机;用"随机"也不准,其实就是系统给i分配的地址下存放的值,赶巧是啥就是啥)
p = '\0';
'\0',系统在内存的数据区,放了一个'\0'。
将数据区的这个'\0'的地址,赋值给 p, 也就是存放在0xaaaa的内存空间下。
所以 *p 就指向,数据区的这个'\0'。
②
p = "abcdefg";
p = &("abcdefg" [5]);
和①一样。
就是把 字符串的首地址,放到p的内存空间下;把字符串的第6个元素的首地址放到p的内存空间下。
如果printf("%s\n",p);的话打印结果分别是: abcdefg 和 fg 。
"abcdefg" [5] 的写法 和 ‘char str[]="abcdefg";str[5];’的写法一个意思。
③
*p = "abcdefg"[5];//segament fault //段错误
//segament fault //段错误
*p = "abcdefg";
含义是 对 *p 指向的那段内存空间赋值。
但是*p 指向哪里呢? p的内存空间下也没有存放明确地址值呀?
系统不知道该指向哪里,所以//segament fault //段错误 。
- 指针 段错误 segament fault
- 指针 段错误 segament fault
- 指针 段错误 segament fault
- 结构体指针之 段错误 详解(segmentation fault)
- 段错误(segmentation fault)
- 段错误(segmentation fault)
- 总结段错误(Segmentation fault)
- 总结段错误(Segmentation fault)
- "Segmentation fault(段错误)"探究
- Segmentation fault(段错误)探究
- 总结段错误(Segmentation fault)
- 总结段错误(Segmentation fault)
- 段错误总结(segmentation fault)
- Linux段错误(Segmentation fault)
- 【Segment Fault】段错误解析
- mysql_real_query()段错误(Segmentation fault)
- 用gdb检查段错误(segment fault)
- 总结段错误(Segmentation fault) (转)
- Android输入法框架整理
- 宏定义中的#,##,@#及\符号
- Windows 无法自动检测此网络的代理配置!
- tcpdump使用
- win32载入一张位图
- 指针 段错误 segament fault
- SSO(Single Sign-on) in Action
- 查看端口是否被占用
- ORACLE 回收站管理
- android导入源码编译的一个错误
- 大牌智能机巅峰PK:HTC One X对比iPhone 4S
- ubuntu下搭建c/c++环境步骤讲解
- 【二分图最佳匹配】移动棋子
- 已经为另一个apple id 验证电子邮件地址的问题