类型安全与不安全演示

举报
howard2005 发表于 2022/05/19 23:52:00 2022/05/19
【摘要】 文章目录 一、类型安全的含义二、类型安全与不安全的演示(一)C/C++语言允许数组越界(二)Java不允许数组越界 一、类型安全的含义 一般来说,一门语言只要保证类型安全,就可以说它是...

一、类型安全的含义

  • 一般来说,一门语言只要保证类型安全,就可以说它是一门安全的语言。简单来说,类型安全是指类型系统可以保证程序的行为是意义明确、不出错的。像C/C++语言的类型系统就不是类型安全的,因为它们并没有对无意义的行为进行约束。

二、类型安全与不安全的演示

(一)C/C++语言允许数组越界

  • 一个最简单的例子就是数组越界,在C/C++语言中并不对其做任何检查,导致发生了语言规范规定之外的行为,也就是未定义行为(Undefined Behavior)。而这些未定义行为恰恰是漏洞的温床。所以,像C/C++这种语言就是类型不安全的语言。
    在这里插入图片描述
  • 定义的数组arr长度为5,合法的数组元素应该是arr[0]arr[1]arr[2]arr[3]arr[4],但是C程序竟然可以对越界的数组元素arr[10]进行操作,必然存在不安全的隐患。

(二)Java不允许数组越界

  • 定义的数组arr长度为5,访问越界的数组元素arr[10],运行时抛出ArrayIndexOutOfBoundsException异常。
    在这里插入图片描述
  • 数组下标越界异常,只有在运行时才抛出,编译期是无法捕获的
    在这里插入图片描述

文章来源: howard2005.blog.csdn.net,作者:howard2005,版权归原作者所有,如需转载,请联系作者。

原文链接:howard2005.blog.csdn.net/article/details/124849473

【版权声明】本文为华为云社区用户转载文章,如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

评论(0

0/1000
抱歉,系统识别当前为高风险访问,暂不支持该操作

全部回复

上滑加载中

设置昵称

在此一键设置昵称,即可参与社区互动!

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。