理解不同编程语言类型安全的需求

本文涉及的产品
应用实时监控服务-可观测链路OpenTelemetry版,每月50GB免费额度
云原生网关 MSE Higress,422元/月
注册配置 MSE Nacos/ZooKeeper,118元/月
简介: 【7月更文挑战第12天】本文介绍编程语言类型系统与语言设计密不可分,影响编程习惯和语言安全。微服务架构允许跨语言技术栈,每个服务都能用最适合的平台构建,强调代码质量原则,以实现高效解决方案。

1 简介

编程安全关乎内存、类型和线程安全。静态类型如ML用类型推理减少注释,而C家族语言较冗长。
不同类型系统适应不同安全需求,如HIPAA和PCI合规。

内存安全防止CVE,类型安全确保数据正确处理,线程安全避免多线程冲突。设计良好的静态类型语言可通过类型推理减轻程序员负担。
在多语言环境中,每个服务可根据需求选择最适合的安全策略。

在静态语言中的静态类型如ML利用类型推理减少注释,而C家族更显冗长。不同语言满足不同安全需求,如HIPAA和PCI合规。

更广泛的安全定义为:

 编程安全 = 内存安全 + 类型安全 + 线程安全

安全问题可以分类为如下几个

编程安全

内存安全
类型安全
线程安全

本文也举例说明为什么这很重要?

内存安全问题
类型安全问题
线程安全问题

2 类型系统和语言设计

记住将类型系统改造成未设计类型检查的语言可能很棘手;理想情况下,语言设计应该与类型系统一起设计。

---Alf (Magnusson and Nordström, 1994) 直接基于类型论。Constable (1998) 和 Pfenning (1999) 讨论了这些系统的历史。

数据库社区对类型系统的兴趣也在增加,随着以文档类型定义(XML 1998)和其他类型的模式(例如新的 XML-Schema标准 [XS 2000]) 用于描述 XML 中的结构化数据。

新语言查询和操作 XML 提供了强大的基于静态类型系统直接针对这些模式语言

---(Hosoya 和 Pierce,2000;Hosoya、Vouil lon 和 Pierce,2001;Hosoya 和 Pierce,2001;Relax,2000;Shields,2001)。

类型系统的一个完全不同的应用出现在计算语言学领域,其中类型化的 lambda 演算构成了形式主义的基础例如分类语法

---(van Benthem,1995;van Benthem 和 Meulen,1997;兰塔,1995;等等。)。

造成这种情况的一个原因是,没有类型系统的语言——即使是安全的、动态检查的语言——往往会提供使类型检查变得困难或不可行的特性或鼓励编程习惯用法。

确实,在键入语言类型系统本身通常被视为设计和组织原则的基础,根据它的其他方面设计被考虑。

另一个因素是类型语言的具体语法往往是比无类型语言更复杂,因为类型注释必须考虑在内。做好清洁设计工作更容易当所有问题都可以一起解决时,语法可以理解。

类型应该是编程语言的一个组成部分的断言与程序员必须在哪里物理写下类型注释以及它们可以在哪里推断的问题是分开的由编译器。

设计良好的静态类型语言永远不需要由程序员显式且繁琐地维护大量类型信息。但是,对于多少有一些分歧显式类型信息太多。

ML 中的语言设计者努力将注释保持在最低限度,使用类型推理方法来恢复必要的信息。 C语言家族,包括 Java,都选择了更加冗长的风格。

3 内存安全,类型安全和线程安全:不同语言的不同要求

每个语言和应用程序在安全性方面都有不同的要求。
例如,与医疗保健相关的应用程序可能需要 HIPAA 合规性,或者金融应用程序可能需要 PCI 合规性。
在选择正确的堆栈时,我们还考虑了更一般的安全建议,例如 OWASP Top 10。
密切关注所选堆栈的安全公告将有助于应用程序更加健壮。

  • 内存安全

在内存安全语言中,当您访问数组中的变量或项时,您可以确定您确实正在访问您想要访问的内容或被允许访问的内容。换句话说,无论您在程序中执行什么操作,您都不会错误地读取或写入另一个变量或指针的内存

内存安全问题
内存安全问题是我们遇到的大多数安全 CVE(常见漏洞和暴露,在Microsoft的视窗系统70%的CVE为内存安全问题)的原因。

黑客可能会滥用未定义的行为来控制程序或泄露特权信息。如果您尝试使用内存安全语言访问越界数组元素,您只会因崩溃或错误而崩溃,这是可预测的行为。

这就是为什么 C/C++ 系统中与内存相关的错误通常会导致 CVE 和紧急补丁的原因。C/C++ 中还有其他内存不安全的行为,例如从已弹出的堆栈帧访问指针、已取消分配的内存、迭代器失效等。内存安全语言,即使不是最安全的语言,仍然可以防止此类安全问题。

  • 类型安全

在类型安全语言中,当您访问变量时,您可以根据变量的存储方式将其作为正确的数据类型进行访问。这让我们有信心处理数据,而无需在运行时手动检查数据类型。内存安全是语言类型安全的必要条件。

类型安全问题
虽然不像内存和线程安全那么重要,但缺乏类型安全也会导致安全问题,而类型安全对于确保内存安全非常重要。

在类型不安全的语言中,低级别攻击是可能的,因为攻击者可以操纵数据结构并更改数据类型以获取对特权信息的访问权限。虽然这种类型的漏洞非常罕见,但并非闻所未闻。

  • 线程安全
    在线程安全语言中,您可以同时从多个线程访问或修改相同的内存,而不必担心数据争用。
    这通常是使用消息传递技术、互斥锁(互斥锁)和线程同步来实现的。
    线程安全是最佳内存和类型安全所必需的,因此通常,内存和类型安全语言也倾向于线程安全。

线程安全问题

虽然不像内存安全那样臭名昭著,但线程安全也是开发人员头疼的一个原因,并可能导致安全问题。

线程安全问题可能导致两种类型的漏洞:

一个线程覆盖另一个线程的信息导致的信息丢失
允许权限提升或远程执行的指针损坏
由于来自多个线程的信息交错而导致的完整性损失
这种类型的最著名的攻击称为 TOCTOU(检查时间到使用时间)攻击,它是检查条件(如安全凭证)和使用结果之间的竞争条件。

信息丢失和完整性丢失都可能被利用并导致安全问题。虽然与线程安全相关的漏洞比内存安全漏洞更难且不那么常见,但它们仍然是可能的。

4 小结

需要注意的是,在后单体软件世界中,技术决策在应用程序生态系统中并不相互排斥。
我们越来越多地实现微服务架构,因此我们可以运行基于不同编程语言和框架构建的单个服务。

通过这种方式,我们可以确保每个特定任务都由最佳平台提供服务。
凭借我们广泛的经验和专业知识,并坚持良好代码的标志 - 可维护性,简单性,YAGNI,干燥,固体和可测试性 - 我们能够始终如一地指导我们的客户找到最有效的技术解决方案。

目录
相关文章
|
8月前
|
Java Go C++
Go语言中的面向对象编程实践
【2月更文挑战第10天】本文将深入探讨在Go语言中如何进行面向对象编程实践。我们将了解如何在Go中实现封装、继承和多态,以及如何利用结构体、接口和方法来构建健壮和可维护的对象导向程序。通过实际代码示例,我们将更好地理解Go的OOP特性,并学习如何有效地运用它们。
|
1月前
|
存储 算法 开发者
揭秘编程语言的魔法:从代码到计算机理解
编程,一种将思维转化为指令的艺术。本文将带你走进编程语言的世界,探索如何将简单的代码变成计算机能够理解的指令。我们将通过Python语言的例子,展示变量、数据类型、控制结构等基本概念,并解释它们是如何被计算机执行的。无论你是编程新手还是有经验的开发者,这篇文章都将为你提供新的视角和深入的理解。让我们一起揭开编程语言的神秘面纱,看看那些我们每天使用的代码是如何在计算机中运行的。
|
6月前
|
XML 安全 程序员
了解编程语言中的类型安全
【7月更文挑战第15天】本文介绍类型安全与效率在语言设计中至关重要。安全性需求各异,从HIPAA到PCI合规,选择最佳技术栈要考虑多方面,包括微服务架构中的语言多样性,以确保每个服务都能高效且安全地执行其特定任务。
177 14
了解编程语言中的类型安全
|
6月前
|
人工智能 Java C#
理解编程语言的类型系统
【7月更文挑战第11天】本文介绍现代软件工程借助形式化方法确保系统正确性。强类型系统如数理逻辑虽能表达普遍属性但复杂,轻量级技术如模型检查(用于芯片设计和通信协议验证)和类型系统则更易用。类型系统是推理工具,起源于解决逻辑悖论,经历多个里程碑发展,分为动态和静态分支,重点在于编程语言应用,特别是AI领域。
81 2
理解编程语言的类型系统
|
6月前
|
自然语言处理 算法 安全
编程语言中的静态和动态类型语言
【7月更文挑战第14天】本文介绍静态与动态类型语言对比。类型检查效率是关键,一些系统可能在极端情况下慢。自动化与高效算法的研究持续进行.
82 5
编程语言中的静态和动态类型语言
|
6月前
|
人工智能 Java C#
什么是面向对象的编程语言?
【7月更文挑战第18天】什么是面向对象的编程语言?
162 2
|
7月前
|
安全 Java 编译器
Java 泛型详解:全面掌握类型安全与灵活性的利器
Java 泛型详解:全面掌握类型安全与灵活性的利器
66 1
|
8月前
|
C语言 iOS开发 MacOS
Objective-C是一种面向对象的编程语言,它扩展了C语言,添加了面向对象编程的特性
【5月更文挑战第9天】Objective-C是苹果公司的面向对象编程语言,用于iOS和macOS应用开发。它扩展了C语言,包含类定义(接口和实现)、对象创建、消息传递、属性、协议、块和类别等语法特性。例如,类通过`@interface`和`@implementation`定义,对象用`alloc`和`init`创建,方法通过消息传递调用。属性简化变量声明,协议定义可选方法集合,块支持代码块作为参数,类别用于扩展已有类。错误处理常使用NSError对象。要深入了解,建议查阅相关教程和文档。
68 0
|
8月前
|
Rust 安全 Java
Rust 语言的类型系统
假如让你设计编程语言的类型,你会怎么做? 要定义哪些类型? 类型之间如何交互? 是否需要类型推断? 类型系统是编程语言中用于定义和控制类型的一组规则。
Rust 语言的类型系统
|
8月前
|
Java 程序员 C#
Lambda表达式:简洁而强大的函数式编程利器
【4月更文挑战第3天】本文探讨了Lambda表达式的基础和在编程中的应用,包括简化代码和提高可读性。Lambda表达式是匿名函数,用于简单的功能,如示例中的平方运算和列表筛选。通过`map`、`filter`等函数,Lambda表达式能有效处理列表操作。文中还展示了Lambda表达式的高级用法,如闭包特性、异常处理及与高阶函数的结合。通过实例,读者可以学习如何利用Lambda表达式实现更高效、简洁的编程。
79 0