Skip to content
  • Categories
  • Recent
  • Tags
  • Popular
  • Users
  • Groups
  • Search
  • Get Qt Extensions
  • Unsolved
Collapse
Brand Logo
  1. Home
  2. Qt Development
  3. General and Desktop
  4. QUdpSocket receive Datagram into QtConcurrent
Forum Updated to NodeBB v4.3 + New Features

QUdpSocket receive Datagram into QtConcurrent

Scheduled Pinned Locked Moved Solved General and Desktop
24 Posts 4 Posters 3.0k Views 1 Watching
  • Oldest to Newest
  • Newest to Oldest
  • Most Votes
Reply
  • Reply as topic
Log in to reply
This topic has been deleted. Only users with topic management privileges can see it.
  • LudoFRL Offline
    LudoFRL Offline
    LudoFR
    wrote on last edited by
    #4

    Mean while i wrinting my previous answer... my GUI is freezed, i can move the windows but "Not responding" and cant resize for an example..
    Screenshot 2021-10-03 122614.png

    JonBJ 1 Reply Last reply
    0
    • LudoFRL LudoFR

      Mean while i wrinting my previous answer... my GUI is freezed, i can move the windows but "Not responding" and cant resize for an example..
      Screenshot 2021-10-03 122614.png

      JonBJ Offline
      JonBJ Offline
      JonB
      wrote on last edited by
      #5

      @LudoFR
      Where are you in your code when this happens? Like I said, I don't know if there is anything special in QML. But in principle the code you have written looks right to me for non-blocking: you connect() the QUdpSocket::readyRead() signal to your slot which only reads datagrams while (udpSock->hasPendingDatagrams()), then it should exit and the Ui become responsive again. How many times do you see qDebug() <<"Message From :" << datagram.data();? Put a qDebug() at the end of the slot so we know it has exited.

      1 Reply Last reply
      1
      • LudoFRL Offline
        LudoFRL Offline
        LudoFR
        wrote on last edited by LudoFR
        #6

        First, thanks for your anwser.

        Well in fact the goal is to get data read from joysticks and I/O cards, this "while" is infinite until the program is closed.

        Between 4 and 8 hours (work time).

        I have add a counter in my C# udp sender function and I send 131225 time in 10 seconds. Its a lot I know but in this data, some value like "Emergency button" need to be get really fast. Do you think this is the problem ?

        I don't know if that can help but here my C# sender function : (Function just created for my Qt training)

            public partial class MainWindow : Window
            {
                int counter = 0;
                public MainWindow()
                {
                    InitializeComponent();
        
                    Timer time = new Timer(10000);
                    time.Elapsed += Time_Elapsed;
        
                    Task.Run(() =>
                    {
                        Socket s = new Socket(AddressFamily.InterNetwork, SocketType.Dgram, ProtocolType.Udp);
                        IPEndPoint ep = new IPEndPoint(IPAddress.Parse("192.168.1.14"), 50003);
                        time.Start();
                        while (true)
                        {
                            byte[] datas;
                            string p = string.Empty;
                            Dispatcher.Invoke(() => { p = txt_textbox.Text; });
        
                            datas = Encoding.UTF8.GetBytes(p);
                            s.SendTo(datas, ep);
                            counter++;
                        }
                    });
                }
        
                private void Time_Elapsed(object sender, ElapsedEventArgs e)
                {
                    MessageBox.Show(counter.ToString());
                }
            }
        
        JonBJ 1 Reply Last reply
        0
        • LudoFRL LudoFR

          First, thanks for your anwser.

          Well in fact the goal is to get data read from joysticks and I/O cards, this "while" is infinite until the program is closed.

          Between 4 and 8 hours (work time).

          I have add a counter in my C# udp sender function and I send 131225 time in 10 seconds. Its a lot I know but in this data, some value like "Emergency button" need to be get really fast. Do you think this is the problem ?

          I don't know if that can help but here my C# sender function : (Function just created for my Qt training)

              public partial class MainWindow : Window
              {
                  int counter = 0;
                  public MainWindow()
                  {
                      InitializeComponent();
          
                      Timer time = new Timer(10000);
                      time.Elapsed += Time_Elapsed;
          
                      Task.Run(() =>
                      {
                          Socket s = new Socket(AddressFamily.InterNetwork, SocketType.Dgram, ProtocolType.Udp);
                          IPEndPoint ep = new IPEndPoint(IPAddress.Parse("192.168.1.14"), 50003);
                          time.Start();
                          while (true)
                          {
                              byte[] datas;
                              string p = string.Empty;
                              Dispatcher.Invoke(() => { p = txt_textbox.Text; });
          
                              datas = Encoding.UTF8.GetBytes(p);
                              s.SendTo(datas, ep);
                              counter++;
                          }
                      });
                  }
          
                  private void Time_Elapsed(object sender, ElapsedEventArgs e)
                  {
                      MessageBox.Show(counter.ToString());
                  }
              }
          
          JonBJ Offline
          JonBJ Offline
          JonB
          wrote on last edited by
          #7

          @LudoFR
          You do not seem to have done anything about determining where your QML UI client is unresponsive.

          I send 131225 time in 10 seconds

          If you mean your client may be executing ReceiveUdpPackage(), or receiving datagrams inside it, 13 thousand times per second I imagine that might be problem.

          LudoFRL 1 Reply Last reply
          0
          • JonBJ JonB

            @LudoFR
            You do not seem to have done anything about determining where your QML UI client is unresponsive.

            I send 131225 time in 10 seconds

            If you mean your client may be executing ReceiveUdpPackage(), or receiving datagrams inside it, 13 thousand times per second I imagine that might be problem.

            LudoFRL Offline
            LudoFRL Offline
            LudoFR
            wrote on last edited by
            #8

            @JonB said in QUdpSocket receive Datagram into QtConcurrent:

            If you mean your client may be executing ReceiveUdpPackage(), or receiving datagrams inside it, 13 thousand times per second I imagine that might be problem.

            In C# is work really good, so do you think this amount of data is too much?

            But is for Qt not for c++ who is apparently more efficient than C#? My IDE is also in pain, its hard to put a breakpoint because my IDE is laggy and almost freezed too !!

            1 Reply Last reply
            0
            • Christian EhrlicherC Offline
              Christian EhrlicherC Offline
              Christian Ehrlicher
              Lifetime Qt Champion
              wrote on last edited by
              #9

              Then use C# ...

              Qt Online Installer direct download: https://download.qt.io/official_releases/online_installers/
              Visit the Qt Academy at https://academy.qt.io/catalog

              LudoFRL 1 Reply Last reply
              1
              • Christian EhrlicherC Christian Ehrlicher

                Then use C# ...

                LudoFRL Offline
                LudoFRL Offline
                LudoFR
                wrote on last edited by
                #10

                @Christian-Ehrlicher Wow, thank for this answer, really appreciate champ.

                @JonB Seems to be really better if I do not run in Debug, not a surprise.. the console take like 3/4 seconds for beeing updated, but after some test with breakpoint, the console look to take long time to print but the value receive look good apprently..

                1 Reply Last reply
                0
                • Christian EhrlicherC Offline
                  Christian EhrlicherC Offline
                  Christian Ehrlicher
                  Lifetime Qt Champion
                  wrote on last edited by
                  #11

                  You just blame about something, @JonB tells you that you should try to reduce the data rate to see if it helps (which I doubt - there is another problem somewhere in your app) and you start complaining about your IDE just to blame Qt again. This is nothing more than trolling for me.

                  The normal way here is to reduce the program until the error/problem goes away and/or others can reproduce it. Daily programmers work.

                  Qt Online Installer direct download: https://download.qt.io/official_releases/online_installers/
                  Visit the Qt Academy at https://academy.qt.io/catalog

                  1 Reply Last reply
                  2
                  • LudoFRL Offline
                    LudoFRL Offline
                    LudoFR
                    wrote on last edited by LudoFR
                    #12

                    Listen champ,

                    In my country, and almost all country around Earth I think, question mark,

                    @LudoFR said in QUdpSocket receive Datagram into QtConcurrent:

                    But is for Qt not for c++ who is apparently more efficient than C#?

                    Is for asking a question, not for blaming or something.

                    Yea I have reduce the amount of data with a 50ms delay... but whatever you don't care by having deduction without asking if the result is better..

                    Complaining? No, just tryin to understand, I'm sorry if I hurt you by asking question performance about your IDE (baby, life or anything it is for you), but for me its a tool... yea a tool.. with pros and cons I'm sure, but if you told me Qt are only pros, so do not loose your time to answer me because you can't be objective to me.

                    I want make you happy, in C# and visual studio (yea Microsoft, pretty sure you like according to your avatar) well console is slow in Debug mode when you use it roughly..

                    Qt has to stay free or it will die.
                    I'm sure your help Qt with your kind of answers champ.

                    Here, now you have your troll.

                    Christian EhrlicherC JonBJ 2 Replies Last reply
                    0
                    • LudoFRL LudoFR

                      Listen champ,

                      In my country, and almost all country around Earth I think, question mark,

                      @LudoFR said in QUdpSocket receive Datagram into QtConcurrent:

                      But is for Qt not for c++ who is apparently more efficient than C#?

                      Is for asking a question, not for blaming or something.

                      Yea I have reduce the amount of data with a 50ms delay... but whatever you don't care by having deduction without asking if the result is better..

                      Complaining? No, just tryin to understand, I'm sorry if I hurt you by asking question performance about your IDE (baby, life or anything it is for you), but for me its a tool... yea a tool.. with pros and cons I'm sure, but if you told me Qt are only pros, so do not loose your time to answer me because you can't be objective to me.

                      I want make you happy, in C# and visual studio (yea Microsoft, pretty sure you like according to your avatar) well console is slow in Debug mode when you use it roughly..

                      Qt has to stay free or it will die.
                      I'm sure your help Qt with your kind of answers champ.

                      Here, now you have your troll.

                      Christian EhrlicherC Offline
                      Christian EhrlicherC Offline
                      Christian Ehrlicher
                      Lifetime Qt Champion
                      wrote on last edited by Christian Ehrlicher
                      #13

                      @LudoFR said in QUdpSocket receive Datagram into QtConcurrent:

                      your IDE

                      It's not my IDE - I did not even contributed a single line to QtCreator. I'm using mostly MSVC for debugging because gdb and cdb (not QtCreator) are painful slow. Blaming an IDE for this is nonsense. And btw: Qt != QtCreator.

                      Qt Online Installer direct download: https://download.qt.io/official_releases/online_installers/
                      Visit the Qt Academy at https://academy.qt.io/catalog

                      1 Reply Last reply
                      0
                      • LudoFRL LudoFR

                        Listen champ,

                        In my country, and almost all country around Earth I think, question mark,

                        @LudoFR said in QUdpSocket receive Datagram into QtConcurrent:

                        But is for Qt not for c++ who is apparently more efficient than C#?

                        Is for asking a question, not for blaming or something.

                        Yea I have reduce the amount of data with a 50ms delay... but whatever you don't care by having deduction without asking if the result is better..

                        Complaining? No, just tryin to understand, I'm sorry if I hurt you by asking question performance about your IDE (baby, life or anything it is for you), but for me its a tool... yea a tool.. with pros and cons I'm sure, but if you told me Qt are only pros, so do not loose your time to answer me because you can't be objective to me.

                        I want make you happy, in C# and visual studio (yea Microsoft, pretty sure you like according to your avatar) well console is slow in Debug mode when you use it roughly..

                        Qt has to stay free or it will die.
                        I'm sure your help Qt with your kind of answers champ.

                        Here, now you have your troll.

                        JonBJ Offline
                        JonBJ Offline
                        JonB
                        wrote on last edited by JonB
                        #14

                        @LudoFR
                        I said earlier I don't know where your window is freezing. Let's find out whether ReceiveUdpPackage() is being run thousands of times per second? Comment out your qDebug() for each datagram, we don't want thousands per seconds debug output. Put in a member variable to count the total number of times and debug it out occasionally. Are we indeed talking about thousands per second?

                        LudoFRL 1 Reply Last reply
                        1
                        • Christian EhrlicherC Offline
                          Christian EhrlicherC Offline
                          Christian Ehrlicher
                          Lifetime Qt Champion
                          wrote on last edited by
                          #15

                          @JonB said in QUdpSocket receive Datagram into QtConcurrent:

                          Comment out your qDebug() for each datagram

                          correct - printing so much data to the windows console will not work, no matter if it's C++, C#, Java or whatever. The windows console is painful slow.

                          Qt Online Installer direct download: https://download.qt.io/official_releases/online_installers/
                          Visit the Qt Academy at https://academy.qt.io/catalog

                          1 Reply Last reply
                          0
                          • JonBJ JonB

                            @LudoFR
                            I said earlier I don't know where your window is freezing. Let's find out whether ReceiveUdpPackage() is being run thousands of times per second? Comment out your qDebug() for each datagram, we don't want thousands per seconds debug output. Put in a member variable to count the total number of times and debug it out occasionally. Are we indeed talking about thousands per second?

                            LudoFRL Offline
                            LudoFRL Offline
                            LudoFR
                            wrote on last edited by
                            #16

                            @JonB Thanks again for your help, well its seems your right, without qDebug(), my GUI is not freezed, I have try with a delay of 50 and 100ms.

                            I will be careful next time with how I use the qDebug(), good to know.

                            Didn't think about that because never has any problem with my console output who usually are really fast. (Used only for debuging of course).

                            Now I will try Databing in my GUI and IO cards communication for check if this 50/100ms delay do not affect smoothest for our drivers.

                            Thanks a lot @JonB for your help, your professionalism and all this informations.

                            JonBJ 1 Reply Last reply
                            0
                            • LudoFRL LudoFR

                              @JonB Thanks again for your help, well its seems your right, without qDebug(), my GUI is not freezed, I have try with a delay of 50 and 100ms.

                              I will be careful next time with how I use the qDebug(), good to know.

                              Didn't think about that because never has any problem with my console output who usually are really fast. (Used only for debuging of course).

                              Now I will try Databing in my GUI and IO cards communication for check if this 50/100ms delay do not affect smoothest for our drivers.

                              Thanks a lot @JonB for your help, your professionalism and all this informations.

                              JonBJ Offline
                              JonBJ Offline
                              JonB
                              wrote on last edited by
                              #17

                              @LudoFR
                              I am interested to learn: if you have put it some counter for each datagram received instead, are you indeed seeing 13,000-odd per second?

                              LudoFRL 1 Reply Last reply
                              0
                              • JonBJ JonB

                                @LudoFR
                                I am interested to learn: if you have put it some counter for each datagram received instead, are you indeed seeing 13,000-odd per second?

                                LudoFRL Offline
                                LudoFRL Offline
                                LudoFR
                                wrote on last edited by LudoFR
                                #18

                                @JonB

                                For one second exactly (No delay) :

                                QT receive counter : 4602.
                                VS sender counter : 4565

                                For 10 seconds exactly (No delay):

                                QT : 129278
                                VS: 129234

                                JonBJ 2 Replies Last reply
                                1
                                • LudoFRL LudoFR

                                  @JonB

                                  For one second exactly (No delay) :

                                  QT receive counter : 4602.
                                  VS sender counter : 4565

                                  For 10 seconds exactly (No delay):

                                  QT : 129278
                                  VS: 129234

                                  JonBJ Offline
                                  JonBJ Offline
                                  JonB
                                  wrote on last edited by
                                  #19

                                  @LudoFR
                                  You don't really need a timer. This will do, presumably:

                                          udpSock->readDatagram(datagram.data(),datagram.size(),&sender,&port);
                                          memberCounter++;
                                          if (memberCounter % 10000 == 0)
                                              qDebug() <<"memberCounter:" << memberCounter;
                                  
                                  1 Reply Last reply
                                  0
                                  • LudoFRL LudoFR

                                    @JonB

                                    For one second exactly (No delay) :

                                    QT receive counter : 4602.
                                    VS sender counter : 4565

                                    For 10 seconds exactly (No delay):

                                    QT : 129278
                                    VS: 129234

                                    JonBJ Offline
                                    JonBJ Offline
                                    JonB
                                    wrote on last edited by JonB
                                    #20

                                    @LudoFR
                                    Well, firstly looks like VS & Qt are similar, which is good news. Secondly surprised it seems receiver is receiving more than sent? I don't think each side agrees on exactly what 1 second is :D

                                    LudoFRL 1 Reply Last reply
                                    0
                                    • JonBJ JonB

                                      @LudoFR
                                      Well, firstly looks like VS & Qt are similar, which is good news. Secondly surprised it seems receiver is receiving more than sent? I don't think each side agrees on exactly what 1 second is :D

                                      LudoFRL Offline
                                      LudoFRL Offline
                                      LudoFR
                                      wrote on last edited by LudoFR
                                      #21

                                      @JonB said in QUdpSocket receive Datagram into QtConcurrent:

                                      Secondly surprised it seems receiver is receiving more than sent?

                                      @JonB Thanks god I'm not the only one...

                                      @JonB said in QUdpSocket receive Datagram into QtConcurrent:

                                      I don't think each side agrees on exactly what 1 second is :D

                                      Science....is not an exact science... did performance computer impact that kind of information? Sender is an Asus Rog Strix3 with a config lower than my PC

                                      JonBJ 1 Reply Last reply
                                      0
                                      • LudoFRL LudoFR

                                        Hello everyone,

                                        Still learning on Qt, and I try to run a QUdpSocket receiving UDP data into a QtConcurrent thread, for avoiding GUI freezing.

                                        Here my main.cpp

                                        If i call "testComThread()" my function work and I receive my data, but if i call "QtConcurrent::run(testComThread);" I dont see any data into my console and my breakpoint in my "while" is never reached.

                                        Did I need to call a kind of dispatcher or something maybe? This is my first use of QtConcurrent. Thanks in advance.

                                        #include <QGuiApplication>
                                        #include <QQmlApplicationEngine>
                                        #include <Manage/variablesglobales.h>
                                        #include <Manage/communications.h>
                                        #include <QtConcurrent>
                                        
                                        void testComThread();
                                        
                                        int main(int argc, char *argv[])
                                        {
                                        #if QT_VERSION < QT_VERSION_CHECK(6, 0, 0)
                                            QCoreApplication::setAttribute(Qt::AA_EnableHighDpiScaling);
                                        #endif
                                        
                                            QGuiApplication app(argc, argv);
                                        
                                            QQmlApplicationEngine engine;
                                            const QUrl url(QStringLiteral("qrc:/main.qml"));
                                            QObject::connect(&engine, &QQmlApplicationEngine::objectCreated,
                                                             &app, [url](QObject *obj, const QUrl &objUrl) {
                                                if (!obj && url == objUrl)
                                                    QCoreApplication::exit(-1);
                                            }, Qt::QueuedConnection);
                                            engine.load(url);
                                        
                                        
                                            QFuture<void> test1 = QtConcurrent::run(testComThread);
                                            //testComThread();
                                        
                                        
                                            return app.exec();
                                        }
                                        
                                        void testComThread()
                                        {
                                            Communications* com = new Communications();
                                            com->InitialiseConnection();
                                        }
                                        

                                        my communication.cpp

                                        #include "communications.h"
                                        
                                        Communications::Communications(QObject *parent) : QObject(parent)
                                        {
                                        
                                        }
                                        
                                        void Communications::InitialiseConnection()
                                        {
                                            udpSock = new QUdpSocket(this);
                                            udpSock->bind(QHostAddress::Any,50003);
                                        
                                           connect(udpSock,&QUdpSocket::readyRead,this,&Communications::ReceiveUdpPackage);
                                        }
                                        
                                        void Communications::ReceiveUdpPackage()
                                        {
                                            QHostAddress sender;
                                            quint16  port;
                                        
                                            while (udpSock->hasPendingDatagrams())
                                            {
                                                QByteArray datagram;
                                                datagram.resize(udpSock->pendingDatagramSize());
                                                udpSock->readDatagram(datagram.data(),datagram.size(),&sender,&port);
                                                qDebug() <<"Message From :" << datagram.data();
                                            }
                                        }
                                        

                                        Thank you in advance.

                                        jeremy_kJ Offline
                                        jeremy_kJ Offline
                                        jeremy_k
                                        wrote on last edited by jeremy_k
                                        #22

                                        @LudoFR said in QUdpSocket receive Datagram into QtConcurrent:

                                        Hello everyone,

                                        Still learning on Qt, and I try to run a QUdpSocket receiving UDP data into a QtConcurrent thread, for avoiding GUI freezing.

                                        Here my main.cpp

                                        If i call "testComThread()" my function work and I receive my data, but if i call "QtConcurrent::run(testComThread);" I dont see any data into my console and my breakpoint in my "while" is never reached.

                                        Did I need to call a kind of dispatcher or something maybe? This is my first use of QtConcurrent. Thanks in advance.

                                        Truncated code:

                                        int main(int argc, char *argv[])
                                        {
                                            QFuture<void> test1 = QtConcurrent::run(testComThread);
                                            return app.exec();
                                        }
                                        
                                        void testComThread()
                                        {
                                            Communications* com = new Communications();
                                            com->InitialiseConnection();
                                        
                                            udpSock = new QUdpSocket(com);
                                            udpSock->bind(QHostAddress::Any,50003);
                                        
                                            connect(udpSock,&QUdpSocket::readyRead,this,&Communications::ReceiveUdpPackage);
                                        }
                                        

                                        This won't work. QtConcurrent::run() runs a function in a thread that doesn't have an event loop, and may cease to exist when the invoked function returns.

                                        Regarding QML: The language has fairly strong rules regarding capitalization. Types should begin with an upper case letter. Properties and functions should begin with a lower case letter. Following the convention in C++ will make integration easier.

                                        Asking a question about code? http://eel.is/iso-c++/testcase/

                                        LudoFRL 1 Reply Last reply
                                        0
                                        • LudoFRL LudoFR

                                          @JonB said in QUdpSocket receive Datagram into QtConcurrent:

                                          Secondly surprised it seems receiver is receiving more than sent?

                                          @JonB Thanks god I'm not the only one...

                                          @JonB said in QUdpSocket receive Datagram into QtConcurrent:

                                          I don't think each side agrees on exactly what 1 second is :D

                                          Science....is not an exact science... did performance computer impact that kind of information? Sender is an Asus Rog Strix3 with a config lower than my PC

                                          JonBJ Offline
                                          JonBJ Offline
                                          JonB
                                          wrote on last edited by
                                          #23

                                          @LudoFR
                                          Don't worry about exact timings. Your 10 second timing indicates there are around 13,000 datagrams per second, which is just what you were originally expecting. Just make sure whatever processing you do on those datagrams is fast!

                                          1 Reply Last reply
                                          0

                                          • Login

                                          • Login or register to search.
                                          • First post
                                            Last post
                                          0
                                          • Categories
                                          • Recent
                                          • Tags
                                          • Popular
                                          • Users
                                          • Groups
                                          • Search
                                          • Get Qt Extensions
                                          • Unsolved