HTML Diff
1 added 1 removed
Original 2026-01-01
Modified 2026-02-26
1 <p>В этом уроке мы познакомимся с типами данных и узнаем, чем они полезны для разработчика. Также мы поговорим про типы как про множества. Это позволит понимать принципы работы TypeScript.</p>
1 <p>В этом уроке мы познакомимся с типами данных и узнаем, чем они полезны для разработчика. Также мы поговорим про типы как про множества. Это позволит понимать принципы работы TypeScript.</p>
2 <h2>Типы данных</h2>
2 <h2>Типы данных</h2>
3 <p>Семейство языков, в котором нет типов данных, называется<strong>ассемблером</strong>. Эти языки работают напрямую с процессором и оперируют его регистрами. В регистрах хранятся значения, которые с точки зрения языка считаются числами, а что закодировано за этим числом, должен определять сам программист. Это может быть строка или часть картинки.</p>
3 <p>Семейство языков, в котором нет типов данных, называется<strong>ассемблером</strong>. Эти языки работают напрямую с процессором и оперируют его регистрами. В регистрах хранятся значения, которые с точки зрения языка считаются числами, а что закодировано за этим числом, должен определять сам программист. Это может быть строка или часть картинки.</p>
4 <p>Главная проблема такого подхода - отсутствие безопасности. Программа не выдаст ошибку, если мы случайно сделаем что-то неправильное со строкой. С точки зрения процессора и языка программирования, строки нет - есть число, и мы выполняем над ним какие-то операции. В итоге программа работает всегда, но результат неверный. Нужен высокий уровень внимательности, чтобы программировать в таком режиме.</p>
4 <p>Главная проблема такого подхода - отсутствие безопасности. Программа не выдаст ошибку, если мы случайно сделаем что-то неправильное со строкой. С точки зрения процессора и языка программирования, строки нет - есть число, и мы выполняем над ним какие-то операции. В итоге программа работает всегда, но результат неверный. Нужен высокий уровень внимательности, чтобы программировать в таком режиме.</p>
5 <p>Ситуация исправилась, когда появились типы данных в высокоуровневых языках. Они позволили выполнить две задачи:</p>
5 <p>Ситуация исправилась, когда появились типы данных в высокоуровневых языках. Они позволили выполнить две задачи:</p>
6 <ul><li>описать и ограничить множество всех значений конкретного типа</li>
6 <ul><li>описать и ограничить множество всех значений конкретного типа</li>
7 <li>определить операции, которые возможно выполнить с этим типом</li>
7 <li>определить операции, которые возможно выполнить с этим типом</li>
8 </ul><p><strong>Тип данных</strong>- это множество всех значений и набор допустимых операций над ними. Это обеспечивает<strong>типобезопасность</strong>. В JavaScript и других динамических языках мы получаем более сильную безопасность, чем в ассемблере. В статическом TypeScript уровень проверки совместимости типов выходит на другой уровень.</p>
8 </ul><p><strong>Тип данных</strong>- это множество всех значений и набор допустимых операций над ними. Это обеспечивает<strong>типобезопасность</strong>. В JavaScript и других динамических языках мы получаем более сильную безопасность, чем в ассемблере. В статическом TypeScript уровень проверки совместимости типов выходит на другой уровень.</p>
9 <h2>Множества</h2>
9 <h2>Множества</h2>
10 <p>Если говорить про типы данных как про набор допустимых значений, то с одной стороны, это может быть ограничение числа по верхней и нижней границе. Например, так устроено в JavaScript. У нас есть Number для одного диапазона чисел и BigInt - для другого, когда нужно работать с огромными числами. С другой стороны, мы говорим про множества.</p>
10 <p>Если говорить про типы данных как про набор допустимых значений, то с одной стороны, это может быть ограничение числа по верхней и нижней границе. Например, так устроено в JavaScript. У нас есть Number для одного диапазона чисел и BigInt - для другого, когда нужно работать с огромными числами. С другой стороны, мы говорим про множества.</p>
11 <p>Взгляд на типы как на множества играет важную роль. Это связано с тем, что система типов языка TypeScript умеет комбинировать типы так, как это делается в обычных множествах. Например, мы можем объединить два множества типов и получить новый тип, в который входят все элементы первого множества и второго множества. Так появляется Union Type:</p>
11 <p>Взгляд на типы как на множества играет важную роль. Это связано с тем, что система типов языка TypeScript умеет комбинировать типы так, как это делается в обычных множествах. Например, мы можем объединить два множества типов и получить новый тип, в который входят все элементы первого множества и второго множества. Так появляется Union Type:</p>
12 - <p>Примерно таким же способом можно построить пересечение и расширение типов и сделать другие действия с типами. Некоторые из них мы рассмотрим в курсе, но часть вещей останется за пределами. Главное - нужно престроить свое мышление на операции с типами. Так будет проще понимать принципы работы TypeScript и запоминать определенное поведение.</p>
12 + <p>Примерно таким же способом можно построить пересечение и расширение типов и сделать другие действия с типами. Некоторые из них мы рассмотрим в курсе, но часть вещей останется за пределами. Главное - нужно перестроить свое мышление на операции с типами. Так будет проще понимать принципы работы TypeScript и запоминать определенное поведение.</p>