了解编程语言的安全

本文涉及的产品
可观测可视化 Grafana 版,10个用户账号 1个月
Serverless 应用引擎免费试用套餐包,4320000 CU,有效期3个月
容器镜像服务 ACR,镜像仓库100个 不限时长
简介: 【7月更文挑战第11天】本文介绍编程语言中的类型的安全与效率:安全不仅关乎防止错误,也影响性能和可预测性。

1 简介

安全通常意味着加密,如下为一个普通的安全通信过程,它将hello加密为另一个无意义的字符串,在最后再进行解密。

image.png

而语言的类型安全性似乎完全式另一个事情。它涉及防止运行时错误,如OCaml的Obj.magic或C的Unsafe.cast,但这些可能导致不安全的逃逸。

安全语言通过静态类型检查提高效率,消除动态检查的需要。类型系统也影响优化,如Fortran早期用于数值效率。

编译器利用类型信息进行优化,如Titanium中指针范围分析提升并行性能。ML Kit Compiler的区域推断甚至能减少垃圾收集,实现基于堆栈的内存管理。

在所有语言的安全这方面,C 语言的漏洞数量最多,占过去 10 年中报告的所有漏洞的 50%。

在我们进一步深入研究之前,在评估这些项目时,我们应该考虑两个因素。虽然从表面上看,有些人可能会错误地认为 C 天生就更容易受到攻击,但事实并非如此。

对于初学者来说,编写的代码比任何其他语言都多,为发现漏洞提供了更多机会。

事实上,C语言的使用时间比大多数其他语言要长得多,并且是我们使用的大多数产品和平台的核心。因此,它必然比其他漏洞具有更多的已知漏洞

2 类型的效率和安全

语言的类型安全很少有绝对的。安全通常为程序员提供“逃生口”,例如对用其他语言编写的代码的外部函数调用,可能是不安全的语言。

事实上,这种逃生口有时会在语言本身内以受控形式提供——OCaml 中的 Obj.magic(Leroy, 2000), Unsafe.cast 在新泽西州执行标准ML 等 Modula-3 (Cardelli et al., 1989; Nelson, 1991) 和 C] (Wille, 2000)。

更进一步,提供一种旨在实施的“不安全的子语言”低级运行时设施,例如垃圾收集器。

特殊功能这种子语言的一部分只能在明确标记为不安全的模块中使用。
Cardelli (1996) 阐述了一种不同的语言安全性观点,区分所谓的捕获和未捕获的运行时错误。

捕获的错误会导致计算立即停止(或引发可以在程序中干净地处理的异常),而未被捕获错误可能允许计算继续(至少一段时间)。

未捕获错误的示例可能是访问超出末尾的数据像 C 这样的语言中的数组。在这种情况下,一种安全的语言可以防止运行时未捕获的错误。

还有一种观点侧重于可移植性。它可以表示为口号,“安全的语言完全由其程序员手册定义。”
让语言的定义成为程序员需要的一组东西理解以预测语言中每个程序的行为。

那么像C这样的语言的手册并不构成定义,由于某些程序的行为(例如,涉及未经检查的数组如果不知道特定 C 编译器如何在内存中布局结构等细节,则无法预测访问或指针算术),并且同一个程序在被不同的编译器执行时可能会有完全不同的行为。

相比之下,用于/和指定的手册(具有不同的严格程度)语言中所有程序的确切行为。一个类型良好的程序在任何正确的实现下都会产生相同的结果这些语言中。

3 效率

计算机科学中的第一类系统,从 1950 年代开始使用 Fortran (Backus, 1981) 等语言,被引入以提高效率。

通过区分整数值来提高数值计算的效率算术表达式和实值表达式;这允许编译器使用不同的表示并生成适当的机器指令原始操作。

在安全语言中,进一步的效率改进是通过消除许多需要的动态检查来获得保证安全(通过静态证明他们将永远得到满足)。

今天,大多数高性能编译器严重依赖收集到的信息在优化和代码生成阶段由类型检查器执行。甚至本身没有类型系统的语言的编译器努力恢复此类型信息的近似值。依赖类型信息的效率改进可能来自于一些令人惊讶的地方。

4 C语言的安全例子

最近已经表明,不仅代码使用类型分析生成的信息可以改进并行科学程序中的生成决策以及指针表示。在Titanium 语言 (Yelick et al., 1998) 使用类型推断技术来分析指针的范围,并能够做出明显更好的决策在此基础上,程序员显式地手动调整他们的程序。

而如下图缓冲区错误(CWE-119)是C语言中最常见的安全漏洞,与C++的漏洞配置文件类似。
这是可以理解的,因为其他语言中常见的大多数 CWE 都与 Web 和 Web 服务问题有关,而这些问题在 C 语言中无关紧要C++。

需要注意的是,这组漏洞(有时称为内存损坏)通常会产生严重后果。

image.png

在ML Kit Compiler中 使用了更强大的区域推断算法(Gifford、Jou velot、Lucassen 和 Sheldon,1987;Jouvelot 和 Gifford,1991;Talpin 和朱维洛,1992;托夫特和塔尔平,1994,1997; Tofte 和 Birkedal,1998 年)到将垃圾收集的大部分(在某些程序中,全部)替换为基于堆栈的内存管理。

下图显式了使用C语言实现的不同项目中的漏洞数量。

image.png

虽然大多数语言都用于构建数百甚至数千个包,但跟踪基于 C 语言构建的开源项目很容易。这使我们能够确切地了解哪些开源库在多年来漏洞增加之后,报告的已知漏洞有所增加。

目录
相关文章
|
人工智能 开发框架 物联网
为什么 C# 可能是最好的第一编程语言
C# 是一个全面领域的全能型语言,结合新时代的 .NET 平台,与时俱进的发展创新,未来无限可期!对于带着有色眼镜看待的人们,是否该刮目相看了呢?下面看看行业大佬关于 .NET 的解说。
1213 2
为什么 C# 可能是最好的第一编程语言
|
1月前
|
Rust JavaScript 前端开发
编程语言
【10月更文挑战第13天】编程语言
31 4
|
6月前
|
JavaScript Java iOS开发
编程语言有哪些?
【5月更文挑战第22天】编程语言有哪些?
207 10
|
6月前
|
机器学习/深度学习 人工智能 测试技术
年度编程语言将花落谁家
年度编程语言将花落谁家
|
人工智能 分布式计算 Java
【编程语言选择】我们学C++将来能做什么?
【编程语言选择】我们学C++将来能做什么?
125 0
|
JavaScript 前端开发 Java
常用的编程语言
世界上最常用的几种语言
138 0
|
Oracle JavaScript Java
最好的编程语言
当我想在工作中休息一下时,我有时会阅读技术论坛。有一种帖子我真的很喜欢:编程语言之间的火焰战争。我喜欢这些帖子,因为你可以看到充满激情和聪明的人,他们正在争论,好像他们的生活正在发挥作用。 这些职位有2个优点: 他们让我笑 我学新东西 如果我必须总结这种帖子,那将是这样的: 帖子标题“Java是最好的语言”由NewJavaFanBoy撰写 NewJavaFanBoy:Java是最好的语言,因为它的社区。此外,它具有非常酷的功能,如lambdas。为什么这么多人讨厌Java? 前JavaFanBoy:Oracle杀死了Java。 DotNetFanBoy:Java的演进太慢了,
158 0
最好的编程语言
|
算法 数据可视化 IDE
1 分钟学会 30 种编程语言
1 分钟学会 30 种编程语言
166 0
1 分钟学会 30 种编程语言
|
Rust Ubuntu 编译器
“C 不再是一种编程语言”
本文标题里的观点很“刺激”,它来自国外一位 Swift 和 Rust 专家 Aria Beingessner,他近日撰写了一篇文章《C 不再是一种编程语言》,在技术社区引起了热议。
207 0
“C 不再是一种编程语言”
|
Java 程序员 容器
最好的编程语言是怎样的?
最好的编程语言是怎样的?
218 0
最好的编程语言是怎样的?
下一篇
无影云桌面