Форум программистов, компьютерный форум, киберфорум
C++
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
 
Рейтинг 4.67/48: Рейтинг темы: голосов - 48, средняя оценка - 4.67
21 / 19 / 7
Регистрация: 14.03.2014
Сообщений: 249

Тестовое задание от компании Exness

07.08.2017, 22:55. Показов 9438. Ответов 69
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
У меня нет никакого вопроса, но я так и не понял в какую ветку надо написать (все изучил внимательно), поэтому пишу сюда.
Я просто хочу поделиться своим опытом трудоустройства на тот случай если это кому нибудь поможет и узнать мнение общественности.
Я получил тестовое задание от компании Exness и решил сделать его рефакторинг, а потом выполнил его и получил рецензию.
Всё во вложении.
Аннотация:
TA.2017.refactoring-optimization (2) (1).pdf - тестовое задание
MultiQueueProcessor.zip - код для рефакторинга
Описание_задачи.docx - моя версия рефакторинга самого задания
exness_testwork.zip - мой результат выполнения

Рецензия от lyubov.belogrudova@exness.com>: вот:
Юрий, добрый день! В пятницу не успела Вам написать.
Вас благодарим за внимание к нашей компании, за уделенное на тестовое задание время. Но, к сожалению, по результатам тестового задания делать оффер мы не готовы.
Пишу feedback от коллег:

Есть несколько основных проблемы присланного кода:
1. Читаемость и понимаемость кода стремится к нулю
2. Нет краткости, элегантности, какой-то красоты в присланном решении
3. Технически код выглядит очень старомодным:
a. Встречаются new/delete, unique_ptr/shared_ptr не найден
b. Обилие малооправданных "велосипедов"
c. С++11 очень мало по проекту

Вам успехов. Еси решение изменится, дам Вам знать.
Вложения
Тип файла: pdf TA.2017.refactoring-optimization (2) (1).pdf (45.8 Кб, 95 просмотров)
Тип файла: docx Описание_задачи.docx (16.1 Кб, 77 просмотров)
Тип файла: zip exness_testwork.zip (23.4 Кб, 67 просмотров)
Тип файла: zip MultiQueueProcessor.zip (870 байт, 56 просмотров)
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
07.08.2017, 22:55
Ответы с готовыми решениями:

Тестовое задание от работадателя. Хотелось бы услышать критику.
Пробую устроиться программистом. Вот одна из компаний выслала мне тестовое задание следующего содержания: Немного поломав голову,...

Небольшое тестовое задание в финской компании.
Привествую всех жителей форума. Сразу отмечу, что решения просить не хочу, а просто хочу показать задание, которая давала компания...

Тестовое задание
private class Connect (){ public Device dev1 = new Device(); public Device dev2 = new Device(); puclic void Connect (){ for...

69
Почетный модератор
Эксперт С++
 Аватар для SatanaXIII
5851 / 2862 / 392
Регистрация: 01.11.2011
Сообщений: 6,906
08.08.2017, 09:06
Pechkin80, вы хотите, чтобы форумчане поглядели ваш код и оценили б на сколько критика оправдана?
0
21 / 19 / 7
Регистрация: 14.03.2014
Сообщений: 249
08.08.2017, 10:47  [ТС]
Всё возможно. Критика может быть не оправдана или наоборот критика может быть неполной и результат выполнения требует большей критики, а кому то может это поможет просто трудоустроиться в данную компанию.

Добавлено через 8 минут
Приведу текст тут, для тех кому скачивать.
Описание задачи
Перед программистом стояла задача сделать универсальный обработчик нескольких
очередей с требованиями:
● Код должен быть максимально универсальным и простым в использовании:
○ добавление в очередь (несколько продюсеров в разных потоках),
○ получение из очереди,
○ подписка/отписка на разбор очереди в отдельном потоке (потоках) одним
фиксированным консьюмером
● Код должен быть потокобезопасным
● Решение должно эффективно распоряжаться ресурсами (ядра CPU, память) и
работать максимально быстро (с минимальными задержками между добавлением
в очередь и получением данных в консьюмере)
Представленное решение (см. код) по ряду причин не получилось удачным, требуется
внести исправления в приведенный код:
● Добиться корректности и стабильности работы класса, устранить потенциальные
“уязвимости”
● Провести рефакторинг существующего кода так, чтобы класс было легко развивать
и поддерживать
● Провести оптимизацию, добиться максимальной производительности
Решение данной задачи может быть простым или сколь угодно сложным, можно
вводить/использовать любые типы, переделывать внутреннюю реализацию так, как это
потребуется, исходя из требований задачи и общих best-practice
Обязательные требования по коду:
● Из библиотек разрешается использовать только STL и boost
● Код должен быть написан только на С++, с использованием C++03 или более
новых стандартов (С++11/14 приветствуется)
0
Неэпический
 Аватар для Croessmah
18144 / 10728 / 2066
Регистрация: 27.09.2012
Сообщений: 27,026
Записей в блоге: 1
08.08.2017, 12:36
Pechkin80, посмотрел мельком результат.
Много повторяющегося кода, который, при
минимальных изменениях можно раскидать по функциям.

Еще, например,
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
    try
    {
        TLordNS lock{ m_mtx_nodeset };
        if (consumer != nullptr)
        {
            plnode = new(std::nothrow) TLN;
            if (plnode != nullptr)
            {
                plnode->consumer = consumer;
                plnode->m_list = new(std::nothrow) TContainer(MAXCAPACITY);//Если здесь память не выделилась, то plnode утёк
                if (plnode->m_list != nullptr)
                {
                    key = (TKey)(plnode);
                    initNode(key);
                    consumer->setKey(key);
                    m_nodes.insert(key);
                    #ifdef  MPP_NO_IDLEMODE
                    // An order of locks doesn`t matter since
                    // key->isLinked = false
                    TLordEX lock_ex(m_mtx_exclusive);
                    if (lock_ex.lock())
                    {
                        // if another producer linked
                        // due waiting of mutex
                        if (!plnode->isLinked)
                        {
                            includeNode(key);
                        }
                    }
                    else // Exclusive lock is frozen
                    {
                        throw "";
                    }
                    #endif
                }
                else
                {
                    errspace::show_errmsg(funcname);
                    send_exit_event(*m_args,TThreadArgs::th_exit_error);
                }
            }
            else
            {
                errspace::show_errmsg(funcname);
                send_exit_event(*m_args,TThreadArgs::th_exit_error);
            }
        }
        else
        {
            errspace::show_errmsg(funcname);
            send_exit_event(*m_args,TThreadArgs::th_exit_error);
        }
можно поменять на
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
    try
    {
        TLordNS lock{ m_mtx_nodeset };        
        if (consumer != nullptr)
        {
            std::unique_ptr<TNL> plnode = std::make_unique<TNL>();
            plnode->consumer = consumer;
            plnode->m_list = new TContainer(MAXCAPACITY);//Можно и это прикрутить к умному указателю. Не знаю как там дальше всё устроено, так что оставлю так
            key = (TKey)plnode.release();//если дальше исключения невозможны.
            initNode(key);
            consumer->setKey(key);//А здесь как дела с исключениями?
            m_nodes.insert(key);//И здесь? А то может release рано еще вызывать было и list тоже может стоило обезопасить?
            #ifdef  MPP_NO_IDLEMODE
            // An order of locks doesn`t matter since
            // key->isLinked = false
            TLordEX lock_ex(m_mtx_exclusive);
            if (lock_ex.lock())
            {
                // if another producer linked
                // due waiting of mutex
                if (!plnode->isLinked)
                {
                    includeNode(key);
                }
            }
            else // Exclusive lock is frozen
            {
                throw "";//Ужас, но оставил
            }
            #endif
        }
    } catch (...)
    {
        errspace::show_errmsg(funcname);
        send_exit_event(*m_args,TThreadArgs::th_exit_error);
    }
и это без подробного разбора кода.
0
21 / 19 / 7
Регистрация: 14.03.2014
Сообщений: 249
08.08.2017, 13:46  [ТС]
Croessmah, В чём смысл ваших манипуляций с кодом ?
0
Неэпический
 Аватар для Croessmah
18144 / 10728 / 2066
Регистрация: 27.09.2012
Сообщений: 27,026
Записей в блоге: 1
08.08.2017, 13:48
Pechkin80, убраны проверки на nullptr,
а значит уменьшена вложенность кода и его длина,
при этом были удалены лишние
C++
1
2
3
4
5
6
7
8
9
10
11
                else
                {
                    errspace::show_errmsg(funcname);
                    send_exit_event(*m_args,TThreadArgs::th_exit_error);
                }
            }
            else
            {
                errspace::show_errmsg(funcname);
                send_exit_event(*m_args,TThreadArgs::th_exit_error);
            }
устранена потенциальная утечка памяти.
Хотя еще не устранена, нужно смотреть
как там что устроено, и что есть что.
0
21 / 19 / 7
Регистрация: 14.03.2014
Сообщений: 249
08.08.2017, 14:12  [ТС]
Croessmah, Не совсем понял про связь умных указателей и вложенности кода. Т.е. умные указатели настолько умные что сами выведут нужное разработчику сообщение об ошибки без вызова исключений? Где потенциальная утечка памяти ?

Добавлено через 16 минут
Большая вложенность кода тут в качестве загатовки для разветвлённой системы сообщений об ощибках. Можно как альтернативу сделать разветвлённую иерархию классов исключений, но как это связано с способом создания объекта для меня загадка.
0
Неэпический
 Аватар для Croessmah
18144 / 10728 / 2066
Регистрация: 27.09.2012
Сообщений: 27,026
Записей в блоге: 1
08.08.2017, 14:18
Цитата Сообщение от Pechkin80 Посмотреть сообщение
Т.е. умные указатели настолько умные что сами выведут нужное разработчику сообщение об ошибки без вызова исключений?
new выкенит исключение и мы перейдем в catch,
а умные указатели помогут не потерять ресурсы.
Цитата Сообщение от Pechkin80 Посмотреть сообщение
Где потенциальная утечка памяти ?
Я написал уже в комментарии. Например, здесь:
C++
1
plnode->m_list = new(std::nothrow) TContainer(MAXCAPACITY);//Если здесь память не выделилась, то plnode утёк
И дальше по коду в любом месте, где ресурсом еще никто не владеет.
Хотя если send_exit_event убьет процесс (не поток, а весь процесс),
то может и не надо заботится об освобождении ресурса,
хотя всё равно всё зависит от устройства.
Но в таком случае зачем nothrow и все эти проверки в коде,
если в catch всё убьется в случае вылета исключения?
Я сначала подумал, что нельзя использовать new, который выбрасывает исключение,
но, выше всё-таки используется new, выбрасывающий исключение.
send_exit_event убивает весь процесс или только поток?
Если поток, то в коде явные проблемы с потенциальными утечками.
Если, использовать умные указатели (с умом) вместо голых, то код
упростится и станет безопаснее по отношению к исключениям.
0
21 / 19 / 7
Регистрация: 14.03.2014
Сообщений: 249
08.08.2017, 14:21  [ТС]
Croessmah, Не забудьбте как модератор подтереть собственный перл, пока я не полез в стандарт.
-2
Неэпический
 Аватар для Croessmah
18144 / 10728 / 2066
Регистрация: 27.09.2012
Сообщений: 27,026
Записей в блоге: 1
08.08.2017, 14:45
Цитата Сообщение от Pechkin80 Посмотреть сообщение
пока я не полез в стандарт.
Вперед.

Добавлено через 20 минут
Повторяющиеся фрагменты:
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
    if (doShowtoDisplay)
    {
        fputs(prompt,stderr);
        fputs(symbol,stderr);
        fputs(rt,stderr);
    }
    if ((doWriteToFile) && (logFile != nullptr))
    {
        fputs(prompt,logFile);
        fputs(symbol,logFile);
        fputs(rt,logFile);
        fflush(logFile);
    }
Можно поменять, например, как-то так:
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
static void print_to_stream(FILE *stream, std::initializer_list<const char*> messages)
{
    for (const char *message: messages)
        fputs(message, stream);
}
 
 
static void show_message_impl(std::initializer_list<const char*> messages)
{
    if (doShowtoDisplay)
    {
        print_to_stream(stderr, messages);
    }
    if ((doWriteToFile) && (logFile != nullptr))
    {
        print_to_stream(logFile, messages);
        fflush(logFile);
    }
}
//...
void show_errmsg(const char * msg)
{
    //...
    show_message_impl({prompt, msg, rt});
}
void show_errAddons(const unsigned char code)
{
    //...
    show_message_impl({prompt, symbol, rt})
}
0
21 / 19 / 7
Регистрация: 14.03.2014
Сообщений: 249
08.08.2017, 16:35  [ТС]
Croessmah, Можно завтра так как сегодня у меня д.р. ?
0
Неэпический
 Аватар для Croessmah
18144 / 10728 / 2066
Регистрация: 27.09.2012
Сообщений: 27,026
Записей в блоге: 1
08.08.2017, 16:43
Цитата Сообщение от Pechkin80 Посмотреть сообщение
Можно завтра так как сегодня у меня д.р. ?
Завтра что? Я Вам не начальник. Это форум.
Вы будете у каждого отвечающего отпрашиваться?

По существу Вам уже написали в рецензии:
1. Читаемость и понимаемость кода стремится к нулю <- согласен
2. Нет краткости, элегантности, какой-то красоты в присланном решении <- согласен
3. Технически код выглядит очень старомодным: <- согласен
a. Встречаются new/delete, unique_ptr/shared_ptr не найден <- согласен
b. Обилие малооправданных "велосипедов" <- это он про что конкретно?
c. С++11 очень мало по проекту <- согласен

С Днем Рождения.
0
21 / 19 / 7
Регистрация: 14.03.2014
Сообщений: 249
08.08.2017, 16:54  [ТС]
Croessmah,
ISO 14882-2003
18.4.1.1 Single-object forms
void* operator new(std::size_t size) throw(std::bad_alloc);
1 Effects: The allocation function (3.7.3.1) called by a new-expression (5.3.4) to allocate size bytes of
storage suitably aligned to represent any object of that size.
2 Replaceable: a C + + program may define a function with this function signature that displaces the default
version defined by the C + + Standard library.
3 Required behavior: Return a non-null pointer to suitably aligned storage (3.7.3), or else throw a
bad_alloc exception. This requirement is binding on a replacement version of this function.
4 Default behavior:
— Executes a loop: Within the loop, the function first attempts to allocate the requested storage. Whether
the attempt involves a call to the Standard C library function malloc is unspecified.
— Returns a pointer to the allocated storage if the attempt is successful. Otherwise, if the last argument to
set_new_handler() was a null pointer, throw bad_alloc.
— Otherwise, the function calls the current new_handler (18.4.2.2). If the called function returns, the loop
repeats.
— The loop terminates when an attempt to allocate the requested storage is successful or when a called
new_handler function does not return.
void* operator new(std::size_t size, const std::nothrow_t&) throw();
5 Effects: Same as above, except that it is called by a placement version of a new-expression when a C + +
program prefers a null pointer result as an error indication, instead of a bad_alloc exception.
Добавлено через 7 минут
Croessmah, По поводу остального напишу завтра. У меня нету цели вас "уесть" но эта тема возможно комуто поможет найти работу и я не хотел бы чтобы вы вводили людей в заблуждение.
0
Неэпический
 Аватар для Croessmah
18144 / 10728 / 2066
Регистрация: 27.09.2012
Сообщений: 27,026
Записей в блоге: 1
08.08.2017, 16:56
Pechkin80, и?
Я убрал std::nothrow в new-expression.
В моем коде new выбросит исключение и мы перейдем в catch.
Умный указатель (plnode) при этом освободит выделенную ранее память.
C++
1
2
3
4
5
if (consumer != nullptr)
{
   std::unique_ptr<TNL> plnode = std::make_unique<TNL>();
   plnode->consumer = consumer;
   plnode->m_list = new TContainer(MAXCAPACITY);//Если здесь вылетит исключение, то для plnode будет вызван деструктор
В Вашем коде:
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
plnode = new(std::nothrow) TLN;
if (plnode != nullptr)
{
   plnode->consumer = consumer;
   plnode->m_list = new(std::nothrow) TContainer(MAXCAPACITY);//Если здесь память не выделилась, то 
   if (plnode->m_list != nullptr)//сюда не зайдем
   {
      //...
   }
   else//а зайдем сюда
   {      
      //здесь должен быть delete plnode; иначе
      //если send_exit_event убивает поток, а не весь процесс (так что он делает в результате?),
      //то память выделенная в начале plnode = new(std::nothrow) TLN;
      //утечет навсегда
      errspace::show_errmsg(funcname);
      send_exit_event(*m_args,TThreadArgs::th_exit_error);
   }
}
Надеюсь, так ошибка стала понятнее.
0
21 / 19 / 7
Регистрация: 14.03.2014
Сообщений: 249
09.08.2017, 11:30  [ТС]
Croessmah,
1) Если память не выделена, то она не может утечь. Память это не кран, который вдруг сломался и образовалась лужа Но перл прикольный., мне понравился.
2)Спасибо, что наконец привели явное пояснение, что вы рассматриваете гипотетическую ошибку где оператор new используется в классической форме. Я тут не говорил что нуждаюсь в пояснениях по использованию умных указателей, но всё равно спасибо. Кому нибудь это обязательно поможет.
3)send_exit_event как и следует из названия посылает событие в главный поток о том что поток очереди завершился и код завершения.
4)Про повторяющиеся фрагменты не совсем понял. Это хорошо или плохо, по вашему мнению что я сделал не в вашем варианте ?
5)Если чтото пропустил, то прошу продублировать.
-0.50
Неэпический
 Аватар для Croessmah
18144 / 10728 / 2066
Регистрация: 27.09.2012
Сообщений: 27,026
Записей в блоге: 1
09.08.2017, 11:42
Цитата Сообщение от Pechkin80 Посмотреть сообщение
Если память не выделена, то она не может утечь.
C++
1
2
3
4
5
plnode = new(std::nothrow) TLN;//ПАМЯТЬ ВЫДЕЛИЛАСЬ
if (plnode != nullptr)
{
   plnode->consumer = consumer;
   plnode->m_list = new(std::nothrow) TContainer(MAXCAPACITY);//А ЗДЕСЬ ЗАФЕЙЛИЛОСЬ ВЫДЕЛЕНИЕ.
где у меня написано о том, что течет не выделенная память:
C++
1
plnode->m_list = new(std::nothrow) TContainer(MAXCAPACITY);//Если здесь память не выделилась, то plnode утёк
???
Вы там что-то себе напридумывали, или не так прочитали, но сами в это поверили.
Цитата Сообщение от Pechkin80 Посмотреть сообщение
Я тут не говорил что нуждаюсь в пояснениях по использованию умных указателей
Видимо поэтому в рецензии написано
Цитата Сообщение от Pechkin80 Посмотреть сообщение
3. Технически код выглядит очень старомодным:
a. Встречаются new/delete, unique_ptr/shared_ptr не найден
b. Обилие малооправданных "велосипедов"
Цитата Сообщение от Pechkin80 Посмотреть сообщение
Про повторяющиеся фрагменты не совсем понял. Это хорошо или плохо
Повторяющиеся фрагменты стоит вынести в отдельную функцию.
Дублирование кода - потенциальный источник ошибок, глупых и не очень.
Цитата Сообщение от Pechkin80 Посмотреть сообщение
Если чтото пропустил, то прошу продублировать.
Чтобы Вы опять что-то напридумывали? Спасибо, не надо.
0
21 / 19 / 7
Регистрация: 14.03.2014
Сообщений: 249
09.08.2017, 12:04  [ТС]
Croessmah, Как понять "//А ЗДЕСЬ ЗАФЕЙЛИЛОСЬ ВЫДЕЛЕНИЕ." ? Пришол крокодил и за мягкое место укусил ? Т.е. полный undefined behaviour ?

Про "Повторяющиеся фрагменты стоит вынести в отдельную функцию.
Дублирование кода - потенциальный источник ошибок, глупых и не очень."
Хорошо, приму к сведению вашу точку зрения))))))))))

Добавлено через 14 минут
Приведу злаполучный фрагмент в более полном изложении:
C++ (Qt)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
template <typename TValue,typename TContainer,const TSize c_MaxConsumers>
void TMultiPipeProcessor<TValue, TContainer, c_MaxConsumers>::
Subscribe(IConsumer<TValue>* consumer)
{
    const char * funcname = __PRETTY_FUNCTION__;
    TKey key = nullptr;
    TLN * plnode = nullptr;
    try
    {
        TLordNS lock{ m_mtx_nodeset };
        if (consumer != nullptr)
        {
            plnode = new(std::nothrow) TLN;
            if (plnode != nullptr)
            {
                plnode->consumer = consumer;
                plnode->m_list = new(std::nothrow) TContainer(MAXCAPACITY);
                if (plnode->m_list != nullptr)
                {
                    key = (TKey)(plnode);
-0.50
Любитель чаепитий
 Аватар для GbaLog-
3745 / 1801 / 566
Регистрация: 24.08.2014
Сообщений: 6,020
Записей в блоге: 1
09.08.2017, 12:05
Цитата Сообщение от Pechkin80 Посмотреть сообщение
Если память не выделена, то она не может утечь. Память это не кран, который вдруг сломался и образовалась лужа
память это, действительно, не кран, а вода.
а вот operator new - это кран.
в приведенном в #14 коде в строке 1 вы открываете кран, набираете себе воды.
после этого, если что-то пошло не так, то вы завершаете поток(процесс?) и воду, набранную в строке 1, не возвращаете в резервуар.
она утекает в итоге.
кстати, ваш
Цитата Сообщение от Pechkin80 Посмотреть сообщение
перл прикольный., мне понравился.
0
21 / 19 / 7
Регистрация: 14.03.2014
Сообщений: 249
09.08.2017, 12:13  [ТС]
GbaLog-, Поведение оператора new вполне однозначно определено стандартом для всех ситуаций. Чтото идёт не так у тех кому его лень учить.
0
Неэпический
 Аватар для Croessmah
18144 / 10728 / 2066
Регистрация: 27.09.2012
Сообщений: 27,026
Записей в блоге: 1
09.08.2017, 12:24
Цитата Сообщение от Pechkin80 Посмотреть сообщение
Чтото идёт не так у тех кому его лень учить.
Вот-вот, стоило бы подучить.
Цитата Сообщение от Pechkin80 Посмотреть сообщение
Пришол крокодил и за мягкое место укусил ? Т.е. полный undefined behaviour ?
Мде... фантазия через край.
Цитата Сообщение от Pechkin80 Посмотреть сообщение
Как понять "//А ЗДЕСЬ ЗАФЕЙЛИЛОСЬ ВЫДЕЛЕНИЕ." ?
Значит не удалось выделить.
Цитата Сообщение от Pechkin80 Посмотреть сообщение
Приведу злаполучный фрагмент в более полном изложении:
А смысл? Выше он уже есть,
только с акцентом на нужные участки.
Но так и быть. Повторение - мать мучения.
Попытка последняя. Гора идет к Магомету.
Если его нет дома, то черт с ним.
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
    TLN * plnode = nullptr;//Следим за этим указателем.
    try
    {
        TLordNS lock{ m_mtx_nodeset };
        if (consumer != nullptr)
        {
            plnode = new(std::nothrow) TLN;//выделяем минимум sizeof(TLN) байт,
            if (plnode != nullptr)//если память выделилась, 
            {//то идем сюды
                plnode->consumer = consumer;//бла-бла-бла
                plnode->m_list = new(std::nothrow) TContainer(MAXCAPACITY);//выделяем минимум sizeof(TContainer) байт
                if (plnode->m_list != nullptr)//если выделилась, 
                {//то идем сюды
                   //...
                } 
                else//а если не выделилась, то зайдем сюда
                {      
                    //после сие ветки мы выйдем из функции и вжух - sizeof(TLN) байт утекли.
                    //здесь должен быть delete plnode; иначе
                    //память выделенная в начале plnode = new(std::nothrow) TLN;
                    //утечет сквозь пальцы, потому что не научились работать с памятью.
                    errspace::show_errmsg(funcname);
                    send_exit_event(*m_args,TThreadArgs::th_exit_error);
               }
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
09.08.2017, 12:24
Помогаю со студенческими работами здесь

Тестовое задание на Junior C++ dev
Доброго времени суток. Неделю назад ради интереса отправил свое резюме в одну компанию, куда требуются с++ юниоры. Получил от них...

ООП. Тестовое задание собеседования.
Это тестовое задание для устройста на работу. Я не совсем понимаю что от меня хотят. Не могли бы вы мне далее составить набросок плана...

Тестовое задание для трудоустройства
Решил попробовать устроиться в компанию и узнать что вообще и как. Отправил в компанию резюме, дали тестовое задание: Страуструп. Глава...

Написать ответы на тестовое задание при приёме на работу (исключения, sizeof, mutex)
Добрый день! Ходил недавно на собеседование. Имеется список вопросов, на некоторые ответил правильно на какие-то - нет. Хотелось бы...

Тестовое задание
Добрый день! Относительно недавно начал изучать SQL, подкинули тестовое задание (во вложении). Ума не приложу как его сделать....


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
20
Ответ Создать тему
Новые блоги и статьи
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов На странице: https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/ нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
Ломающие изменения в C#.NStar Alpha
Etyuhibosecyu 20.11.2025
Уже можно не только тестировать, но и пользоваться C#. NStar - писать оконные приложения, содержащие надписи, кнопки, текстовые поля и даже изображения, например, моя игра "Три в ряд" написана на этом. . .
Мысли в слух
kumehtar 18.11.2025
Кстати, совсем недавно имел разговор на тему медитаций с людьми. И обнаружил, что они вообще не понимают что такое медитация и зачем она нужна. Самые базовые вещи. Для них это - когда просто люди. . .
Создание Single Page Application на фреймах
krapotkin 16.11.2025
Статья исключительно для начинающих. Подходы оригинальностью не блещут. В век Веб все очень привыкли к дизайну Single-Page-Application . Быстренько разберем подход "на фреймах". Мы делаем одну. . .
Фото: Daniel Greenwood
kumehtar 13.11.2025
Расскажи мне о Мире, бродяга
kumehtar 12.11.2025
— Расскажи мне о Мире, бродяга, Ты же видел моря и метели. Как сменялись короны и стяги, Как эпохи стрелою летели. - Этот мир — это крылья и горы, Снег и пламя, любовь и тревоги, И бескрайние. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru