>
>
Почему создание 64-битной версии програ…

Андрей Карпов
Статей: 643

Почему создание 64-битной версии программы может быть не простым делом?

К сожалению, несмотря на кажущуюся простоту, простой пересборки 32-битной программы под 64-битную платформу и исправления ошибок компилятора зачастую бывает недостаточно для обеспечения гарантированной работоспособности переносимого приложения. Основной проблемой при миграции на 64 бита является наличие в коде скрытых 64-битных ошибок, т.е. таких ситуаций, когда фрагмент кода, успешно работавший в 32-битном варианте, приводит к возникновению ошибки в 64-битной версии приложения.

Наиболее часто 64-битные ошибки проявляют себя в следующих участках кода:

  • код, основанный на некорректных представлениях о размере типов (например, что размер указателя всегда равен 4 байтам);
  • код, обрабатывающий большие массивы, размер которых на 64-битных системах превышает 2 гигабайта;
  • код записи и чтения данных;
  • код с битовыми операциями;
  • код со сложной адресной арифметикой;
  • старый код;

Детальное описание данного типа ошибок доступно в статье Коллекция примеров 64-битных ошибок в реальных программах. И хотя в конечном итоге все ошибки в коде, проявляющие себя при компиляции для 64-битных систем, связаны с неточным следованием идеологии стандарта языка Си/Си++, ни один реальный проект от них не застрахован.

Другой проблемой при миграции на 64-битную платформу может стать зависимость приложения от библиотек, не имеющих 64-битных версий, поскольку совместное использование 64-битной программы и 32-битной библиотеки в операционных системах семейства Windows невозможно.

Подробное описание процесса миграции и оценка времени и стоимости переноса программы на 64-битную платформу рассмотрены в данной статье.

Библиографический список