|
|
||||||
Кому интересно поломать голову31.01.2015, 11:51. Показов 4552. Ответов 63
Метки нет (Все метки)
Привет!
Сейчас на работе думал с ума схожу - есть код, который (с виду) работать не должен, но он работает В итоге я разобрался почему он работает, но не сразу.Предлагаю вам подумать в как и когда может работать данный код (выкладываю именно в том контексте, в который я смотрел, больше не скажу, не интересно будет)
0
|
||||||
| 31.01.2015, 11:51 | |
|
Ответы с готовыми решениями:
63
Кому интересно. Покер Бинарные деревья ! кому интересно , сюда!;) прога странно работает=) кому интересно покопать? |
|
8973 / 4319 / 960
Регистрация: 15.11.2014
Сообщений: 9,760
|
||||||||
| 31.01.2015, 13:24 | ||||||||
|
Кликните здесь для просмотра всего текста
Но как можно было сразу не заметить наследования - хз. У нас такой момент в нотации указан: если нужно подсократить имя базового класса, то его можно называть parent, или созвучно: Parent, myparent, etc.
0
|
||||||||
|
4226 / 1796 / 211
Регистрация: 24.11.2009
Сообщений: 27,562
|
|
| 31.01.2015, 13:32 | |
|
0
|
|
|
8973 / 4319 / 960
Регистрация: 15.11.2014
Сообщений: 9,760
|
||
| 31.01.2015, 14:15 | ||
|
А вот в реализацию лишний раз не лезу. Зачем мне тратить время на изучение принципа действия функции, если по её имени итак понятно что она делает? В любом случае, прежде чем разбираться с "как она это делает", я выясняю "что она должна делать". Зная, что должна делать функция, понять, как она это делает обычно уже не сложно.
0
|
||
|
|
||
| 31.01.2015, 16:43 [ТС] | ||
|
0
|
||
|
4226 / 1796 / 211
Регистрация: 24.11.2009
Сообщений: 27,562
|
||
| 31.01.2015, 17:23 | ||
|
0
|
||
|
4226 / 1796 / 211
Регистрация: 24.11.2009
Сообщений: 27,562
|
|
| 31.01.2015, 17:25 | |
|
Срочно сюда:
cut обсуждать релаксатор.
0
|
|
|
710 / 283 / 16
Регистрация: 31.03.2013
Сообщений: 1,340
|
|
| 31.01.2015, 18:48 | |
|
ой-вей, наследование от стандартного контейнера, нет пути
1
|
|
|
8973 / 4319 / 960
Регистрация: 15.11.2014
Сообщений: 9,760
|
|
| 31.01.2015, 19:14 | |
|
0
|
|
| 31.01.2015, 20:01 | |
|
0
|
|
|
710 / 283 / 16
Регистрация: 31.03.2013
Сообщений: 1,340
|
||
| 01.02.2015, 18:22 | ||
|
0
|
||
|
8973 / 4319 / 960
Регистрация: 15.11.2014
Сообщений: 9,760
|
||||
| 01.02.2015, 18:49 | ||||
|
при малейшем подозрении на возможную программную ошибку (неконсистентное состояние данных), узел должен немедленно прервать работу всего приложения. (std::terminate, и это без вариантов. Нельзя даже в логи ничего записать. Никаких действий кроме самоликвидации). Это было связанно с тем, что в условиях нестабильности слишком велика опасность непредсказуемого поведения приложения, которое может причинить вред не сопоставимый с убытками от возможных потерь данных. Ну так вот, в этой компании запрещено использовать std::vector, потому что его operator[] может пропустить в релизе выход за пределы диапазона. Вместо него используется наследник. Для которого интерфейс подправлен и лучше отвечает требованиям корпоративного стандарта.
0
|
||||
|
|
|
| 01.02.2015, 21:59 [ТС] | |
|
Даже в STL (не берусь утвержать,что во всех реализациях) адаптеры контейнеров сделаны с помощью композиции, а не наследованием от контейнера.
Я тоже считаю, что наследование от std контейнеров no way.
1
|
|
|
8973 / 4319 / 960
Регистрация: 15.11.2014
Сообщений: 9,760
|
|
| 01.02.2015, 22:06 | |
|
0
|
|
|
2784 / 1937 / 570
Регистрация: 05.06.2014
Сообщений: 5,602
|
||
| 01.02.2015, 22:11 | ||
|
0
|
||
|
419 / 418 / 72
Регистрация: 27.05.2012
Сообщений: 1,168
|
|
| 01.02.2015, 22:33 | |
|
0
|
|
|
8973 / 4319 / 960
Регистрация: 15.11.2014
Сообщений: 9,760
|
|
| 01.02.2015, 22:47 | |
|
0
|
|
|
419 / 418 / 72
Регистрация: 27.05.2012
Сообщений: 1,168
|
||
| 02.02.2015, 18:32 | ||
|
0
|
||
|
8973 / 4319 / 960
Регистрация: 15.11.2014
Сообщений: 9,760
|
|||||||
| 02.02.2015, 19:01 | |||||||
|
Например:
подмешивается ли туда какая то логика самого адаптера, или нет. Вариант с наследованием позволяет определить только те методы, логика которых действительно нуждается в изменении. Это тупо проще и быстрее. --------------------------------------- Кроме того, предположим адаптер должен представлять собой "почти такой же" вектор, изменена лишь логика oparetor[]. Все остальное должно оставаться, как у обычного вектора. При наследовании, построенный во времена с++03, адаптер без усилий со стороны потребителя, и без необходимости править код, автоматически подхватит новые плюшки, такие как emplace_back и др. В то время, как в случае с композицией - кукишь. Там если что-то явно ручками не прописали - само уже ниоткуда не возникнет. ----------------------------------------------------- Итого: При наследовании: минимум работы: определяем только необходимое. новые плюшки подхватываются автоматически. При композиции: максимум работы: определяем даже то, что не нуждается в изменении. новые плюшки добавляются только вручную.
0
|
|||||||
|
What a waste!
1612 / 1304 / 180
Регистрация: 21.04.2012
Сообщений: 2,735
|
|
| 02.02.2015, 22:09 | |
|
hoggy, можно закрытое наследование; писать правда всё равно больше, чем при открытом (и надо будет дописывать при изменении интерфейса адаптируемого класса), но и ненужных при этом свойств открытого наследования тоже нет.
0
|
|
| 02.02.2015, 22:09 | |
|
Шифрование "Лозунговым методом" (кому интересно) В чем интересно загвоздка???интересно разобраться!
Задача для любителей поломать голову Открыта вакансия Программиста 1С - кому интересно? Искать еще темы с ответами Или воспользуйтесь поиском по форуму: |
|
Новые блоги и статьи
|
|||
|
[golang] Конкурентный fetcher с ограничением максимального количества одновременных HTTP запросов.
alhaos 10.06.2026
Задача
Реализовать конкурентный fetcher с ограничением максимального количества одновременных HTTP запросов.
Сигнатура
func Fetch(urls string, maxConcurrent int) Result
Пример
urls :=. . .
|
[golang] Состояние гонки (race condition)
alhaos 10.06.2026
Состояние гонки (race condition)
Состояние гонки (Race Condition) — это ошибка, возникающая при одновременном доступе нескольких горутин к одним и тем же данным без должной синхронизации. При этом. . .
|
Взрослые отношения, и почему они не получаются
kumehtar 09.06.2026
Когда в детстве ребёнок не получает от родителей чего-то важного, он лишается не просто приятных переживаний, а основы для формирования определённых внутренних качеств и навыков. Если ребёнок не. . .
|
[golang] Worker Pool
alhaos 09.06.2026
Worker Pool
Worker Pool — паттерн конкурентной обработки задач в Go.
Суть: фиксированное количество горутин-воркеров читают задачи из общего канала
и пишут результаты в общий канал результатов. . . .
|
|
[golang] Pipeline
alhaos 08.06.2026
Pipeline
Pipeline — паттерн конкурентной обработки данных в Go.
Суть: данные проходят через цепочку независимых стадий, каждая из которых работает в своей горутине и общается с соседями через. . .
|
Свет внутри себя
kumehtar 07.06.2026
Пусть это будет здесь
lIs4oanZS9Y
|
Программа для com-порта
Uhbif79 05.06.2026
Всем привет, давно хотел изучить Qt, начинал, бросал, потом снова начинал. И сейчас вот смог написать свою первую программу.
До этого имел опыт программирования микроконтроллеров, писал прошивки на. . .
|
Транскрипция 55-минутного видео через Whisper: WhisperDesktop облажался, спас Google Colab[
anaschu 01.06.2026
Понадобилось получить текст из свежезагруженного видео на YouTube. Казалось бы, задача на пять минут. Заняла полтора часа. Делюсь опытом — может кому пригодится последовательность решений.
. . .
|