Набор манифеста - Manifest typing

В информатике манифестная типизация явная идентификация программист из тип каждой объявленной переменной. Например: если переменная Икс будет хранить целые числа, тогда его тип должен быть объявлен как целое число. Термин «манифестная типизация» часто используется вместе с термином скрытая типизация чтобы описать разницу между статический, время компиляции типовая принадлежность объекта и его время выполнения тип идентичности.

Напротив, некоторые языки программирования используют неявная типизация (a.k.a. вывод типа ), где тип выводится из контекста во время компиляции или позволяет динамическая типизация в котором переменная только что объявлена ​​и может быть присвоено значение любого типа во время выполнения.

Примеры

Рассмотрим следующий пример, написанный на Язык программирования C:

#включают <stdio.h>int главный(пустота) {    char s[] = «Тестовая строка»;    плавать Икс = 0.0;    int у = 0;    printf("Привет, мир!");    возвращаться 0;}

Обратите внимание, что переменные s, Икс, и у были объявлены как массив символов, число с плавающей запятой и целое число соответственно. Система типов отвергает во время компиляции такие заблуждения, как попытки добавить s и Икс.

Напротив, в Стандартный ML, то типы не требуется явного объявления. Вместо этого тип определяется типом присвоенного выражения.

позволять вал s = «Тестовая строка»    вал Икс = 0.0    вал у = 0в Распечатать "Привет, мир!"конец

В этой программе нет манифестных типов, но компилятор все равно делает вывод типы нить, настоящий и int для них, и отклонил бы выражение s + x как ошибка времени компиляции.

внешняя ссылка