psilogic: (Default)
[personal profile] psilogic
Специально для любителей шОблоноф и прочих C++ наворотов. :) Сразу пердупердяю: задачка с подвохом.

Дано.

В программе есть некоторое количество классов, которые являются элементами односвязных списков с internal storage (проще говоря, это когда указатель на следующий элемент является членом класса).

Классы имеют вид:
class MyClass...
{
   MyClass *nextListItem;


Причем, варьируется не только название класса, но и название поля "nextListItem".

Задача.

Написать универсальную функцию вставки в начало списка с применением template, inline и pointer-to-member операторов. На входе должны быть: вставляемый элемент; указатель на первый элемент; название поля, указывающего на следующий элемент и тип класса. Функция может быть глобальной или членом namespace или функцией какого-либо нового класса - важно, чтобы она была одна, но работала для всех тех классов. Функция должна работать примерно так же, как ниже представленный #define:

#define INSERT_TO_LIST(firstItemPtr, item, nextItemName) \
(item)->nextItemName= (firstItemPtr), (firstItemPtr)= (item)


Посчитать количество строк в полученной функции. Факультативно: перечислить и обосновать преимущества перед приведенным #define.

Date: 2009-07-20 06:40 am (UTC)
From: [identity profile] http://technorati.com/people/technorati/ketmar (from livejournal.com)
кстати сказать, если это код из «продакшына» — то кого-то надо больно убить. ибо все «списковые» классы надо наследовать от одной базы, и там иметь итераторы да все функции добавления/удаления.

Date: 2009-07-20 07:07 am (UTC)
From: [identity profile] snusmumrikkk.livejournal.com
Необязательно от одной базы. Посмотрите на std::vector и std::list. У них даже методы добавления не симметричны. Вы уже хотите убить Степанова?

Date: 2009-07-20 07:11 am (UTC)
From: [identity profile] http://technorati.com/people/technorati/ketmar (from livejournal.com)
конечно. аффтара STL надо было в детстве на дубе повесить. страуструпа, впрочем, тоже.

Date: 2009-07-20 07:11 am (UTC)
From: [identity profile] http://technorati.com/people/technorati/ketmar (from livejournal.com)
я не знаю — надо пояснять, почему, или оно таки очевидно?
(deleted comment)

Date: 2009-07-20 07:27 am (UTC)
From: [identity profile] http://technorati.com/people/technorati/ketmar (from livejournal.com)
тогда начнё издалека. ты в курсе, что такое «объектно-ориентированное программирование», и почему в цпп его нет? а также почему делать оное без нормального GC — атомный идиотизм?

Date: 2009-07-20 07:38 am (UTC)
From: [identity profile] psilogic.livejournal.com
Что такое GC? Горбухи Коллектор?

Date: 2009-07-20 07:41 am (UTC)
From: [identity profile] http://technorati.com/people/technorati/ketmar (from livejournal.com)
Грёбаный Совок.

Date: 2009-07-20 08:55 am (UTC)
From: [identity profile] snusmumrikkk.livejournal.com
ООП разное бывает, не только Java-стайл. ООП в первую очередь способ мышления (как альтернатива, например, функциональному программированию), а уже во вторую очередь языковые средства. Наличие GC не имеет никакого отношения к объектно-ориентированности.

А то, что STL не вполне соответствует концепциям ООП, не делает его чем-то инфернальным. Оно выполняет свои задачи, и оно по-своему красиво.

(no subject)

From: [identity profile] http://technorati.com/people/technorati/ketmar - Date: 2009-07-20 09:06 am (UTC) - Expand

(no subject)

From: [identity profile] psilogic.livejournal.com - Date: 2009-07-20 09:16 am (UTC) - Expand

(no subject)

From: [identity profile] http://technorati.com/people/technorati/ketmar - Date: 2009-07-20 09:23 am (UTC) - Expand

(no subject)

From: [identity profile] snusmumrikkk.livejournal.com - Date: 2009-07-20 10:00 am (UTC) - Expand

(no subject)

From: [identity profile] http://technorati.com/people/technorati/ketmar - Date: 2009-07-20 10:14 am (UTC) - Expand

(no subject)

From: [identity profile] snusmumrikkk.livejournal.com - Date: 2009-07-20 10:21 am (UTC) - Expand

(no subject)

From: [identity profile] http://technorati.com/people/technorati/ketmar - Date: 2009-07-20 10:29 am (UTC) - Expand

(no subject)

From: [identity profile] psilogic.livejournal.com - Date: 2009-07-20 10:41 am (UTC) - Expand

(no subject)

From: [identity profile] http://technorati.com/people/technorati/ketmar - Date: 2009-07-20 10:54 am (UTC) - Expand

(no subject)

From: [identity profile] psilogic.livejournal.com - Date: 2009-07-20 10:58 am (UTC) - Expand

(no subject)

From: [identity profile] http://technorati.com/people/technorati/ketmar - Date: 2009-07-20 11:10 am (UTC) - Expand

(no subject)

From: [identity profile] psilogic.livejournal.com - Date: 2009-07-20 11:18 am (UTC) - Expand

(no subject)

From: [identity profile] http://technorati.com/people/technorati/ketmar - Date: 2009-07-20 11:24 am (UTC) - Expand

(no subject)

From: [identity profile] http://technorati.com/people/technorati/ketmar - Date: 2009-07-20 10:55 am (UTC) - Expand

(no subject)

From: [identity profile] psilogic.livejournal.com - Date: 2009-07-20 10:59 am (UTC) - Expand

(no subject)

From: [identity profile] http://technorati.com/people/technorati/ketmar - Date: 2009-07-20 11:11 am (UTC) - Expand

(no subject)

From: [identity profile] psilogic.livejournal.com - Date: 2009-07-20 11:19 am (UTC) - Expand

(no subject)

From: [identity profile] http://technorati.com/people/technorati/ketmar - Date: 2009-07-20 11:23 am (UTC) - Expand

(no subject)

From: [identity profile] psilogic.livejournal.com - Date: 2009-07-20 11:34 am (UTC) - Expand

(no subject)

From: [identity profile] http://technorati.com/people/technorati/ketmar - Date: 2009-07-20 11:37 am (UTC) - Expand

(no subject)

From: [identity profile] psilogic.livejournal.com - Date: 2009-07-20 11:46 am (UTC) - Expand

(no subject)

From: [identity profile] http://technorati.com/people/technorati/ketmar - Date: 2009-07-20 11:54 am (UTC) - Expand

(no subject)

From: [identity profile] psilogic.livejournal.com - Date: 2009-07-20 11:58 am (UTC) - Expand

(no subject)

From: [identity profile] http://technorati.com/people/technorati/ketmar - Date: 2009-07-20 12:15 pm (UTC) - Expand

(no subject)

From: [identity profile] psilogic.livejournal.com - Date: 2009-07-20 12:18 pm (UTC) - Expand

(no subject)

From: [identity profile] http://technorati.com/people/technorati/ketmar - Date: 2009-07-20 12:24 pm (UTC) - Expand

(no subject)

From: [identity profile] psilogic.livejournal.com - Date: 2009-07-20 12:33 pm (UTC) - Expand

(no subject)

From: [identity profile] http://technorati.com/people/technorati/ketmar - Date: 2009-07-20 12:38 pm (UTC) - Expand

(no subject)

From: [identity profile] psilogic.livejournal.com - Date: 2009-07-20 12:39 pm (UTC) - Expand

(no subject)

From: [identity profile] http://technorati.com/people/technorati/ketmar - Date: 2009-07-20 09:30 pm (UTC) - Expand

(no subject)

From: [identity profile] psilogic.livejournal.com - Date: 2009-07-21 08:49 am (UTC) - Expand

(no subject)

From: [identity profile] http://technorati.com/people/technorati/ketmar - Date: 2009-07-21 11:57 am (UTC) - Expand

(no subject)

From: [identity profile] psilogic.livejournal.com - Date: 2009-07-21 12:01 pm (UTC) - Expand

Date: 2009-07-20 07:13 am (UTC)
From: [identity profile] http://technorati.com/people/technorati/ketmar (from livejournal.com)
вдогон: массив != списку, так что пример некорректный.

Date: 2009-07-20 07:28 am (UTC)
From: [identity profile] psilogic.livejournal.com
Ну каг же, зато они оба - контейнеры. Надо было создать класс std::container с виртуальной фабрикой, мля, а не совать повсюду левые "allocator"-ы.

Если чо - это я так... в порядке стеба... на самом деле мне похуй на STL.

Date: 2009-07-20 07:30 am (UTC)
From: [identity profile] http://technorati.com/people/technorati/ketmar (from livejournal.com)
о! таки да же! таки сделать один контейнер, и не ебать моск непонятно чем!

Date: 2009-07-20 07:23 am (UTC)
From: [identity profile] psilogic.livejournal.com
Нет, не из продакшена, это задачка. Задачка связана с реальными вещами, где наследовать от одной базы бесполезно. Прикинь, что будет, если элемент с internal storage лежит в нескольких списках. В wiki-статье говорится, что это невозможно, но это вполне возможно :)

Date: 2009-07-20 07:26 am (UTC)
From: [identity profile] http://technorati.com/people/technorati/ketmar (from livejournal.com)
это всё от безблагодатности. патамуша цпп — не иснтрумент для нормального программирования, увы.

Date: 2009-07-20 07:30 am (UTC)
From: [identity profile] psilogic.livejournal.com
Ну... ничего лучше (по совоПуКности факторов) пока не придумали...

Date: 2009-07-20 07:34 am (UTC)
From: [identity profile] http://technorati.com/people/technorati/ketmar (from livejournal.com)
да? O_O
Component Pascal, например. Smalltalk. Objective C, кстати сказать, очень достойная вещь.

Date: 2009-07-20 07:37 am (UTC)
From: [identity profile] psilogic.livejournal.com
Зачем ты с такой любовью перечисляешь сорта говна? :)

(no subject)

From: [identity profile] http://technorati.com/people/technorati/ketmar - Date: 2009-07-20 07:40 am (UTC) - Expand

Date: 2009-07-20 08:58 am (UTC)
From: [identity profile] snusmumrikkk.livejournal.com
Это в Objective C по-твоему ООП? Хаха :)

(no subject)

From: [identity profile] http://technorati.com/people/technorati/ketmar - Date: 2009-07-20 09:07 am (UTC) - Expand

Date: 2009-07-20 07:34 am (UTC)
From: [identity profile] http://technorati.com/people/technorati/ketmar (from livejournal.com)
ну, и LISP, конечно же. %-)

Date: 2009-07-20 07:46 am (UTC)
From: [identity profile] afa-at-work.livejournal.com
фигась...
цэпэпэ - инструмент для низкоуровнего програмленья, ага.
да, предупреждая стёб - слово "програмленье" - сложносоставное. от программирование и камланье.

Date: 2009-07-20 07:58 am (UTC)
From: [identity profile] http://technorati.com/people/technorati/ketmar (from livejournal.com)
нет, даже для этого он не пригоден, увы.

Date: 2009-07-20 08:21 am (UTC)
From: [identity profile] afa-at-work.livejournal.com
ну почему.
выкинуть нахер новомодностя всякия, стл и иже. использовать молоток по назначению, вопчем. как строго типизированный асм для таймкритикал кусков. склеивать в целое нормальным языком. рубить руки желающим вылезти за пределы примитивов.

(no subject)

From: [identity profile] http://technorati.com/people/technorati/ketmar - Date: 2009-07-20 08:31 am (UTC) - Expand

(no subject)

From: [identity profile] afa-at-work.livejournal.com - Date: 2009-07-20 08:51 am (UTC) - Expand

(no subject)

From: [identity profile] http://technorati.com/people/technorati/ketmar - Date: 2009-07-20 08:54 am (UTC) - Expand

(no subject)

From: [identity profile] afa-at-work.livejournal.com - Date: 2009-07-20 08:59 am (UTC) - Expand

(no subject)

From: [identity profile] http://technorati.com/people/technorati/ketmar - Date: 2009-07-20 09:08 am (UTC) - Expand

(no subject)

From: [identity profile] afa-at-work.livejournal.com - Date: 2009-07-20 09:13 am (UTC) - Expand

(no subject)

From: [identity profile] http://technorati.com/people/technorati/ketmar - Date: 2009-07-20 09:28 am (UTC) - Expand

(no subject)

From: [identity profile] psilogic.livejournal.com - Date: 2009-07-20 09:33 am (UTC) - Expand

(no subject)

From: [identity profile] http://technorati.com/people/technorati/ketmar - Date: 2009-07-20 09:34 am (UTC) - Expand

(no subject)

From: [identity profile] psilogic.livejournal.com - Date: 2009-07-20 09:42 am (UTC) - Expand

(no subject)

From: [identity profile] http://technorati.com/people/technorati/ketmar - Date: 2009-07-20 09:46 am (UTC) - Expand

(no subject)

From: [identity profile] psilogic.livejournal.com - Date: 2009-07-20 09:47 am (UTC) - Expand

(no subject)

From: [identity profile] http://technorati.com/people/technorati/ketmar - Date: 2009-07-20 09:49 am (UTC) - Expand

(no subject)

From: [identity profile] psilogic.livejournal.com - Date: 2009-07-20 09:54 am (UTC) - Expand

(no subject)

From: [identity profile] afa-at-work.livejournal.com - Date: 2009-07-20 10:44 am (UTC) - Expand

(no subject)

From: [identity profile] http://technorati.com/people/technorati/ketmar - Date: 2009-07-20 10:50 am (UTC) - Expand

(no subject)

From: [identity profile] psilogic.livejournal.com - Date: 2009-07-20 10:54 am (UTC) - Expand

(no subject)

From: [identity profile] http://technorati.com/people/technorati/ketmar - Date: 2009-07-20 10:59 am (UTC) - Expand

(no subject)

From: [identity profile] psilogic.livejournal.com - Date: 2009-07-20 11:01 am (UTC) - Expand

(no subject)

From: [identity profile] http://technorati.com/people/technorati/ketmar - Date: 2009-07-20 11:10 am (UTC) - Expand

(no subject)

From: [identity profile] psilogic.livejournal.com - Date: 2009-07-20 11:21 am (UTC) - Expand

(no subject)

From: [identity profile] http://technorati.com/people/technorati/ketmar - Date: 2009-07-20 11:30 am (UTC) - Expand

(no subject)

From: [identity profile] psilogic.livejournal.com - Date: 2009-07-20 11:36 am (UTC) - Expand

(no subject)

From: [identity profile] http://technorati.com/people/technorati/ketmar - Date: 2009-07-20 11:52 am (UTC) - Expand

(no subject)

From: [identity profile] psilogic.livejournal.com - Date: 2009-07-20 11:54 am (UTC) - Expand

(no subject)

From: [identity profile] http://technorati.com/people/technorati/ketmar - Date: 2009-07-20 11:56 am (UTC) - Expand

(no subject)

From: [identity profile] psilogic.livejournal.com - Date: 2009-07-20 11:59 am (UTC) - Expand

(no subject)

From: [identity profile] http://technorati.com/people/technorati/ketmar - Date: 2009-07-20 12:13 pm (UTC) - Expand

(no subject)

From: [identity profile] psilogic.livejournal.com - Date: 2009-07-20 12:16 pm (UTC) - Expand

(no subject)

From: [identity profile] http://technorati.com/people/technorati/ketmar - Date: 2009-07-20 11:58 am (UTC) - Expand

(no subject)

From: [identity profile] psilogic.livejournal.com - Date: 2009-07-20 12:01 pm (UTC) - Expand

(no subject)

From: [identity profile] http://technorati.com/people/technorati/ketmar - Date: 2009-07-20 12:12 pm (UTC) - Expand

(no subject)

From: [identity profile] psilogic.livejournal.com - Date: 2009-07-20 12:22 pm (UTC) - Expand

(no subject)

From: [identity profile] http://technorati.com/people/technorati/ketmar - Date: 2009-07-20 12:31 pm (UTC) - Expand

(no subject)

From: [identity profile] http://technorati.com/people/technorati/ketmar - Date: 2009-07-20 12:33 pm (UTC) - Expand

(no subject)

From: [identity profile] psilogic.livejournal.com - Date: 2009-07-20 12:37 pm (UTC) - Expand

(no subject)

From: [identity profile] eugenius-nsk.livejournal.com - Date: 2009-07-21 03:03 am (UTC) - Expand

(no subject)

From: [identity profile] afa-at-work.livejournal.com - Date: 2009-07-20 09:00 am (UTC) - Expand

(no subject)

From: [identity profile] http://technorati.com/people/technorati/ketmar - Date: 2009-07-20 09:08 am (UTC) - Expand

(no subject)

From: [identity profile] afa-at-work.livejournal.com - Date: 2009-07-20 09:15 am (UTC) - Expand

(no subject)

From: [identity profile] http://technorati.com/people/technorati/ketmar - Date: 2009-07-20 09:25 am (UTC) - Expand

(no subject)

From: [identity profile] afa-at-work.livejournal.com - Date: 2009-07-20 10:47 am (UTC) - Expand

(no subject)

From: [identity profile] http://technorati.com/people/technorati/ketmar - Date: 2009-07-20 11:04 am (UTC) - Expand

(no subject)

From: [identity profile] afa-at-work.livejournal.com - Date: 2009-07-20 12:00 pm (UTC) - Expand

(no subject)

From: [identity profile] http://technorati.com/people/technorati/ketmar - Date: 2009-07-20 12:13 pm (UTC) - Expand

(no subject)

From: [identity profile] afa-at-work.livejournal.com - Date: 2009-07-20 01:51 pm (UTC) - Expand

(no subject)

From: [identity profile] http://technorati.com/people/technorati/ketmar - Date: 2009-07-20 09:29 pm (UTC) - Expand

(no subject)

From: [identity profile] afa-at-work.livejournal.com - Date: 2009-07-21 07:11 am (UTC) - Expand

(no subject)

From: [identity profile] http://technorati.com/people/technorati/ketmar - Date: 2009-07-20 09:26 am (UTC) - Expand

(no subject)

From: [identity profile] psilogic.livejournal.com - Date: 2009-07-20 09:05 am (UTC) - Expand

(no subject)

From: [identity profile] http://technorati.com/people/technorati/ketmar - Date: 2009-07-20 09:09 am (UTC) - Expand

(no subject)

From: [identity profile] psilogic.livejournal.com - Date: 2009-07-20 09:17 am (UTC) - Expand

(no subject)

From: [identity profile] http://technorati.com/people/technorati/ketmar - Date: 2009-07-20 09:21 am (UTC) - Expand

(no subject)

From: [identity profile] psilogic.livejournal.com - Date: 2009-07-20 09:23 am (UTC) - Expand

(no subject)

From: [identity profile] http://technorati.com/people/technorati/ketmar - Date: 2009-07-20 09:30 am (UTC) - Expand

Date: 2009-07-20 07:29 am (UTC)
From: [identity profile] http://technorati.com/people/technorati/ketmar (from livejournal.com)
кстати, это возможно, но нахер не надо. архитектора бить молотком по гойлове, пока не поумнеет. или пока не выучит хотя бы слово «контейнер».

Date: 2009-07-20 07:32 am (UTC)
From: [identity profile] psilogic.livejournal.com
Что-то у тебя молоток зудит... чуть выше ты предлагал бить по голове уже создателя тру-контейнеров...

Date: 2009-07-20 07:40 am (UTC)
From: [identity profile] http://technorati.com/people/technorati/ketmar (from livejournal.com)
а любого «улучшателя» цпп в принципе надо бить молотком.
Page generated Sep. 14th, 2025 02:41 pm
Powered by Dreamwidth Studios