zoukankan
html css js c++ java
[转]一个比较有用的指针测试程序
//
execise2.cpp : Defines the entry point for the console application.
//
#include
"
stdafx.h
"
#include
<
iostream
>
using
namespace
std;
//
-----------------------------------------------
void
GetMemory1(
char
*
p)
{
p
=
(
char
*
)malloc(
100
);
}
void
Test1(
void
)
{
char
*
str
=
NULL;
GetMemory1( str );
strcpy(str,
"
hello world
"
);
printf(str);
}
//
-----------------------------------------------
char
*
GetMemory2(
void
)
{
char
p[]
=
"
hello world
"
;
return
p;
}
void
Test2(
void
)
{
char
*
str
=
NULL;
str
=
GetMemory2();
printf(str);
}
//
-----------------------------------------------
void
GetMemory3(
char
**
p,
int
num)
{
*
p
=
(
char
*
)malloc(num);
}
void
Test3(
void
)
{
char
*
str
=
NULL;
GetMemory3(
&
str,
100
);
strcpy(str,
"
hello
"
);
printf(str);
}
//
-----------------------------------------------
void
Test4(
void
)
{
char
*
str
=
(
char
*
) malloc(
100
);
strcpy(str,
"
hello
"
);
free(str);
if
(str
!=
NULL)
{
strcpy(str,
"
world
"
);
printf(str);
}
}
//
-----------------------------------------------
main()
{
//
-----------------------------------------------
//
请问运行Test1函数会有什么样的结果?
//
//
答:程序崩溃。
//
//
因为GetMemory并不能传递动态内存,
//
//
Test函数中的 str一直都是 NULL。
//
//
strcpy(str, "hello world");将使程序崩溃。
Test1();
//
-----------------------------------------------
//
请问运行Test2函数会有什么样的结果?
//
//
答:可能是乱码。
//
//
因为GetMemory返回的是指向“栈内存”的指针,
//
该指针的地址不是 NULL,但其原现的内容已经被清除,新内容不可知。
Test2();
//
-----------------------------------------------
//
请问运行Test3函数会有什么样的结果?
//
//
答:
//
//
(1)能够输出hello
//
//
(2)内存泄漏
Test3();
//
-----------------------------------------------
//
请问运行Test函数会有什么样的结果?
//
//
答:篡改动态内存区的内容,后果难以预料,非常危险。
//
//
因为free(str);之后,str成为野指针,
//
//
if(str != NULL)语句不起作用。
Test4();
//
-----------------------------------------------
}
原文链接:
http://www.cppblog.com/mzty/archive/2006/07/07/9536.html
查看全文
相关阅读:
Seam的安全框架授权(Authorization)(译) (三)
Seam的安全框架授权(Authorization)(译) (一)
Seam的安全框架错误信息(Error Messages)(译)
如何编出健壮的代码,java编程30条规则(转)
Seam的安全框架身份管理(Identity Management)(译)
Seam的安全框架授权(Authorization)(译) (二)
集成Seam,Spring和jBPM指南(译)
拖拉是种病,不治会要命!(转)
Jboss Seam, mysql中文乱码问题4步骤总结(转)
ubuntu上的mysql字符集设置(转)
原文地址:https://www.cnblogs.com/zhangqingping/p/1432633.html
最新文章
兼容ie各大浏览器的解决方法
在网页里添加客服
兼容ie的placeholder设置
去除页面横滚动条,保留竖滚动条
Javascript Dom编程艺术(第2版)读书笔记
网站用户体验是王道 网站seo如何优化?
ASCII,unicode, utf8 ,big5 ,gb2312,gbk,gb18030等几种常用编码区别
让函数容易阅读
System.DateTime.Now.ToString
类、对象和包
热门文章
一周总结
ATM
基础小结
哎哟不错哦
数组
基础小总结
对象的行为
上台阶
算24
迷宫
Copyright © 2011-2022 走看看