博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
不要伤害指针(6)--指针的安全问题
阅读量:6373 次
发布时间:2019-06-23

本文共 1106 字,大约阅读时间需要 3 分钟。

看下面的例子:

例十八:

char s = 'a';int *ptr;ptr = (int *)&s;*ptr = 1298;

指针ptr 是一个int *类型的指针,它指向的类型是int。它指向的地址就是s 的首地址。在32 位程序中,s 占一个字节,int 类型占四个字节。最后一条语句不但改变了s 所占的一个字节,还把和s 相临的高地址方向的三个字节也改变了。这三个字节是干什么的?只有编译程序知道,而写程序的人是不太可能知道的。也许这三个字节里存储了非常重要的数据,也许这三个字节里正好是程序的一条代码,而由于你对指针的马虎应用,这三个字节的值被改变了!这会造成崩溃性的错误。
让我们再来看一例:
例十九:

char a;int *ptr = &a;ptr++;*ptr = 115;

该例子完全可以通过编译,并能执行。但是看到没有?第3 句对指针ptr 进行自加1 运算后,ptr 指向了和整形变量a 相邻的高地址方向的一块存储区。这块存储区里是什么?我们不知道。有可能它是一个非常重要的数据,甚至可能是一条代码。而第4 句竟然往这片存储区里写入一个数据!这是严重的错误。所以在使用指针时,程序员心里必须非常清楚:我的指针究竟指向了哪里。在用指针访问数组的时候,也要注意不要超出数组的低端和高端界限,否则也会造成类似的错误。
在指针的强制类型转换:ptr1=(TYPE *)ptr2 中,如果sizeof(ptr2的类型)大于sizeof(ptr1 的类型),那么在使用指针ptr1 来访问ptr2所指向的存储区时是安全的。如果sizeof(ptr2 的类型) 小于sizeof(ptr1 的类型),那么在使用指针ptr1 来访问ptr2 所指向的存储区时是不安全的。至于为什么,读者结合例十八来想一想,应该会明白的。
经过一个系列的对指针的学习,现在你是否已经觉得指针再也不是你所想的那么害怕了,如果你的回答是:对,我不怕了!哈哈,恭喜你,你已经掌握C 语言的精华了,C中唯一的难点就是指针,指针搞定其它小菜而已,重要的是实践,好吧,让我们先暂停C 的旅程吧,开始我们的C++编程,C 是对底层操作非常方便的语言,但开发大型程序本人觉得还是没有C++方便,至少维护方面不太好做。而且C++是面向对象的语言,现在基本已经是面向对象的天下了,所以建议学C++。C++是一门难学易用的语言,要真正掌握C++可不是那么容易的,将基本的学完后,就学数据结构吧,算法才是永恒的,程序设计语言层出不穷,永远学不完。

转载于:https://www.cnblogs.com/stemon/p/4153311.html

你可能感兴趣的文章
std::forward的性质.
查看>>
类型转换
查看>>
系统托盘
查看>>
java存储过程调用例子
查看>>
java如何进阶
查看>>
Maven+SpringMVC+MyBatis实现系统(二)
查看>>
mongodb的安装及主从复制
查看>>
LLDB 简单用法
查看>>
dbms_space_admin.drop_empty_segments
查看>>
关于前增量与后增量的认识误区
查看>>
Java-Final
查看>>
DPI 设置过大该如何还原?
查看>>
iOS 开发之CocoaPods常用第三方框架导入
查看>>
我的友情链接
查看>>
iOS设计模式-适配器
查看>>
LAMP(Linux+Apache+Mysql+Php)快速部署(yum)
查看>>
活动目录和域实验
查看>>
zabbix 清理历史数据
查看>>
运维工程师必会工具(Nmap和TCPdump)
查看>>
关于HTML加密混淆、源码保护、代码安全,防止解压直接看源码
查看>>