Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 5.00/11: Рейтинг темы: голосов - 11, средняя оценка - 5.00
2784 / 1937 / 570
Регистрация: 05.06.2014
Сообщений: 5,602

Просмотр цепочки вызовов

13.12.2016, 23:17. Показов 2096. Ответов 4
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Функция func1 вызывает функцию func2. Функция func2 вызывает функцию func3. А в функции func3 происходит сбой и функция показывает сообщение об ошибке. Каким наименее геморойным способом можно из func3 получить цепочку вызовов func1->func2->func3 и отобразить ее в сообщении об ошибке? Пусть даже с привязкой к расширениям конкретного компилятора. В голову приходит вариант кинуть из func3 исключение, а потом во всех вышестоящих функциях ловить это исключение, писать "ошибка туточки" и кидать исключение дальше. Но это каждую функцию надо будет в try-catch секцию обшивать.
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
void func3()
{
    std::cout<<"error in func3"<<std::endl;
    throw std::runtime_error("");
}
void func2()
try
{
    func3();
}
catch(...)
{
    std::cout<<"error in func2"<<std::endl;
    throw;
}
 
void func1()
try
{
    func2();
    throw;
}
catch(...)
{
    std::cout<<"error in func1"<<std::endl;
}
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
13.12.2016, 23:17
Ответы с готовыми решениями:

STL: найти все максимальные цепочки подряд идущих положительных чисел с указанием длины каждой цепочки
Создать массив длины N (число N вводится с клавиатуры). Заполнить массив рандомно. Найти все максимальные цепочки подряд идущих...

Цепочки вызовов методов
Здравствуйте! В общем чет нагуглить не получилось, хотя как мне казалось задача тривиальная. Вот простой понятный...

Стек вызовов
в данное время изучаю Javascript. дошла до исключений и встретила понятие &quot;вверх по стеку&quot;. что оно означает? определение стек...

4
27 / 27 / 18
Регистрация: 13.09.2014
Сообщений: 137
14.12.2016, 01:21
Renji, еще вариант.

C++
1
2
3
4
5
6
7
8
9
enum ACTION {ADD, REMOVE, REPORT} 
 
void function_logger(string funcName, ACTION a)
{
  static list_type _list;
  if (a == ACTION::PUSH) _list.add(funcNme);
  else if (a == ACTION::REMOVE) _list.removeLast()
  else {/*print error*/}
}
Вызывать в начале и в конце каждой функции:

C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
void func3()
{
  function_logger(__FUNC__, ACTION::ADD);
  if (error) function_logger(__FUNC__, ACTION::REPORT);
  function_logger(__FUNC__, ACTION::REMOVE);
}
 
void func2()
{
  function_logger(__FUNC__, ACTION::ADD);
  func3();
  function_logger(__FUNC__, ACTION::REMOVE);
}
 
void func1()
{
  function_logger(__FUNC__, ACTION::ADD);
  func2();
  function_logger(__FUNC__, ACTION::REMOVE);
}
Добавлено через 10 минут
Или класс со статическими методами и переменной, содержащей список имен функций. Т.е. можем получить доступ к этой переменной в любой момент и работать с ней.
Или сделать, чтобы func_logger() возвращал ссылку на статическую переменную внутри себя.
1
Эксперт С++
 Аватар для Mr.X
3225 / 1752 / 436
Регистрация: 03.05.2010
Сообщений: 3,867
14.12.2016, 02:09
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
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
//Функция func1 вызывает функцию func2. Функция func2
//вызывает функцию func3. А в функции func3 происходит сбой
//и функция показывает сообщение об ошибке. Каким наименее
//геморойным способом можно из func3 получить цепочку вызовов
//func1->func2->func3 и отобразить ее в сообщении об ошибке?
//Пусть даже с привязкой к расширениям конкретного компилятора.
//В голову приходит вариант кинуть из func3 исключение, а потом
//во всех вышестоящих функциях ловить это исключение, писать
//"ошибка туточки" и кидать исключение дальше. Но это каждую
//функцию надо будет в try-catch секцию обшивать.
///////////////////////////////////////////////////////////////////////////////
#include <cstdlib>
#include <ctime>
#include <iostream>
#include <sstream>
#include <string>
///////////////////////////////////////////////////////////////////////////////
typedef std::string     T_str;
///////////////////////////////////////////////////////////////////////////////
void    f_3( std::ostream  &   info_ostr )
{
    info_ostr   <<  __FUNCTION__
                <<  '\t';
 
    if  (
            rand() % 2
        )
    {
        info_ostr   <<  "error"
                    <<  '\t';
    }
}
///////////////////////////////////////////////////////////////////////////////
void    f_2( std::ostream  &   info_ostr )
{
    info_ostr   <<  __FUNCTION__
                <<  '\t';
 
    if  (
            rand() % 2
        )
    {
        info_ostr   <<  "error"
                    <<  '\t';
    }
    else
    {
        f_3( info_ostr );
    }
}
///////////////////////////////////////////////////////////////////////////////
void    f_1( std::ostream  &   info_ostr )
{
    info_ostr   <<  __FUNCTION__
                <<  '\t';
 
    if  (
            rand() % 2
        )
    {
        info_ostr   <<  "error"
                    <<  '\t';
    }
    else
    {
        f_2( info_ostr );
    }
}
///////////////////////////////////////////////////////////////////////////////
int     main()
{
    srand(unsigned(time(0)));
 
    for(;;)
    {
        std::ostringstream  info_ostr;
        f_1( info_ostr );
 
        std::cout   <<  std::endl
                    <<  info_ostr.str()
                    <<  std::endl;
 
        system("pause");
    }//for
}
1
Эксперт С++
 Аватар для hoggy
8973 / 4319 / 960
Регистрация: 15.11.2014
Сообщений: 9,760
14.12.2016, 04:01
Цитата Сообщение от Renji Посмотреть сообщение
Каким наименее геморойным способом можно из func3 получить цепочку вызовов func1->func2->func3 и отобразить ее в сообщении об ошибке?
1.
логгирование.

2.
паттерн "политики" (не путать со стратегией).
1
2784 / 1937 / 570
Регистрация: 05.06.2014
Сообщений: 5,602
14.12.2016, 10:01  [ТС]
Цитата Сообщение от hoggy Посмотреть сообщение
паттерн "политики" (не путать со стратегией).
Чего-то не нашел такого. Можно поподробней?
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
14.12.2016, 10:01
Помогаю со студенческими работами здесь

Запрет вызовов
Можете подсказать модель телефона, в котором можно поставить запрет на входящие/исходящие вызовы. К примеру в Motorola C380 можно выбрать...

Запрет вызовов?
Подскажите пожалуйста, как можно организовать на Android 2.2 запрет входящих? Вариант с дополнительными приложениями не подходит, т.к....

Перенаправление вызовов
День добрый! Стоит задача: Есть два филиала, один в РБ, другой в Казахстане, надо сделать так что бы если в казахстане не подняли...

Стек вызовов
Прочитал про то, что память не очищается после очистки стека от функции и просто освобождается. Логично предположил, что можно получить...

Переполнение стека вызовов
using System; using System.Collections.Generic; namespace Lists { /// &lt;summary&gt; /// Позволяет выводить на экран строковые...


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

Или воспользуйтесь поиском по форуму:
5
Ответ Создать тему
Новые блоги и статьи
Автозаполнение реквизита при выборе элемента справочника
Maks 27.03.2026
Программный код из решения ниже на примере нетипового документа "ЗаявкаНаРемонтСпецтехники" разработанного в конфигурации КА2. При выборе "Спецтехники" (Тип Справочник. Спецтехника), заполняется. . .
Сумматор с применением элементов трёх состояний.
Hrethgir 26.03.2026
Тут. https:/ / fips. ru/ EGD/ ab3c85c8-836d-4866-871b-c2f0c5d77fbc Первый документ красиво выглядит, но без схемы. Это конечно не даёт никаких плюсов автору, но тем не менее. . . всё может быть. . .
Автозаполнение реквизитов при создании документа
Maks 26.03.2026
Программный код из решения ниже размещается в модуле объекта документа, в процедуре "ПриСозданииНаСервере". Алгоритм проверки заполнения реализован для исключения перезаписи значения реквизита,. . .
Команды формы и диалоговое окно
Maks 26.03.2026
1. Команда формы "ЗаполнитьЗапчасти". Программный код из решения ниже на примере нетипового документа "ЗаявкаНаРемонтСпецтехники" разработанного в конфигурации КА2. В качестве источника данных. . .
Кому нужен AOT?
DevAlt 26.03.2026
Решил сделать простой ланчер Написал заготовку: dotnet new console --aot -o UrlHandler var items = args. Split(":"); var tag = items; var id = items; var executable = args;. . .
Отправка уведомления на почту при создании или изменении элементов справочника
Maks 24.03.2026
Программная отправка письма электронной почты на примере типового справочника "Склады" в конфигурации БП3. Перед реализацией необходимо выполнить настройку системной учетной записи электронной. . .
модель ЗдравоСохранения 5. Меньше увольнений- больше дохода!
anaschu 24.03.2026
Теперь система здравосохранения уменьшает количество увольнений. 9TO2GP2bpX4 a42b81fb172ffc12ca589c7898261ccb/ https:/ / rutube. ru/ video/ a42b81fb172ffc12ca589c7898261ccb/ Слева синяя линия -. . .
Midnight Chicago Blues
kumehtar 24.03.2026
Такой Midnight Chicago Blues, знаешь?. . Когда вечерние улицы становятся ночными, а ты не можешь уснуть. Ты идёшь в любимый старый бар, и бармен наливает тебе виски. Ты смотришь на пролетающие. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru