Ada语言学习(1)Basic Knowledge

news2025/1/13 9:36:16

文章目录

  • 说在前头
  • 命名
  • 注释
  • 数字
  • 变量
    • 变量类型
      • signed integers
      • Enumerations
      • Floating Points
    • 类型重用(继承)
    • 类型转换
  • 运算符
  • 属性(Attributes)
  • 练习

说在前头

  • 本系列教程将会通过提问的方式来完成整个学习过程,因为当你能够提出一个好问题,你才能找到自己哪里不懂,然后去解决它,这样你就学会了。
  • 所以当你想学习一门新的知识的时候,请先问问自己,哪里不会,如果你自己不知道自己哪里有问题,那么就没办法学会这个新知识。
  • 本教程的所有内容均来自于 youtube 的 Ada001 学习教程,Ada002 学习教程 这好像也是全网唯一的 Ada 学习教程。

为什么学习 ada 语言呢?它与其他语言的差异是什么?

  • Ada是一种在特定领域中非常重要的编程语言。它的主要设计目标是支持大型,长寿命,高可靠性的系统开发。Ada在包括航天、防务、交通、医疗设备等关键性领域得到广泛应用,因为它的设计目标和特性非常适应这些领域的需求。

  • 学习Ada编程语言有以下几个原因:

    • 可靠性和安全性: Ada是为了提高可靠性和安全性而设计的。例如,Ada有很强的类型检查,这可以在编译时捕获许多错误。Ada还有各种特性来支持并发和实时编程,这在需要高度可靠的系统中很重要。
    • 长寿命项目: Ada的设计使其非常适合长寿命项目。例如,Ada有很好的支持模块化和信息隐藏,这可以帮助管理大型代码库。此外,Ada语言的稳定性也有助于保证长期项目的持续性。
    • 高性能: Ada提供了一些特性,可以帮助开发人员更好地控制程序的性能。例如,Ada支持低级别的编程,允许程序员直接操作硬件
  • 与其他编程语言相比,Ada的一些显著差异包括:

    • 强类型: Ada有非常严格的类型系统,这可以帮助预防许多常见的编程错误。
    • 包和子程序规格: Ada语言强调软件工程原则,例如信息隐藏、模块化和抽象。Ada使用包(package)来组织相关的类型和子程序,而子程序规格和实现的分离则提供了清晰的接口和实现分离。
    • 并发和实时支持: Ada提供了对并发和实时系统的原生支持,这在许多其他语言中是缺失的或者作为库提供的。
    • 异常处理: Ada提供了一种结构化的异常处理机制,可以在出现错误时提供清晰的程序控制流。

命名

  • 变量命名是 case insensitive 的:Hello=hello=HellO
  • 必须以字母开头
  • 以数字或者字母结尾
  • 不能有连续的下划线

在这里插入图片描述

注释

在这里插入图片描述

数字

  • ada 允许数字中出现下划线
    在这里插入图片描述
  • 数字允许使用 2-16进制的表达方式:
    在这里插入图片描述
  • 浮点数必须使用 . 不能省略,因为 ada 强数据类型,严格区分浮点数和整数
    在这里插入图片描述

变量

  • 变量定义 变量名称 : 变量类型 ;
  • 变量声明+赋值 变量名称 : 变量类型 := ... ;
  • 声明多个变量 变量1, 变量2 : 变量类型 := ... ;
    在这里插入图片描述
  • 变量必须先声明后使用:
    在这里插入图片描述

变量类型

  • ada 中的任何类型都不会进行自动转换也不能混用,除非进行显式的数据类型转换
    在这里插入图片描述
  • ada 的全部类型
    在这里插入图片描述

signed integers

在这里插入图片描述

Enumerations

在这里插入图片描述

Floating Points

在这里插入图片描述

  • 需要注意的是:在 Ada 语言中,类型的精度(比如 Short_IntegerLong_Integer)通常取决于具体的编译器和目标平台。 Ada 规范并没有为 Short_IntegerLong_Integer 精确地规定位数。规范只要求 Short_Integer 的范围至少能覆盖 − 2 1 5 -2^15 215 2 15 − 1 2^{15} - 1 2151(即至少16位),而 Long_Integer 的范围至少能覆盖 − 2 31 -2^{31} 231 2 31 − 1 2^{31} - 1 2311(即至少32位)。具体的位数可能会因为编译器和平台的不同而有所差异。

  • 如果你要实现一个操作,而这个操作要指定特定的数据类型,那么你可以自己定义一个数据类型来覆盖你想测试的所有数据范围,例如:
    在这里插入图片描述

  • 同样的,enumeration 类型的数据也如此:
    在这里插入图片描述

  • 同样的也可以定义浮点型的数据类型:
    在这里插入图片描述

    • type Distance is digits 10; 定义了一个叫做 Distance 的浮点类型。关键字 digits 指定了这个类型的有效数字位数,也就是精度。在这个例子中,Distance 类型的精度至少为 10 位数字。

    • type Temperature is digits 5 range -273.15 .. 1 000 000.0; 定义了一个叫做 Temperature 的浮点类型。这个类型的精度至少为 5 位数字。关键字 range 指定了这个类型的有效范围,可以接受的值在 -273.15 到 1 000 000.0 之间。如果试图将超出这个范围的值赋予 Temperature 类型的变量,Ada 的运行时系统将会抛出异常。

    • 这些类型定义使得你能够创建具有特定精度和范围限制的变量,这对于数值计算和物理测量等场景非常有用。

    • 如果你指定的精度位数太高,那么 Ada 编译器会拒绝贬义你的程序,同时,对于浮点数的数据类型来说,尽量不要使用 range 语句来设定范围,因为代价很大。

类型重用(继承)

在这里插入图片描述

类型转换

  • 类型的转换必须是显式的,ada 不会进行任何隐式的类型转换
    在这里插入图片描述
  • 类型转换的时候需要注意类型的定义是否符合转换的要求:
    在这里插入图片描述
    • 本图中 T1 定义的范围是 0-10, 而 T2 是 1-10
    • 因此当将 V1 强转成 T2 类型的时候,范围不符合,就报错

运算符

  • 在 Ada 语言中,modrem 都是用于实现**模运算(也就是求余数)**的操作符,但是他们在处理负数时的行为不同。

mod: mod 操作符在 Ada 中执行的是数学上的模运算。它的结果总是非负的。例如,-7 mod 5 会得到 3,因为 -7 可以被表达为 -2 * 5 + 3。

rem: rem 操作符执行的是“余数”运算,其结果的符号和被除数相同。例如,-7 rem 5 会得到 -2,因为 -7 可以被表达为 -1 * 5 - 2。

这两个操作符的这种行为和其他一些编程语言(如 Python)中的模运算操作符的行为是不同的。在使用它们的时候,需要特别注意负数的处理。

属性(Attributes)

  • 在 Ada 语言中,属性(attributes)是一种特殊的结构,用于从某个实体中提取特定的信息或者执行特定的操作。实体可以是一个对象、类型、子程序等。

  • 每个属性都由一个名字和一个前缀组成,前缀通常是类型的名称,而名字则描述了要获取的信息或要执行的操作。属性通过单引号(')来访问,格式为 Prefix'Attribute

  • 例如,假设你有一个数组 A,你可以使用 A'Length 来获取这个数组的长度。

  • Ada 提供了许多内置的属性,比如:

    • 'First'Last:获取一个范围或数组的首个和最后一个元素的索引。

    • 'Length:获取一个数组的长度。

    • 'Image:获取一个标量对象或类型的字符串表示。
      在这里插入图片描述

    • 'Value:从字符串生成一个标量对象。

在这里插入图片描述

  • 下面是一个只能用于处理浮点数的属性集合(attributes set)
    在这里插入图片描述
  • 如果将 floating 转成 integer 要用 rounding 而不要用 truncation

练习

在这里插入图片描述

  • 修正版本:

    V : Integer := 7;
    
    # 不需要再次声明 V 而是直接赋值
    V := V + 5;
    

在这里插入图片描述

  • 这里的错误是新定义的数据类型 N 的范围太大了, 因此编译器会拒绝编译
    在这里插入图片描述

  • 在这个修正后的代码中,我们首先定义了一个类型为 Natural 的常量 ClassRoom,并将其初始化为 5。然后,我们定义了一个类型为 Natural 的变量 Next_ClassRoom,并将其初始化为 ClassRoom 的值加 1,即 6。

    什么时候需要加 constant 这个关键字进行限定呢?

    • 在 Ada 编程语言中,constant 关键字用于声明一个常量。一旦一个常量被初始化,它的值就不能再被改变。这个特性可以帮助避免在程序执行过程中意外地改变变量的值,增加代码的可读性和可维护性。

    • 你应该在以下情况下使用 constant 关键字:

      • 当你想定义一个在程序生命周期中保持不变的值时。例如,你可能想定义物理常数(如光速或派)、数学常数(如 π 或 e)或者应用程序特有的常数(如最大用户数量或默认超时时间)。

      • 当你想保护一个变量不被修改,防止在后续的代码中意外地改变它的值时。

    • 请注意,尽管 constant 关键字可以帮助提高代码的健壮性和可读性,但过度使用它可能会导致代码难以理解和维护。因此,你应该根据需要适当地使用它

在这里插入图片描述

  • T2 继承了 T1 的类型,但是却扩展了 T1 的定义范围,这是不被允许的。T2 只能是 T1 的子集

在这里插入图片描述
在这里插入图片描述

  • 下面是代码的执行步骤:

    • F 被初始化为 7.6Div 被初始化为 10

    • beginend 之间的代码块中,首先将 F 的值进行整型转换,Float 类型的 7.6 转为 Integer 类型后变为 7。

    • 之后 7 被 Div(即 10)整除,结果为 0,再将这个 0 转换为 Float 类型,结果仍为 0.0。

    • 最后,Put_Line 函数打印出 F 的值,因为 F 的值现在是 0.0,所以输出将会是 “0.0”。

在这里插入图片描述

  • 在 Ada 中,'Val 和 'Value 是两个预定义的属性,它们都用于从一个表示形式转换到对应的类型。不过,它们在用法上有所不同。

  • 'Val 是用来从整数或者字符类型转换到对应的枚举类型。例如,对于枚举类型 type T is (A, B, C);,你可以使用 T'Val(1) 来获取枚举类型的第二个值,也就是 B

  • 'Value 是用来从字符串转换到对应的类型。对于枚举类型 type T is (A, B, C);,你可以使用 T'Value("B") 来获取枚举类型的 B 值。

  • 需要注意的是,'Value 只能接受字符串类型的参数,而 'Val 可以接受整数或者字符类型的参数。

type T is (A, B, C);

V1 : T := T'Val(1);  -- V1 = B
V2 : T := T'Value("B");  -- V2 = B

在这里插入图片描述

  • ada 大小写不做区分
  • ada 字符串中的空格会被 Value 属性自动删除

在这里插入图片描述

  • ada 的range只接受递增的定义,因此这里的 T 其实是空集

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/537755.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

瑞吉外卖 - 公共字段自动填充功能(10)

某马瑞吉外卖单体架构项目完整开发文档,基于 Spring Boot 2.7.11 JDK 11。预计 5 月 20 日前更新完成,有需要的胖友记得一键三连,关注主页 “瑞吉外卖” 专栏获取最新文章。 相关资料:https://pan.baidu.com/s/1rO1Vytcp67mcw-PD…

每日一练 | 网络工程师软考真题 Day3

1、以下图的两种编码方案分别是 。 A.①差分曼彻斯特编码,②双相码 B.①NRZ编码,②差分曼彻斯特编码 C.①NRZ-I编码,②曼彻斯特编码 D.①极性码,②双极性码 2、假设模拟…

windows下安装emsdk

先从github上下载emsdk工程: # Get the emsdk repo git clone https://github.com/emscripten-core/emsdk.git# Enter that directory cd emsdkgit pull 更新到最新代码 clone 工程可以在 git bash here 命令行下: 执行下面的指令用cmd命令行&#xf…

chatgpt赋能Python-numpy_加速

介绍 NumPy是Python编程语言的数值计算扩展库。它包括一个强大的N维数组对象和用于处理这些数组的函数。NumPy是一个基于Python的免费开源软件项目,由社区驱动。这个库提供了一种高效的存储和处理大型矩阵数据的方式,同时也提供了非常高效的处理大量数据…

chatgpt赋能Python-jinja_python

Jinja Python介绍及SEO优化 Jinja是一个流行的Python模板引擎,它允许开发人员使用简单的语法来生成动态内容。在本文中,我们将介绍Jinja的基础知识,并探讨如何将其应用于搜索引擎优化。 Jinja Python介绍 Jinja是Python语言的一种模板引擎…

Java面向对象程序设计实验报告(实验一 面向对象基础练习)

✨作者:命运之光 ✨ 专栏:Java面向对象程序设计实验报告 目录 ✨一、需求分析 ✨二、概要设计 ✨三、详细设计 ✨四、调试分析 ✨附录:源代码(带注释) 实验一 面向对象基础练习 实验环境:EclipseJDK …

MindFusion.JavaScript Pack 2023 crack

MindFusion.JavaScript Pack 2023 crack 径向树布局-添加了新的类,它将树级别排列在围绕根的同心圆中。 套索缩放工具-控件现在支持使用套索工具进行缩放的几种方法: 可以将行为属性设置为“缩放”以始终绘制缩放套索。 用户可以使用修改键和鼠标左键绘制…

如何用Nginx快速搭建个人下载站?

1.开篇 我们在下载Nginx的时候,发现其下载地址遵循一定的规则。 发现其下载地址为:https://nginx.org/download/nginx-1.24.0.tar.gz, 可以猜测出其下载的主页为:https://nginx.org/download 果然,该页面提供了各个版…

chatgpt赋能Python-num_python

NumPy简介:为什么它对数据科学如此重要? 什么是NumPy? NumPy是一种Python库,帮助程序员在Python中进行高度优化的科学计算。NumPy提供了许多独特的工具,以帮助数据科学家和工程师进行线性代数、离散傅立叶变换和其他…

三十七、微服务保护

1、初识Sentinel 1.1雪崩问题 微服务调用链路中的某个服务故障,引起整个链路中的所有微服务都不可用,这就是雪崩。 解决雪崩问题的常见方式有四种: 超时处理:设定超时时间,请求超过一定时间没有响应就返回错误信息&am…

DEJA_VU3D - Cesium功能集 之 109-三角形(标绘+编辑)

前言 编写这个专栏主要目的是对工作之中基于Cesium实现过的功能进行整合,有自己琢磨实现的,也有参考其他大神后整理实现的,初步算了算现在有差不多实现小140个左右的功能,后续也会不断的追加,所以暂时打算一周2-3更的样子来更新本专栏(每篇博文都会奉上完整demo的源代码…

HTTP第15讲——HTTP的连接管理

短连接 HTTP 协议最初(0.9/1.0)是个非常简单的协议,通信过程也采用了简单的“请求 - 应答”方式。 它底层的数据传输基于 TCP/IP,每次发送请求前需要先与服务器建立连接,收到响应报文后会立即关闭连接。 因为客户端与…

chatgpt赋能Python-numpy_数据归一化

Numpy 数据归一化:介绍和原理 随着大数据和机器学习的发展,数据预处理变得越来越重要。对于数据进行标准化和归一化是其中的一项常见操作。本文将介绍numpy中的数据归一化,包括其原理和实现方法。 什么是数据归一化? 在数据处理…

Spring AOP的概念和使用

什么是AOP AOP是一种思想,它叫做面向切面编程,简单的来说就是对某一类事请做集中处理。比如说:登录效验功能,在使用AOP之前,我们进行登录效验需要在每个方法中写一遍登录效验的代码;使用AOP后,…

chatgpt赋能Python-numpy提取数据

Numpy提取数据:一种高效处理数据的方法 Numpy是Python中一个用于科学计算的库,它提供了一些高效的数值计算工具和数据结构。其中一个重要的功能是对大量数据进行高效的处理与分析。本文将介绍Numpy提取数据的用法,帮助您更高效地处理数据。 …

Java参数绑定(包括按值传递和按引用传递)

在Java中,参数绑定是一种将实际参数值传递给方法或函数的过程。在方法调用中,参数绑定决定了方法的形式参数(在方法声明中定义的参数)和实际参数(传递给方法的参数)之间的关系。 Java中的参数绑定有两种形…

chatgpt赋能Python-numpy数据归一化

Numpy数据归一化:什么是归一化以及为什么要归一化? 当我们处理数据时,我们常常要将它们归一化。归一化是将数值范围缩放到标准范围内的过程。这可以确保不同的特征或变量在计算机算法中具有相同的权重。这对于一些机器学习算法、人工神经网络…

chatgpt赋能Python-mac_python怎么用

如何在Mac上使用Python进行编程? 如果你是一位Python开发者,想在Mac上进行编程,本篇文章将会告诉你如何使用Python在Mac上进行编程。首先,你需要确认你的Mac上是否安装了Python,如果你是新手,可以去Python…

nginx(七十六)nginx与HTTP请求行的深入探讨

一 nginx与请求行相关 nginx处理来自客户端的HTTP请求行和请求头 ① 关于请求行的变量 $request $request_method SP $request_uri SP $server_protocol "案例讲解" ② nginx作为服务端接收关于method控制 1) 请求方法和支持的协议版本包含如下: -->协议…

离线安装apisix

公司部分机器因为某些原因无法联网,只能离线安装apisix,折腾了很久,走了很多弯路,记录一下安装过程。 下载所有的包 安装epel源 sudo yum install epel-release在home下创建文件夹/apisix-dependence 下载apache-apisix-repo以…