Хобрук: Ваш путь к мастерству в программировании

Нельзя использовать дискриминант записи внутри записи

Мой код ниже. Компилятор не позволит мне использовать дискриминант var для управления размером строки name.

procedure p is

   type int is range 1 .. 10;
   type my (var : int) is record
      name : string (1 .. var); -- this var here is bad, why?
   end record;

   hh : my(6);

begin
   put (hh.name);
end p;

Сообщения об ошибках

p.adb:4:23: expected type "Standard.Integer"
p.adb:4:23: found type "int" defined at line 2
03.12.2014

  • Почему бы не использовать Ada.Strings.Bounded? 03.12.2014
  • Если вы используете Gnat, в сообщении об ошибке будет указано, что именно не так. Если бы вы сделали int подтипом Integer вместо нового типа, вы могли бы обнаружить другие ошибки. 03.12.2014

Ответы:


1

Это связано со строгой типизацией Ады. Ада позволяет вам объявлять новые целочисленные типы и типы с плавающей запятой, которые несовместимы друг с другом. Первоначальная цель состояла в том, чтобы предотвратить случайное использование значений с одним значением, как если бы они имели совершенно другое значение, например.

type Length is digits 15;  -- in meters
type Mass is digits 15;    -- in kilograms
L : Length;
M : Mass;

M := L;   -- error, caught at compile time

Компилятор улавливает это утверждение, которое не имеет никакого смысла, поскольку переменная «масса» не может содержать длину. Если бы все было просто Float или Long_Float, компилятор не смог бы это уловить.

Что вы сделали, так это создали еще один целочисленный тип, int. Как и в приведенном выше примере, значения вашего нового типа не могут быть автоматически преобразованы в Integer, который является типом индекса String. (String на самом деле определяется как array (Positive range <>) of Character with Pack;, но Positive является подтипом Integer, и значения могут автоматически преобразовываться между Positive и Integer, поскольку они действительно являются подтипами одного и того же базового типа.)

К сожалению, это тоже запрещено:

type my(var : int) is record
   name : string (1 .. Integer(var)); -- this var here is bad why?
end record;

из-за правила Ады, согласно которому дискриминант должен появляться в этом контексте один. Таким образом, ваш единственный вариант - сделать int подтипом:

subtype int is Integer range 0 .. 10;
type my(var : int) is record
   name : string (1 .. var); -- this var here is bad why?
end record;
03.12.2014
Новые материалы

Создание кнопочного меню с использованием HTML, CSS и JavaScript
Вы будете создавать кнопочное меню, которое имеет состояние наведения, а также позволяет вам выбирать кнопку при нажатии на нее. Финальный проект можно увидеть в этом Codepen . Шаг 1..

Внедрите OAuth в свои веб-приложения для повышения безопасности
OAuth — это широко распространенный стандарт авторизации, который позволяет приложениям получать доступ к ресурсам от имени пользователя, не раскрывая его пароль. Это позволяет пользователям..

Классы в JavaScript
class является образцом java Script Object. Конструкция «class» позволяет определять классы на основе прототипов с чистым, красивым синтаксисом. // define class Human class Human {..

Как свинг-трейдеры могут использовать ИИ для больших выигрышей
По мере того как все больше и больше профессиональных трейдеров и активных розничных трейдеров узнают о возможностях, которые предоставляет искусственный интеллект и машинное обучение для улучшения..

Как построить любой стол
Я разработчик программного обеспечения. Я люблю делать вещи и всегда любил. Для меня программирование всегда было способом создавать вещи, используя только компьютер и мое воображение...

Обзор: Машинное обучение: классификация
Только что закончил третий курс курса 4 часть специализации по машинному обучению . Как и второй курс, он был посвящен низкоуровневой работе алгоритмов машинного обучения. Что касается..

Разработка расширений Qlik Sense с qExt
Использование современных инструментов веб-разработки для разработки крутых расширений Вы когда-нибудь хотели кнопку для установки переменной в приложении Qlik Sense? Когда-нибудь просили..