
| Author | Message |
|---|---|
|
Written on: 20. 10. 2011 [16:40]
|
|
|
hyper_sonic
Роман Федоров
Topic creator
registered since: 13.09.2011
Posts: 13
|
В свободное время разбираюсь в исходниках. Мне вот интересно как прикрутить проект к какой-нибудь правильной IDE и как настроить там отладку. Сейчас сижу в Netbeans, но после запуска вижу только splash screen, гуи не запускаются и Netbean до посинения что там отлаживает. :bang: Хотя просто запуск с кнопки в панели Netbeans проходит успешно. |
|
Written on: 20. 10. 2011 [17:17]
|
|
|
roman
Roman Savochenko
Moderator Contributor Developer
registered since: 12.12.2007
Posts: 3790
|
Смотря что NetBeans использует для отладки. Хотя думаю это не имеет значения. Как Вы вообще представляете себе отладку ресурсоёмкого и многопоточного проекта с вычислителями на периодичности порядка 10мс, в реальном времени? Тот же Valgrind просто стопорит систему даже при запуске без вычислений. Learn, learn and learn better than work, work and work.
|
|
Written on: 20. 10. 2011 [17:23]
|
|
|
hyper_sonic
Роман Федоров
Topic creator
registered since: 13.09.2011
Posts: 13
|
"roman" wrote: Смотря что NetBeans использует для отладки. Хотя думаю это не имеет значения. Как Вы вообще представляете себе отладку ресурсоёмкого и многопоточного проекта с вычислителями на периодичности порядка 10мс, в реальном времени. Тот же Valgrind просто стопорит систему даже при запуске без вычислений. NetBeans использует GDB 7.3, стандартный отладчик под linux. Все-таки я не представляю себе как писать программный модкль не имея возможности его отладить? |
|
Written on: 20. 10. 2011 [17:29]
|
|
|
roman
Roman Savochenko
Moderator Contributor Developer
registered since: 12.12.2007
Posts: 3790
|
"hyper_sonic" wrote: NetBeans использует GDB 7.3, стандартный отладчик под linux. Все-таки я не представляю себе как писать программный модкль не имея возможности его отладить? А я представляю - писать нужно правильно! И OpenSCADA написана без использования специализированных дебагеров и IDE всяких. Разве что ValGrind иногда запускается для отлова и изучения потенциальных утечек памяти и других проблем при работе с памятью, чего обычные дебагеры не умеют. GDB полезен в основном для изучения корок предсмертных дампов и не более того, для OpenSCADA. Learn, learn and learn better than work, work and work.
|
|
Written on: 21. 10. 2011 [09:54]
|
|
|
almaz
Almaz Karimov
Contributor
registered since: 25.09.2008
Posts: 516
|
"hyper_sonic" wrote: При написании любой программы на любом языке программирования возможность отладить есть всегда. Отлаживаю вставкой в нужном месте программы одной строчки (чаще всего) дополнительного кода, который выводит интересующие значения на экран терминала (или собирает значения в строковую переменную, в массив, в файл, в БД и т.д. с последующим выводом для просмотра и анализа). В сложных программах можно делать множество вставок таких "контрольных точек", контролируя одновременно множество взаимодействующих значений переменных. Все-таки я не представляю себе как писать программный модкль не имея возможности его отладить? 21 век - век повсеместной автоматизации. Главное - во благо всем людям.
|
|
Written on: 21. 10. 2011 [13:28]
|
|
|
hyper_sonic
Роман Федоров
Topic creator
registered since: 13.09.2011
Posts: 13
|
"almaz" wrote: "hyper_sonic" wrote: При написании любой программы на любом языке программирования возможность отладить есть всегда. Отлаживаю вставкой в нужном месте программы одной строчки (чаще всего) дополнительного кода, который выводит интересующие значения на экран терминала (или собирает значения в строковую переменную, в массив, в файл, в БД и т.д. с последующим выводом для просмотра и анализа). В сложных программах можно делать множество вставок таких "контрольных точек", контролируя одновременно множество взаимодействующих значений переменных.Все-таки я не представляю себе как писать программный модкль не имея возможности его отладить? Да конечно можно и так, но я только начинаю изучать как в OSCADA все тикает, а имея возможность отладить было бы проще это сделать. |
|
Written on: 21. 10. 2011 [14:19]
|
|
|
almaz
Almaz Karimov
Contributor
registered since: 25.09.2008
Posts: 516
|
При первом знакомстве с OpenSCADA тоже пытался настроить Netbeans для работы с исходным кодом. Сходу не получилось, поэтому и использую старый, добрый, простой и скоростной метод отладки вставкой отладочного кода. Если хотите пойти более сложным путём и всё-таки настроить Netbeans для работы с кодом OpenSCADA - пожалуйста. Поделитесь потом опытом... Может тоже попробую поработать с IDE... http://netbeans.mojgorod.ru/netbeans_firefox.html [This article was edited 2 times, at last 22.10.2011 at 02:24.] 21 век - век повсеместной автоматизации. Главное - во благо всем людям.
|
|
Written on: 31. 10. 2011 [10:15]
|
|
|
hyper_sonic
Роман Федоров
Topic creator
registered since: 13.09.2011
Posts: 13
|
"almaz" wrote: При первом знакомстве с OpenSCADA тоже пытался настроить Netbeans для работы с исходным кодом. Сходу не получилось, поэтому и использую старый, добрый, простой и скоростной метод отладки вставкой отладочного кода. Если хотите пойти более сложным путём и всё-таки настроить Netbeans для работы с кодом OpenSCADA - пожалуйста. Поделитесь потом опытом... Может тоже попробую поработать с IDE... http://netbeans.mojgorod.ru/netbeans_firefox.html Спасибо изучил ссылку, прикрутил Netbeans и даже теперь запускается отладка, сборка и очистка проекта работает, подсветка... Дал пользователю, из под которого работаю в системе, разрешение на создание задачи с риал-тайм приоритетом...(см. последнюю строчку) cat /etc/security/limits.conf # /etc/security/limits.conf # #Each line describes a limit for a user in the form: # #<domain> <type> <item> <value> # #Where: #<domain> can be: # - an user name # - a group name, with @group syntax # - the wildcard *, for default entry # - the wildcard %, can be also used with %group syntax, # for maxlogin limit # - NOTE: group and wildcard limits are not applied to root. # To apply a limit to the root user, <domain> must be # the literal username root. # #<type> can have the two values: # - "soft" for enforcing the soft limits # - "hard" for enforcing hard limits # #<item> can be one of the following: # - core - limits the core file size (KB) # - data - max data size (KB) # - fsize - maximum filesize (KB) # - memlock - max locked-in-memory address space (KB) # - nofile - max number of open files # - rss - max resident set size (KB) # - stack - max stack size (KB) # - cpu - max CPU time (MIN) # - nproc - max number of processes # - as - address space limit (KB) # - maxlogins - max number of logins for this user # - maxsyslogins - max number of logins on the system # - priority - the priority to run user process with # - locks - max number of file locks the user can hold # - sigpending - max number of pending signals # - msgqueue - max memory used by POSIX message queues (bytes) # - nice - max nice priority allowed to raise to values: [-20, 19] # - rtprio - max realtime priority # - chroot - change root to directory (Debian-specific) # #<domain> <type> <item> <value> # #* soft core 0 #root hard core 100000 #* hard rss 10000 #@student hard nproc 20 #@faculty soft nproc 20 #@faculty hard nproc 50 #ftp hard nproc 0 #ftp - chroot /ftp #@student - maxlogins 4 @realtime - rtprio 99 # End of file Без этого отладчик отваливался. Но отладить модуль сбора все равно не выходит... Ставлю точку останова в какой-нибудь функции, а отладчик ее игнорирует. Ловит точки останова только в основном потоке... |
|
Written on: 31. 10. 2011 [13:54]
|
|
|
almaz
Almaz Karimov
Contributor
registered since: 25.09.2008
Posts: 516
|
Может вот эта ссылка поможет? Отладка многопоточных приложений в среде IDE NetBeans: http://netbeans.org/kb/docs/java/debug-multithreaded_ru.html Там же есть видео по многопоточной отладке: http://netbeans.org/kb/docs/java/debug-multithreaded-screencast.html Ещё в настройках "C++ Compiler" есть параметр "Multithreading Level": http://netbeans.mojgorod.ru/project_properties.html [This article was edited 1 times, at last 31.10.2011 at 14:06.] 21 век - век повсеместной автоматизации. Главное - во благо всем людям.
|