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

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

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


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

Date: 2019-10-22 01:17 pm (UTC)
elglin: (Default)
From: [personal profile] elglin
А разве вопрос не в компиляторе и его варнингах?
Есть же у нас size_t, почему бы не заиметь tcp_port_t или network_uint_t?
Да, придется использовать самописную альтернативу htons/htonl или оборачивать, но я тут не вижу принципиальной разницы между плюсами и С.
Но я не сварщик, я в свое время писал htons/htonl, и мне было норм. Правда, тогда и за unsigned int вместо size_t по рукам больно не били.

Date: 2019-10-22 01:41 pm (UTC)
juan_gandhi: (Default)
From: [personal profile] juan_gandhi
Интересно. И главное, no implicit transformations чтобы!

Вот пока не знаю, раст для такого дела проканает или нет.

Date: 2019-10-22 04:10 pm (UTC)
filin: (Default)
From: [personal profile] filin
С виду — проканает. Там полноценная система типов и строгая типизация времени компиляции, с zero overhead.

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

Style Credit

Expand Cut Tags

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