М
МишаDec. 4, 2017, 10:15 a.m.

Как динамической библиотеки использовать переменные класса?

динамическая библиот, QLibrary

Здравствуйте.

У меня есть динамическая библиотека с функцией
void StrategyCod2()
{
    qDebug()<<"Library work2"<<NBar;
}
где NBar - это переменная класса MainWindow основного приложения, вызывающего динамическую библиотеку.
Скажите пожалуйста как функции StrategyCod2() заставить выдавать переменную NBar?
We recommend hosting TIMEWEB
We recommend hosting TIMEWEB
Stable hosting, on which the social network EVILEG is located. For projects on Django we recommend VDS hosting.

Do you like it? Share on social networks!

43
Evgenii Legotckoi
  • Dec. 4, 2017, 4 p.m.

День добрый!
Нужно инстанцировать класс. То есть без созданного объекта класса вы не сможете использовать методы этого класса.

    М
    • Dec. 5, 2017, 2:26 a.m.

    Но как это сделать в динамической библиотеке? Наверно нужно указать ссылку на хедер класса?

      М
      • Dec. 5, 2017, 2:45 a.m.

      Добавил в библиотеку

      #include <C:\\Qt\project\\MyCandleSrick\\mainwindow.h>
      Выдало ошибку на первом же инклуде проекта.
        Evgenii Legotckoi
        • Dec. 5, 2017, 4:24 p.m.

        А вот теперь мы плавно подобрались к нормальному подключению библиотек.
        Для начала смотрим как подключаются предкомпилированные библиотеки на примере статьи о подключении boost . Подробнее посмотрите часть, где описывается QtBoostHello.pro .

        Также смотрите как нормально подключить библиотеку в официальной документации . Там даже скриншоты есть.
          М
          • Dec. 6, 2017, 12:55 a.m.

          Но мне нужна динамическая библиотека для изменения кода библиотеки и последующего подключения. Моя библиотека компилируется и работает, если многого от нее не хотеть.

          На сайте QT описан такой вариант, у меня он работает
             QLibrary MyLib("C:\\Qt\\project\\build-StrategyCod-Desktop_Qt_5_9_2_MinGW_32bit-Debug\\debug\\StrategyCod");  //путь к библиотеке
              MyLib.load();//чтение
              typedef void (*MyPrototype)();
              MyPrototype StrategyCod = (MyPrototype) MyLib.resolve("StrategyCod");
              StrategyCod();  //вызов стратегии из библиотеки
              MyLib.unload();//отключение библиотеки

            М
            • Dec. 6, 2017, 1:17 a.m.

            тут проект библиотеки

              Evgenii Legotckoi
              • Dec. 6, 2017, 2:53 a.m.

              Попробуйте тогда переписать инклюд ещё раз. Только таким образом.

              #include <C:/Qt/project/MyCandleSrick/mainwindow.h>
              Ну и ещё один момент. Если у вас в проекте два заголовочника с одинаковыми именами, а там классы с иденаковыми именами, как и в главном проекте, то ошибки нужно разруливать на уровне namespace .

              А вообще, когда говорите, что инклюд не работает, то приводите ошибку, которую выдаёт компилятор. Я не экстрасенс, чтобы догадываться, что именно у вас там пошло не так.
                М
                • Dec. 6, 2017, 2:59 a.m.

                Когда я прописал INCLUDEPATH = "C:/Qt/project/MyCandleSrick" "C:/Qt/Qt5.9.2/5.9.2/Src/qtbase/include/QtWidgets" с инклудом трудности закончились.

                Когда  функцию написал так
                void StrategyCod(/*MainWinow * main*/)
                {
                    MainWindow w;
                    qDebug()<<"Library work2"<<w.NBar;
                }
                Выдало ошибки :
                C:\Qt\project\StrategyCod\strategycod.cpp:11: ошибка: undefined reference to `MainWindow::MainWindow(QWidget*)'
                C:\Qt\project\StrategyCod\strategycod.cpp:11: ошибка: undefined reference to `MainWindow::~MainWindow()'
                C:\Qt\project\StrategyCod\strategycod.cpp:11: ошибка: undefined reference to `MainWindow::~MainWindow()'
                collect2.exe:-1: ошибка: error: ld returned 1 exit status
                11 строчка: MainWindow w;
                  М
                  • Dec. 6, 2017, 3:07 a.m.
                  Сделал так в хедере 
                  extern "C" {STRATEGYCODSHARED_EXPORT void StrategyCod(MainWindow * main);}
                  А так в *.срр
                  void StrategyCod(MainWindow * main)
                  {
                      //MainWindow w;
                      main->NBar;
                      qDebug()<<"Library work2"<<main->NBar;//<<w.NBar;
                  }
                  Вот только возвращает число не NBar не правильное выводит.
                    Evgenii Legotckoi
                    • Dec. 6, 2017, 3:14 a.m.
                    • (edited)

                    Зря передаёте объект окна для расчёта. Нужно передавать набор информации. Вектор значений, все эти текущие NBar, которые уже должны быть в вашем окне. Вообще, передавать объект главного окна приложения для математических расчётов это дурной тон, что ведёт к тому, что проект становится неподдерживаемым и трудночитаемым. Вы подменяете сущности и понятия своими действиями, обычно такой код без сожаления удаляют и переписывают с нуля, вместо того, чтобы разбираться, что там написано.


                    Если бы вы передавали неконстантные ссылки на NBar и, например, возвращали бы этой функцией результат расчёта, то было бы гораздо адекватнее. неконстантны ссылки позволяют делать изменения значений.
                      М
                      • Dec. 6, 2017, 3:33 a.m.

                      Скажите пожалуйста, как правильно сделать ссылку, так не работает

                      void StrategyCod(/*MainWindow * main*/)
                      {
                          long long &NBar1 =MainWindow.NBar;
                          qDebug()<<"Library work2";//<<w.NBar;
                      }
                        Evgenii Legotckoi
                        • Dec. 6, 2017, 3:40 a.m.
                        • (edited)

                        я бы так переписал сам метод в стратегии

                        void StrategyCod(long long &NBar)
                        {
                            qDebug()<<"Library work2" << NBar1;
                        }
                        А там уже, где вы задаете этот параметр, вызвал бы этот метод передавая ссылку на nbar
                        void someMethodInMainProgram()
                        {
                            // Например, если имеете переменную NBar
                            StrategyCod(m_NBar); 
                        }
                          М
                          • Dec. 6, 2017, 3:44 a.m.

                          Можно и так, но у меня 10 переменных и векторов, участвующих в будущем коде. Выйдет немного не читабельно.

                          И еще этот код должен менять около 10 переменных и векторов класса, по окончанию расчетов.
                            Evgenii Legotckoi
                            • Dec. 6, 2017, 3:52 a.m.
                            • (edited)

                            Этот будет читабельно, если сделать специальную структуру данных, которая будет передаваться для расчёта и содержать необходимые значения.

                            struct StrategyData
                            {
                                long long NBar;
                                // и т.д.
                            }
                            В главном окне приложения можно сделать метод, который будет подготавливать эти значения.

                            Вы делаете отдельную библиотеку, которая должна делать только расчёт. С точки зрения архитектурного планирования софта, эта библиотека не может управлять переменными и данными, которые находятся в GUI, а тем более иметь потенциальную возможность вызывать методы объекта окна приложения. Это уже с точки зрения безопасности софта полный ахтунг. Она должна получить данные и вернуть их. Можете передавать ссылку на подготовленную структуру, как я показал на примере NBar.

                            А также то, что вы делаете передачу объекта GUI в библиотеку уже делает бессмысленным сам факт того, что вы вынесли стратегию в отдельную библиотеку.
                              М
                              • Dec. 6, 2017, 3:58 a.m.

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

                              Но как быть с возвратом данных? тоже через структуру? может быть все же есть способ изменить данные класса?
                                Evgenii Legotckoi
                                • Dec. 6, 2017, 4:15 a.m.
                                • (edited)

                                Вы что, при каждом вызове стратегии считываете данные из файла? Сохраняйте в памяти приложения загруженные данные. Отсылайте их на расчёт, получайте результат. Не понравилось, изменить установки, заново отошлите на расчёт. При этом если данные уже считаны, то не нужно второй раз загружать с файла. Если передаётся объект по ссылке, то объект не копируется, а поэтому все изменения проделываются в объекте, который находится в окне приложения.


                                Вообще бред говорите по поводу приложения. Посылать целое окно приложения просто потому, что вы не знаете языка программирования настолько, чтобы написать адекватный вариант работы с данными... Меня бы за такие решения после второй недели испытательного срока уволили бы.
                                  М
                                  • Dec. 6, 2017, 4:24 a.m.

                                  Установки расчета изменить не достаточно, нужно менять код(он может растягиваться на более 300 строк и порой менять его нужно весьма серьезно). А просто так изменить код в работающем приложении на С++ нельзя. Поэтому и нужна библиотека. Данный считываются только раз, или в дальнейшем при необходимости.

                                  Я знаю что ссылка меняет объект, потому и хочу пользоваться ссылкой.  Можно ли как-то сделать ссылки на объекты класса?
                                    Evgenii Legotckoi
                                    • Dec. 6, 2017, 4:30 a.m.

                                    300 строк? ))) это мелочь... это просто ни о чём... вообще ни о чём. в ряде случаев это всего лишь час работы...
                                    Ваши данные и установки не изменяются, стандартизация данных для расчётов полностью решает многие надуманные вами проблемы.


                                    Ссылка на объект некоторого класса делается также, как и на стандартные типы данных.

                                    И я не буду подсказывать Вам, как передать окно приложения в стороннюю библиотеку, это бред, мои профессиональные компетенции не позволяют мне советовать решения проблемы для заведомо неправильной архитектуры приложения. Пользовательский интерфейс и данные - это разные сущности. И они должны быть отделены друг от друга.
                                      М
                                      • Dec. 6, 2017, 5:02 a.m.

                                      Это могут быть сильно различные 300 строк. И заранее описать трудно, т.к. мысли приходят в процессе работы.

                                      Если ссылка делается так
                                      int q1=5;
                                      int &q2=q1;
                                      то если пишу ссылку на объект класса
                                      long long &NBar1 =MainWindow.NBar;
                                      выдает ошибку C:\Qt\project\StrategyCod\strategycod.cpp:14: ошибка: expected primary-expression before '.' token
                                      long long &NBar1 =MainWindow.NBar;
                                      Скажите пожалуйста, как правильно это написать?
                                        Evgenii Legotckoi
                                        • Dec. 6, 2017, 5:10 a.m.
                                        Это могут быть сильно различные 300 строк. И заранее описать трудно, т.к. мысли приходят в процессе работы.
                                        Для этого есть этап рефакторинга, во время которого обобщаются методы и сущности. Но и при прототипировании проекта нужно думать наперёд. К сожалению это приходит с опытом, но это не значит, что не нужно пытаться делать этого.

                                        long long &NBar1 =MainWindow.NBar;
                                        Класс нужно инстанцировать... У вас не создан объект класса, а поэтому вы не можете использовать объект из него. Он просто не существует.
                                          М
                                          • Dec. 6, 2017, 5:14 a.m.

                                          Не могу создать объект класса. Если делаю так

                                          void StrategyCod(double Parametr)/*MainWindow * main*/
                                          {
                                              MainWindow w;
                                              long long &NBar1 =w.NBar;
                                              qDebug()<<"Library work2";//<<w.NBar;
                                          }
                                          То появляются ошибки:
                                          C:\Qt\project\StrategyCod\strategycod.cpp:11: ошибка: undefined reference to `MainWindow::MainWindow(QWidget*)'
                                          C:\Qt\project\StrategyCod\strategycod.cpp:11: ошибка: undefined reference to `MainWindow::~MainWindow()'
                                          C:\Qt\project\StrategyCod\strategycod.cpp:11: ошибка: undefined reference to `MainWindow::~MainWindow()'
                                          collect2.exe:-1: ошибка: error: ld returned 1 exit status
                                          11 строчка : MainWindow w;
                                            Evgenii Legotckoi
                                            • Dec. 6, 2017, 5:19 a.m.

                                            Нужно подключить заголовочный файл этого MainWindow в код, где хотите инстанцировать.
                                            Вот только у меня такое подозрение, что у вас этот самый MainWindow - это и есть приложение...

                                            Получается, что ваша библиотека со стратегией имеет зависимость от главного приложения, а приложение зависит от библиотеки... Замкнутый круг получается )))) Тут что-то одно должно зависеть от другого... иерархия зависимостей библиотек может быть только древовидной... (опустим ромбовидное наследование и т.д.)

                                            Используйте структуру данных ))) хотя бы попытайтесь...
                                              М
                                              • Dec. 6, 2017, 5:29 a.m.
                                              #include "mainwindow.h" подключен, но ошибки остаются.
                                              По моей задумке оно было все взаимосвязанно.
                                              Структура данных наверно поможет, но это будет то же самое, только больше времени потребуется на передачу данных и немного больше возни с кодом. Если доделать ссылки, это все упростит.
                                              Скажите пожалуйста, как все же создать объект класса и заставить работать ссылки?
                                                Evgenii Legotckoi
                                                • Dec. 6, 2017, 5:47 a.m.

                                                Ваша задумка страшна, как атомная война ))) ну серьёзно ))

                                                Посылать GUI в библиотеку, которая работает исключительно с данными... никто так софт не разрабатывает в серьёзных компаниях, такое просто не проходит код ревью.
                                                По поводу больше времени - вы пробовали делать прототип и измерение времени? - нет, не делали.
                                                Больше возни с кодом - вообще не аргумент. Вы и так потратили кучу времени на заведомо неадекватное решение с точки зрения разработки архитектуры программы.
                                                  М
                                                  • Dec. 6, 2017, 6:02 a.m.

                                                  Я добавил в функцию один аргумент

                                                  void StrategyCod(double Parametr)/*MainWindow * main*/
                                                  {
                                                      qDebug()<<"Library work2"<<Parametr;//<<w.NBar;
                                                  }
                                                  Но при вызове не могу его указать. Если пишу так
                                                  QLibrary MyLib("C:\\Qt\\project\\build-StrategyCod-Desktop_Qt_5_9_2_MinGW_32bit-Debug\\debug\\StrategyCod");  //путь к библиотеке
                                                      MyLib.load();//чтение
                                                      typedef void (*MyPrototype)();
                                                      MyPrototype StrategyCod = (MyPrototype) MyLib.resolve("StrategyCod");
                                                      StrategyCod(25);  //вызов стратегии из библиотеки
                                                      MyLib.unload();//отключение библиотеки
                                                  То выдает ошибку  C:\Qt\project\MyCandleSrick\main.cpp:38: ошибка: too many arguments to function
                                                  StrategyCod(25);  //вызов стратегии РёР· библиотеки
                                                  ^
                                                  строка 38 :StrategyCod(25);
                                                    Evgenii Legotckoi
                                                    • Dec. 6, 2017, 6:06 a.m.

                                                    Ну а прототип функции кто будет правильно описывать за вас?

                                                    typedef void (*MyPrototype)(double);
                                                      М
                                                      • Dec. 6, 2017, 6:11 a.m.

                                                      Спасибо, заработало.

                                                      Раз ссылки не работают, то после вычислений в функции стоит создавать структуру и делать ее возвращение,а в приложении создавать такую же структуру и выводить в нее возвращаемые результаты функции? а уже из этой структуры выводить значения в переменные и векторы класса?

                                                        Evgenii Legotckoi
                                                        • Dec. 6, 2017, 6:16 a.m.

                                                        Вообще, по хорошему, у вас должна быть возможность подключить заголовочный файл библиотеки, в котором будет объявлена структура со всеми полями. В приложении создаёте структуру и посылаете ссылку на неё в библиотеку. Библиотека всё считает и изменяет поля структуры. Даже возвращать ничего не нужно.

                                                          М
                                                          • Dec. 6, 2017, 6:52 a.m.

                                                          Но тогда какая разница, почему не сделать ссылку на класс?

                                                          Я сделал структуру в main.cpp
                                                             struct Test1
                                                              {
                                                                int q1;
                                                                int q2;
                                                              };
                                                              Test1 Struct1; Struct1.q1=12; Struct1.q2=14;
                                                          В библиотеке сделал так:
                                                          #include "strategycod.h"
                                                          #include <QDebug>
                                                          #include "mainwindow.h"
                                                          #include "main.cpp"
                                                          void StrategyCod(double Parametr)
                                                          {
                                                              struct &name=Struct1;
                                                              qDebug()<<"Library work2"<<Parametr;//<<w.NBar;
                                                          }
                                                          Но ссылку сделать не удается, в библиотеке нет знания Test1 и  Struct1

                                                            Evgenii Legotckoi
                                                            • Dec. 6, 2017, 7:01 a.m.
                                                            #include "main.cpp"
                                                            Внутри файла исходных кодов библиотеки? Простите, вы вообще в своём уме?

                                                            #include "mainwindow.h"
                                                            А это главное окно приложения, и опять библиотека зависит от главного приложения.

                                                            НЕ МОЖЕТ БИБЛИОТЕКА ИМЕТЬ ЗАВИСИМОСТЬ ОТ ГЛАВНОГО ПРИЛОЖЕНИЯ НИКОГДА!!!

                                                            Я распинаюсь битый час, чтобы донести до вас эту мысль, а вам что в лоб, что по лбу.
                                                              М
                                                              • Dec. 6, 2017, 7:10 a.m.

                                                              Да я для примера беру эти файлы.

                                                              Создал файл в проекте test1.h , в нем написал
                                                              #ifndef TEST1_H
                                                              #define TEST1_H
                                                              struct Test1
                                                                  {
                                                                    int q1;
                                                                    int q2;
                                                                  };
                                                                  struct Test1 Struct1; Struct1.q1=12; Struct1.q2=14;
                                                              #endif // TEST1_H
                                                              Как теперь сделать ссылку на структуру Struct1 ?
                                                                BlinCT
                                                                • Dec. 6, 2017, 7:11 a.m.

                                                                А вы сильны в своем стремлении создать новый принцып программирования)

                                                                  М
                                                                  • Dec. 6, 2017, 7:13 a.m.

                                                                  Мне нужно просто решить один последний момент моей программы.  Подскажите пожалуйста, как сделать рабочую ссылку на структуру или класс.

                                                                    М
                                                                    • Dec. 6, 2017, 10:05 a.m.

                                                                    разобрался, написал так и заработало

                                                                    QLibrary MyLib("C:\\Qt\\project\\build-StrategyCod-Desktop_Qt_5_9_2_MinGW_32bit-Debug\\debug\\StrategyCod");  
                                                                        MyLib.load();
                                                                        typedef void (*MyPrototype)(MainWindow *);
                                                                        MyPrototype StrategyCod = (MyPrototype) MyLib.resolve("StrategyCod");
                                                                        StrategyCod(&w);  
                                                                        qDebug()<<"q1"<< q1;
                                                                        MyLib.unload();
                                                                      BlinCT
                                                                      • Dec. 7, 2017, 2:29 a.m.

                                                                      Скажите, а это вы пишите на работе что то или нет?)

                                                                        М
                                                                        • Dec. 7, 2017, 2:32 a.m.

                                                                        Нет для себя. Мне удобней такая форма. Производительность не должна страдать. Хотя конечно интерфейс не очень. Но он тут не особо нужен.

                                                                        Но возникла новая трудность. Поместил эту конструкцию в слот класса
                                                                        QLibrary MyLib("C:\\Qt\\project\\build-StrategyCod-Desktop_Qt_5_9_2_MinGW_32bit-Debug\\debug\\StrategyCod");  //путь к библиотеке
                                                                            MyLib.load();//чтение
                                                                            typedef void (*MyPrototype)(double,MainWindow *);
                                                                            MyPrototype StrategyCod = (MyPrototype) MyLib.resolve("StrategyCod");
                                                                            MainWindow w;
                                                                            qDebug()<<NBar;
                                                                            StrategyCod(ParametrForStrategyCod,&w);  //вызов стратегии из библиотеки
                                                                            MyLib.unload();//отключение библиотеки
                                                                        А в самой библиотеке функция
                                                                        void StrategyCod(double Parametr, MainWindow *w)
                                                                        {
                                                                            qDebug()<<"Library work2"<< Parametr<<w->NBar;
                                                                        }
                                                                        qDebug возвращает NBar=1064, а функция NBar=0
                                                                        Скажите пожалуйста что не так?
                                                                        При этом из мэйна нормально работает.
                                                                          BlinCT
                                                                          • Dec. 7, 2017, 2:34 a.m.

                                                                          Это хорошо что вы для себя пишите(или плохо), а то за такое "мне так удобно" вас бы уволили)
                                                                          Но вы наслаждайтесь достижениями)

                                                                            М
                                                                            • Dec. 7, 2017, 2:37 a.m.

                                                                            Это да. Если бы я делал это для кого-то, то наверняка иначе. Все же не могли бы помочь решить вопрос с ссылкой на объект класса. Не знаете, почему при таком вызове выдает 0? И как это поправить?

                                                                              М
                                                                              • Dec. 7, 2017, 2:44 a.m.

                                                                              И пожалуйста не судите строго, это мое первое приложение на с++

                                                                                М
                                                                                • Dec. 7, 2017, 3:22 a.m.

                                                                                Сделал так и заработало

                                                                                StrategyCod(ParametrForStrategyCod,this); 
                                                                                  BlinCT
                                                                                  • Dec. 7, 2017, 3:39 a.m.

                                                                                  Ну знаете, когда человек только учится языку программирования он слушает более знающих и понимающих. Круто что вы так уперты в своих целях. Но и слушать что вам пишут понимающие и знающие больше чем вы, нужно. Вы сейчас пишите для себя, а потом ан работу придете и будет так же писать потому что будете считать что так работает и так норм.
                                                                                  Но это всего лишь совет, как поступать это лично ваше дело.

                                                                                    М
                                                                                    • Dec. 7, 2017, 3:44 a.m.

                                                                                    Я понимаю советы, и считаю что они справедливы и правильны. Просто специфика решаемого мною вопроса толкает меня на такие действия, ну и плюс мое не знание.

                                                                                      М
                                                                                      • Dec. 7, 2017, 3:54 a.m.

                                                                                      А как это запустить в многопоточности, используя лямбда функцию? Этот код не работает:

                                                                                      QVector <double> Perebor1;
                                                                                             for (double i=d1;i<=d2;i=i+d3) 
                                                                                             {
                                                                                                 Perebor1.append(i);
                                                                                             }
                                                                                             QLibrary MyLib("C:\\Qt\\project\\build-StrategyCod-Desktop_Qt_5_9_2_MinGW_32bit-Debug\\debug\\StrategyCod");  
                                                                                             MyLib.load();
                                                                                             typedef void (*MyPrototype)(double,MainWindow *);
                                                                                             MyPrototype StrategyCod = (MyPrototype) MyLib.resolve("StrategyCod");
                                                                                             //StrategyCod(ParametrForStrategyCod,this);  
                                                                                             QFuture<void> Perebor2 = QtConcurrent::map(Perebor1,[&](const double& d){ StrategyCod(d,this);}); 
                                                                                             MyLib.unload();

                                                                                        Comments

                                                                                        Only authorized users can post comments.
                                                                                        Please, Log in or Sign up
                                                                                        AD

                                                                                        C ++ - Test 004. Pointers, Arrays and Loops

                                                                                        • Result:50points,
                                                                                        • Rating points-4
                                                                                        m

                                                                                        C ++ - Test 004. Pointers, Arrays and Loops

                                                                                        • Result:80points,
                                                                                        • Rating points4
                                                                                        m

                                                                                        C ++ - Test 004. Pointers, Arrays and Loops

                                                                                        • Result:20points,
                                                                                        • Rating points-10
                                                                                        Last comments
                                                                                        i
                                                                                        innorwallNov. 13, 2024, 11:03 p.m.
                                                                                        How to make game using Qt - Lesson 3. Interaction with other objects what is priligy tablets What happens during the LASIK surgery process
                                                                                        i
                                                                                        innorwallNov. 13, 2024, 8:09 p.m.
                                                                                        Using variables declared in CMakeLists.txt inside C ++ files where can i buy priligy online safely Tom Platz How about things like we read about in the magazines like roid rage and does that really
                                                                                        i
                                                                                        innorwallNov. 11, 2024, 10:12 p.m.
                                                                                        Django - Tutorial 055. How to write auto populate field functionality Freckles because of several brand names retin a, atralin buy generic priligy
                                                                                        i
                                                                                        innorwallNov. 11, 2024, 6:23 p.m.
                                                                                        QML - Tutorial 035. Using enumerations in QML without C ++ priligy cvs 24 Together with antibiotics such as amphotericin B 10, griseofulvin 11 and streptomycin 12, chloramphenicol 9 is in the World Health Organisation s List of Essential Medici…
                                                                                        i
                                                                                        innorwallNov. 11, 2024, 3:50 p.m.
                                                                                        Qt/C++ - Lesson 052. Customization Qt Audio player in the style of AIMP It decreases stress, supports hormone balance, and regulates and increases blood flow to the reproductive organs buy priligy online safe Promising data were reported in a PDX model re…
                                                                                        Now discuss on the forum
                                                                                        i
                                                                                        innorwallNov. 14, 2024, 12:39 a.m.
                                                                                        добавить qlineseries в функции Listen intently to what Jerry says about Conditional Acceptance because that s the bargaining chip in the song and dance you will have to engage in to protect yourself and your family from AMI S…
                                                                                        i
                                                                                        innorwallNov. 11, 2024, 10:55 a.m.
                                                                                        Всё ещё разбираюсь с кешем. priligy walgreens levitra dulcolax carbs The third ring was found to be made up of ultra relativistic electrons, which are also present in both the outer and inner rings
                                                                                        9
                                                                                        9AnonimOct. 25, 2024, 9:10 a.m.
                                                                                        Машина тьюринга // Начальное состояние 0 0, ,<,1 // Переход в состояние 1 при пустом символе 0,0,>,0 // Остаемся в состоянии 0, двигаясь вправо при встрече 0 0,1,>…

                                                                                        Follow us in social networks