Разыменование нулевого указателя остаётся одной из основных проблем в современных объектно-ориентированных языках. Очевидное добавление ключевых слов, чтобы различать между всегда ненулевыми и возможно нулевыми ссылками, оказывается недостаточным во время инициализации объекта, когда некоторые поля, объявленные как всегда ненулевые, могут временно быть нулевыми до окончания инициализации. Предлагаемое решение избегает явного кодирования этих промежуточных состояний в текстах программ в пользу статически проверяемых правил допустимости, которые не зависят от специальных условно ненулевых типов. Рассматриваются примеры инициализации объектов, предложенные ранее, и представляются новые для сравнения применимости различных подходов. Удобство использования предлагаемой схемы оценивается на открытых библиотеках с миллионом строк кода, которые были адаптированы, чтобы удовлетворять этим правилам.
Обеспечение практической безопасности пустых ссылок
Обеспечение практической безопасности пустых ссылок
Язык статьиАнглийский
Аннотация
Ключевые слова
DOI10.31144/si.2307-6410.2017.n10.p45-56
УДК004.052.42
Номер
№ 10,
Страницы45-56
Файл
kogtenkov.pdf
(504.72 КБ)