beldmit: (Программизм)
[personal profile] beldmit
При работе с сетью нельзя абстрагироваться от порядка байтов, поэтому хотелось бы сделать так, чтобы его нельзя было проигнорировать при написании кода. Более того, у нас не просто число в BE — это номер порта, IP-адрес, номер последовательности TCP, контрольная сумма. Одно нельзя присваивать другому, даже если количество бит совпадает.

Решение известно — строгая типизация, то есть отдельные типы для портов, адресов, номеров. Кроме того, эти типы должны поддерживать конвертацию BE/LE. Boost.Endian нам не подходит, так как в проекте нет Boost.

Размер проекта около 40 тысяч строк на C++17. Если создать безопасные типы-обертки и переписать на них структуры заголовков, автоматически перестанут компилироваться все места, где есть работа с BE. Придется один раз пройтись по ним всем, зато новый код будет только безопасным.


Жаль, что на C это скорее всего не реализовать.

Date: 2019-10-23 03:20 pm (UTC)
From: [personal profile] bowhill
Безопасности от бездумия не бывает. Это хорошо, что хотя бы в Си нет "обёрток". Так что приходится думать, что делаешь.

Date: 2019-10-24 03:29 pm (UTC)
From: [personal profile] bowhill
Лишняя возможность проверки не лишняя, но спихивание мыслительных процессов на железку, как тенденция и как ожидание, заканчивается неудачно. Целая эпоха или культура в программировании проходит под мечтой о том, как любая кухарка сможет управлять программированием. Потому что это дёшево.

Теоретически, неопределённость порядка — проблема дизайна, ну а практически, увы, да, жизнь среди костылей.

Profile

beldmit: (Default)
Dmitry Belyavskiy

December 2025

S M T W T F S
 123456
78910111213
14151617181920
2122 2324252627
28 29 3031   

Most Popular Tags

Page Summary

Style Credit

Expand Cut Tags

No cut tags
Page generated Jan. 13th, 2026 06:04 pm
Powered by Dreamwidth Studios