Система типов называется безопасной (англ.safe) или надёжной (англ.sound), если в программах, прошедших проверку согласования типов (англ.well-typed programs или well-formed programs), исключена возможность возникновения ошибок согласования типов во время выполнения[1][2][3][4][5][6].
Ошибка согласования типов или ошибка типизации (англ.type error) — несогласованность типов компонентов выражений в программе, например попытка использовать целое число в роли функции[7]. Пропущенные ошибки согласования типов на этапе выполнения могут приводить к багам и даже крахам программ. Безопасность языка не является синонимом полного отсутствия багов, но, по меньшей мере, они становятся исследуемы в рамках семантики языка (формальной или неформальной)[8].
Иногда безопасность рассматривается как свойство конкретной программы, а не языка, на котором она написана — по той причине, что некоторые типобезопасные языки разрешают обойти или нарушить систему типов, если программист практикует скудную типобезопасность. Распространено мнение, что такие возможности на практике оказываются необходимостью, но это вымысел[9]. Понятие о «безопасности программы» важно в том смысле, что реализация безопасного языка сама может быть небезопасной. Раскрутка компилятора решает эту проблему, обеспечивая языку безопасность не только в теории, но и на практике.
Робину Милнеру принадлежит выражение «Программы, прошедшие проверку типов, не могут „сбиться с пути истинного“»[10].
Иначе говоря, безопасная система типов предотвращает заведомо ошибочные операции, связанные с неверными типами. Например, выражение 3 / "Hello, World" очевидно является ошибочным, поскольку арифметикане определяет операцию деления числа на строку. Формально, безопасность означает гарантию того, что значение любого выражения, прошедшего проверку типов, и имеющего тип τ, является истинным элементом множества значений τ, то есть будет лежать в границах диапазона значений, допустимого статическим типом этого выражения. На самом деле, в этом требовании есть нюансы — см. подтипы[англ.] и полиморфизм для сложных случаев.
Кроме того, при интенсивном использовании механизмов определения новых типов предотвращаются логические ошибки, проистекающие из семантики различных типов[5]. Например, и миллиметры, и дюймы являются единицами длины и могут представляться целыми числами, но будет ошибкой вычитать дюймы из миллиметров, и развитая система типов не допустит этого (разумеется, при условии, что программист использует для значений, выраженных в различных единицах, различные типы данных, а не описывает и те, и другие как переменные целого типа). Другими словами, безопасность языка означает, что язык защищает программиста от его собственных возможных ошибок[9].
Многие языки системного программирования (например, Ада, Си, C++) предусматривают ненадёжные (англ.unsound) или небезопасные (англ.unsafe) операции, предназначенные для возможности нарушить (англ.violate) систему типов — см. приведение типа и каламбур типизации. В одних случаях это допускается лишь в ограниченных частях программы, в других — неотличимо от хорошо типизированных операций[11].
В мейнстриме[уточнить] нередко встречается сужение понятия типобезопасности до «безопасности типов в отношении доступа к памяти» (англ.memory type safety), означающее, что компоненты объектов одного агрегатного типа не могут обращаться к ячейкам памяти, выделенным под объекты другого типа. Безопасность доступа к памяти означает запрещение возможности скопировать произвольную цепочку бит из одной области памяти в другую. Например, если язык предусматривает тип t, имеющий ограниченный спектр допустимых значений, и предоставляет возможность скопировать нетипизированные данные в переменную этого типа, то это не является типобезопасным, поскольку потенциально допускает, что переменная типа t будет иметь значение, не являющееся допустимым для типа t. И, в частности, если такой небезопасный язык позволяет записать произвольное целое значение в переменную, имеющую тип «указатель», то небезопасность доступа к памяти очевидна (см. Висячий указатель). Примерами небезопасных языков служат Си и C++[4]. В сообществах этих языков часто называют «безопасными» любые операции, непосредственно не приводящие к краху программы. Безопасность доступа к памяти также означает предотвращение возможности переполнения буфера, например, попытки записи крупноразмерных объектов в ячейки, выделенные для объектов другого типа меньшего размера.
Надёжные статические системы типов консервативны (избыточны) в том смысле, что отвергают даже программы, которые исполнились бы корректно. Причина этого заключается в том, что для любого тьюринг-полного языка, множество программ, которые могут порождать ошибки согласования типов во время выполнения, алгоритмически неразрешимо (см. проблема остановки)[12][13]. Как следствие, такие системы типов обеспечивают степень защиты, существенно более высокую, чем это необходимо для обеспечения безопасности доступа к памяти. С другой стороны, безопасность некоторых действий не может быть доказана статически и должна контролироваться динамически — например, индексация массива с произвольным доступом. Такой контроль может осуществляться либо рантайм-системой самого языка, либо непосредственно функциями, реализующими подобные потенциально небезопасные операции.
Сильнодинамически типизируемые языки (например, Лисп➤, Smalltalk) не допускают повреждения данных за счёт того, что программа, пытающаяся преобразовать значение к несовместимому типу, порождает исключение. К достоинствам сильной динамической типизации перед типобезопасностью можно отнести отсутствие консервативности, и, как следствие, расширение спектра решаемых задач программирования. Ценой этого становится неизбежное снижение быстродействия программ, а также необходимость существенно бо́льшего количества пробных запусков для выявления возможных ошибок. Поэтому многие языки комбинируют возможности статического и динамического контроля согласования типов тем или иным образом.[14][12][1]
Примеры безопасных языков
Ада
Ада (наиболее типобезопасный язык в семействе Паскаля) ориентирована на разработку надёжных встраиваемых систем, драйверов и других задач системного программирования. Для реализации критичных секций Ada предоставляет ряд небезопасных конструкций, имена которых обычно начинаются с Unchecked_.
Язык SPARK является подмножеством Ады. Из него устранены небезопасные возможности, но добавлены возможности проектирования по контракту. SPARK исключает возможность возникновения висячих указателей посредством исключения самой возможности динамического выделения памяти. Статически проверяемые контракты были добавлены в Ada2012.
Хоар в тьюринговской лекции утверждал, что для обеспечения надёжности мало статических проверок — надёжность в первую очередь является следствием простоты[15]. Тогда же он предсказал, что сложность Ады станет причиной катастроф.
Исследовательский язык Cyclone является безопасным диалектом языка Си, заимствующим многие идеи из ML➤ (включая типобезопасный параметрический полиморфизм). Cyclone предназначен для тех же задач, что и Си, и после осуществления всех проверок компилятор порождает код на ANSI C. Cyclone не требуетвиртуальной машины или сборки мусора для обеспечения динамической безопасности — вместо этого он основан на управлении памятью посредством регионов. Cyclone устанавливает более высокую планку требований безопасности исходного кода, и из-за небезопасной природы Си портирование даже простых программ с Си на Cyclone может потребовать определённой работы, хотя немалая её часть может быть проделана в рамках Си до смены компилятора. Поэтому Cyclone часто определяют не как диалект Си, а как «язык, синтаксически и семантически похожий на Си».
Rust
Многие идеи Cyclone нашли воплощение в языке Rust. Помимо сильной статической типизации в язык добавлен статический анализ времени жизни указателей, основанный на концепции «владения». Реализованы статические ограничения, блокирующие потенциально некорректный доступ к памяти: отсутствуют нулевые указатели, невозможно появление неинициализированных и деинициализированных переменных, запрещено совместное использование изменяемых переменных несколькими задачами. Проверка на выход за пределы массива обязательна.
Haskell
Haskell (потомок ML➤) изначально разрабатывался как полнотиповыйчистый язык, что должно было сделать поведение программ на нём ещё более предсказуемым, чем на ранних диалектах ML➤. Однако, позже в стандарте языка были предусмотрены небезопасные операции[16][17], необходимые в повседневной практике, хотя и отмеченные соответствующими идентификаторами (начинающимися с unsafe)[18].
Haskell также предоставляет возможности слабойдинамической типизации, и в стандарт языка была включена реализация механизма обработки исключений посредством этих возможностей. Её использование может приводить к аварийному завершению программ, за что Роберт Харпер назвал Хаскел «исключительно небезопасным»[18]. Он считает неприемлемым тот факт, что исключения имеют тип, определённый пользователем в контексте класса типовTypeable, с учётом того, что исключения генерируются безопасным кодом (за пределами монадыIO); и классифицирует выдаваемое компилятором сообщение о внутренней ошибке как несоответствующее слогану Милнера➤. В последовавшем обсуждении было показано, как можно было бы реализовать в Хаскеле статически типобезопасные исключения в стиле Standard ML➤.
Common Lisp является сильно динамически типизируемым языком, но предусматривает возможность явно (манифестно[англ.]) назначать типы (а компилятор SBCL способен сам их выводить), однако, эта возможность используется для оптимизации и усиления динамических проверок и не означает статическую типобезопасность. Программист может установить для компилятора сниженный уровень динамических проверок с целью повышения быстродействия, и скомпилированная таким образом программа уже не может считаться безопасной[20][21].
Язык Scheme также является сильно динамически типизируемым языком, но компилятор Stalin[англ.] статически выводит типы, используя их для агрессивной оптимизации программ. Языки «Typed Racket» (расширение Racket Scheme) и Shen[англ.] типобезопасны. Clojure сочетает сильный динамический и статический контроль типов.
Следствием этого стало то, что потомки ML зачастую априори считаются типобезопасными, даже несмотря на то, что некоторые из них откладывают значимые проверки на этап выполнения программы (OCaml), либо отклоняются от семантики, для которой построено доказательство надёжности, и содержат небезопасные возможности явным образом (Haskell➤). Для языков семейства ML характерна развитая поддержка алгебраических типов данных, использование которых существенно способствует предотвращению логических ошибок, что также поддерживает впечатление типобезопасности.
Некоторые потомки ML так же являются инструментами интерактивного доказательства (Idris, Mercury, Agda). Многие из них, хотя и могли бы использоваться для непосредственной разработки программ с доказанной надёжностью, чаще используются для верификации программ на других языках — из-за таких причин как высокая трудоёмкость использования, низкое быстродействие, отсутствие FFI[англ.] и прочее. Среди потомков ML с доказанной надёжностью выделяются как ориентированные на промышленное применение языки Standard ML➤ и прототип его дальнейшего развития successor ML[22] (ранее известный как «ML2000»).
Standard ML
Язык Standard ML (старший в семействе языков ML➤) ориентирован на разработку крупномасштабных[англ.] программ промышленного быстродействия[23]. Язык имеет строгое формальное определение и его статическая и динамическая безопасность доказана[24]. После статической проверки согласованности интерфейсов компонентов программы (в том числе порождаемых — см. функторы ML), дальнейший контроль безопасности поддерживается рантайм-системой. Как следствие, даже содержащая ошибку программа на Standard ML всегда продолжает вести себя как ML-программа: она может навечно уйти в расчёты или выдать пользователю сообщение об ошибке, но она не можетобрушиться[9].
Однако, некоторые реализации (SML/NJ[англ.], Mythryl[англ.], MLton) включают нестандартные библиотеки, предоставляющие определённые небезопасные операции (их идентификаторы начинаются с Unsafe). Эти возможности необходимы для внешнеязыкового интерфейса[англ.] этих реализаций, обеспечивающего взаимодействие с не-ML-кодом (обычно это код на Си, реализующий критичные по скорости компоненты программ), который может требовать своеобразного битового представления данных. Кроме того, многие реализации Standard ML, хотя сами написаны на нём самом, используют рантайм-систему, написанную на Си. Другим примером является режим REPL компилятора SML/NJ[англ.], использующий небезопасные операции для исполнения интерактивно вводимого программистом кода.
Lawrence C. Paulson. ML for the Working Programmer (англ.). — 2nd. — Cambridge University Press, 1996. — 492 p. — ISBN 0-521-57050-6 (твёрдый переплёт), 0-521-56543-X (мягкий переплёт).
John C. Mitchell. Concepts in Programming Languages (англ.). — Cambridge University Press, 2004. — ISBN 0-511-04091-1 (eBook in netLibrary); 0-521-78098-5 (hardback).
Kekaisaran Romawi pada 125. Dinasti Nerva–Antoninus adalah sebuah dinasti dari tujuh Kaisar Romawi yang memerintah Kekaisaran Romawi dari 96 SM sampai 192 M. Kaisar-kaisar tersebut adalah Nerva, Trajan, Hadrian, Antoninus Pius, Lucius Verus, Marcus Aurelius, dan Commodus. Lima dari enam suksesi pertama dikenal karena mengadopsi kandidat pilihannya menjadi penerusnya. Di bawah hukum Romawi, sebuah adopsi mendirikan sebuah penopang sah sekuat kekerabatan. Karena itu, seluruh kaisar Nerva-Anto...
Artikel ini sebatang kara, artinya tidak ada artikel lain yang memiliki pranala balik ke halaman ini.Bantulah menambah pranala ke artikel ini dari artikel yang berhubungan atau coba peralatan pencari pranala.Tag ini diberikan pada Februari 2023. Fujita adalah nama Jepang. Tokoh-tokoh dengan nama Jepang ini antara lain: Pemain sepak bola Jepang Ibuki Fujita Kazuki Fujita Ken Fujita Kohei Fujita Masato Fujita Naoyuki Fujita Satoshi Fujita Seiya Fujita Shinichi Fujita Shinya Fujita Taisei Fujita...
Azis GagapAzis pada tahun 2023LahirMuhammad Azis22 Desember 1973 (umur 50)Jakarta, IndonesiaKebangsaanIndonesiaNama lainAzis GagapPekerjaanPemeranpelawakTahun aktif1991—sekarangSuami/istri Nurhasanah Dewi Keke (m. 2016) Anak3 Muhammad Azis dikenal sebagai Azis Gagap (lahir 22 Desember 1973) adalah pemeran dan pelawak Indonesia. Karier Azis mengawali karier melawak melalui panggung lenong dari satu kelurahan ke kelurahan lain.[1] Selanju...
Beginning of a year in a lunar calendar This article is about the family of festivals worldwide. For specific festivals, see § Celebrations by region. For the Chinese celebration in particular, see Chinese New Year. Lunar New YearTop to bottom, left to right: Fireworks display at Victoria Harbour, Hong Kong A lion dance performance in Kuala Lumpur Chinese New Year celebrations in Singapore Chinese New Year parade in Manhattan's Chinatown, New York City A family gathering to make bánh t...
Eugène Raynaldy Fonctions Député 1919-1928Sénateur 1930-1938 Gouvernement IIIe République Groupe politique GRD (1919-1928)UR (1930-1938) Biographie Date de naissance 23 décembre 1869 Date de décès 15 juin 1938 (à 68 ans) Résidence Aveyron modifier Jean Jacques dit Eugène Raynaldy est un homme politique français né le 23 décembre 1869 à Rodez (Aveyron), fils d'un aubergiste, et décédé le 15 juin 1938 à Rodez[1]. Biographie Avocat au barreau de Rodez, Eugène...
Bus station in Brisbane, Australia King George SquareGeneral informationLocationKing George Square, BrisbaneCoordinates27°28′07″S 153°01′27″E / 27.468603°S 153.024136°E / -27.468603; 153.024136Owned byDepartment of Transport & Main RoadsOperated byTransport for BrisbaneLine(s)Northern BuswayPlatforms2Bus stands12ConstructionStructure typeUndergroundBicycle facilitiesKing George Square Cycle CentreAccessibleYesOther informationStation code010781 (platfor...
Not to be confused with Tabarca. Place in Jendouba Governorate, TunisiaTabarka طبرقةTabarkaLocation in TunisiaCoordinates: 36°57′16″N 8°45′29″E / 36.95444°N 8.75806°E / 36.95444; 8.75806Country TunisiaGovernorateJendouba GovernorateElevation15.4 ft (4.7 m)Population (2014) • City19,819 • Density10,090/sq mi (3,894/km2) • Urban41,293 • Urban density80/sq mi (31/km2) •...
Une terre arable (du latin arabilis « labourable », dérivé de arō « labourer ») est une terre qui peut être labourée ou cultivée. Selon la FAO, les terres arables sont les terres affectées à des cultures temporaires (les zones de polyculture ne sont comptées qu'une fois), les prairies temporaires à faucher ou à pâturer, les cultures maraîchères et jardins potagers, et les jachères temporaires (moins de cinq ans)[1]. Quand ils sont intensivement cultivés...
Michael Dougherty Michael Dougherty (Columbus, 28 ottobre 1974) è un regista, sceneggiatore e produttore cinematografico statunitense. Indice 1 Carriera 1.1 Fumetti 2 Filmografia 2.1 Regista 2.2 Sceneggiatore 2.3 Produttore 3 Riconoscimenti 4 Altri progetti 5 Collegamenti esterni Carriera Fumetti Nel corso del 2006, il regista e gli sceneggiatori del reboot Superman Returns, Singer, Harris e Dougherty, hanno scritto quattro fumetti che raccontano i fatti antecedenti al film in questione. I r...
Музей природы и экологии Республики БеларусьМузей прыроды і экалогіі Рэспублікі Беларусь Дата основания 25 июля 1983 года Дата открытия Февраль 1992 года Местонахождение Минск Адрес г. Минск, улица Карла Маркса, д.12, каб.11 Сайт pryroda.histmuseum.by/ru/ Медиафайлы на Викискладе Музей ...
يفتقر محتوى هذه المقالة إلى الاستشهاد بمصادر. فضلاً، ساهم في تطوير هذه المقالة من خلال إضافة مصادر موثوق بها. أي معلومات غير موثقة يمكن التشكيك بها وإزالتها. (مارس 2016) رمي الجلة في الألعاب الأولمبية الصيفية 2012 - رجال في الألعاب الأولمبية الصيفية تعديل مصدري - تعديل طالع أ...
У Вікіпедії є статті про інших людей із прізвищем Вишеславський. Леонід Миколайович Вишеславський Портрет Леоніда Вишеславського, зроблений його донькою Іриною, 1984 рікНародився 5 (18) березня 1914Миколаїв, Російська імперіяПомер 27 грудня 2002(2002-12-27)[1] (88 років)Київ, Украї�...
Not to be confused with Klang or Keluang in Indonesia. Town and district capital in Johor, MalaysiaKluang كلواڠTown and district capital SealMotto(s): Kluang Maju Sejahtera, Bandar Berdaya Huni (Prosperous Kluang, A Livable City)KluangCoordinates: 2°2′1″N 103°19′10″E / 2.03361°N 103.31944°E / 2.03361; 103.31944Country MalaysiaState JohorDistrict KluangEstablishment1915Granted municipal status8 May 2001Government • TypeLocal govern...
لمعانٍ أخرى، طالع جيرو (توضيح). هذه المقالة يتيمة إذ تصل إليها مقالات أخرى قليلة جدًا. فضلًا، ساعد بإضافة وصلة إليها في مقالات متعلقة بها. (نوفمبر 2023) هذه مقالة غير مراجعة. ينبغي أن يزال هذا القالب بعد أن يراجعها محرر؛ إذا لزم الأمر فيجب أن توسم المقالة بقوالب الصيانة ا�...
Мануши Чхиллархинди मानुषी छिल्लर Дата рождения 14 мая 1997(1997-05-14)[1][2] (27 лет) Место рождения Рохтак, Харьяна, Индия[3] Гражданство Индия Род деятельности участница конкурса красоты, актриса, киноактриса Внешний вид Рост 1,75 м Цвет волос коричневы�...
Questa voce o sezione sull'argomento attori italiani non è ancora formattata secondo gli standard. Contribuisci a migliorarla secondo le convenzioni di Wikipedia. Segui i suggerimenti del progetto di riferimento. Lucia Modugno Lucia Modugno (Bari, 9 luglio 1932) è un'attrice, regista teatrale e scrittrice italiana. Indice 1 Biografia 1.1 Attrice e regista 1.2 Scrittrice 2 Filmografia 2.1 Cinema 2.2 Televisione 3 Teatro 4 La Compagnia teatrale di Lucia Modugno - Dal 1980 al 2010 5 Note...
Selena RoyleCuplikan publisitas dari tahun 1948Lahir(1904-11-06)6 November 1904New York City, Amerika SerikatMeninggal23 April 1983(1983-04-23) (umur 78)Guadalajara, Jalisco, MeksikoNama lainSelena RoyalePekerjaanPemeran, penulisTahun aktif1921-1957Suami/istriEarle Larrimore (m. 1932; bercerai 1942) Georges Renavent (m. 1948; wafat 1969) Selena Royle (6 November 1904 ...
Hình chiếu bề mặt của các cơ quan chính của thân, sử dụng cột sống và lồng xương sườn làm điểm tham chiếu chính của giải phẫu bề mặt Hệ bài tiết là một hệ thống sinh học thụ động giúp loại bỏ các vật liệu dư thừa, không cần thiết khỏi dịch cơ thể của sinh vật, để giúp duy trì cân bằng nội môi hóa học và ngăn ngừa nguy hại cho cơ thể. Chức năng kép của các hệ thống ...
Island and neighborhood in New York City Blackwell's Island redirects here. For the 1939 film, see Blackwell's Island (film). For other uses, see Roosevelt Island (disambiguation). Roosevelt IslandMinnehanonck / Varken Eylandt[a] ('Hog Island') / Manning's Island / Blackwell's Island / Welfare IslandSeen in July 2017 looking southwardLocation in New York CityGeographyLocationEast River, Manhattan, New York, United StatesCoordinates40°45′41″N 73°57′03″W / 40.7...