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. QSocketNotifier: Socket notifiers cannot be enabled or disabled from another thread
Forum Updated to NodeBB v4.3 + New Features

QSocketNotifier: Socket notifiers cannot be enabled or disabled from another thread

Scheduled Pinned Locked Moved Unsolved General and Desktop
33 Posts 5 Posters 11.0k Views 2 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.
  • R Offline
    R Offline
    rktech
    wrote on last edited by
    #9

    @Christian-Ehrlicher said in QSocketNotifier: Socket notifiers cannot be enabled or disabled from another thread:

    @rktech said in QSocketNotifier: Socket notifiers cannot be enabled or disabled from another thread:

    but I still don't know how to fix it.

    You have to override incomingConnection() as shown there.

    I have tried, but I don't know how to implement that into my code.

    1 Reply Last reply
    0
    • SGaistS Offline
      SGaistS Offline
      SGaist
      Lifetime Qt Champion
      wrote on last edited by
      #10

      What exactly have you tried ?

      Interested in AI ? www.idiap.ch
      Please read the Qt Code of Conduct - https://forum.qt.io/topic/113070/qt-code-of-conduct

      R 1 Reply Last reply
      0
      • SGaistS SGaist

        What exactly have you tried ?

        R Offline
        R Offline
        rktech
        wrote on last edited by
        #11

        @SGaist To add override to my code, but I don't know where should I place it...

        1 Reply Last reply
        0
        • R Offline
          R Offline
          rktech
          wrote on last edited by
          #12

          @SGaist How can I send the connection from incomingConnection() to Pool?

          1 Reply Last reply
          0
          • R Offline
            R Offline
            rktech
            wrote on last edited by
            #13

            @SGaist I have successfully overrided the incomingconnection(), but I don't know, how to pass it to the Pool.

            1 Reply Last reply
            0
            • SGaistS Offline
              SGaistS Offline
              SGaist
              Lifetime Qt Champion
              wrote on last edited by
              #14

              You'll have to redesign your pool a bit to ensure that your sockets are created in the context of the run method of your QThread subclass.

              Interested in AI ? www.idiap.ch
              Please read the Qt Code of Conduct - https://forum.qt.io/topic/113070/qt-code-of-conduct

              R 1 Reply Last reply
              0
              • SGaistS SGaist

                You'll have to redesign your pool a bit to ensure that your sockets are created in the context of the run method of your QThread subclass.

                R Offline
                R Offline
                rktech
                wrote on last edited by
                #15

                @SGaist I know, but how?

                1 Reply Last reply
                0
                • SGaistS Offline
                  SGaistS Offline
                  SGaist
                  Lifetime Qt Champion
                  wrote on last edited by
                  #16

                  You have to transfer the descriptor to your pool and there in your run method create new sockets when descriptors are added.

                  Interested in AI ? www.idiap.ch
                  Please read the Qt Code of Conduct - https://forum.qt.io/topic/113070/qt-code-of-conduct

                  R 2 Replies Last reply
                  0
                  • SGaistS SGaist

                    You have to transfer the descriptor to your pool and there in your run method create new sockets when descriptors are added.

                    R Offline
                    R Offline
                    rktech
                    wrote on last edited by
                    #17

                    @SGaist Should I add this part of code to my Pool::add() method? (Of course with editing it)

                    QTcpSocket tcpSocket;
                    
                        if (!tcpSocket.setSocketDescriptor(socketDescriptor)) {
                            emit error(tcpSocket.error());
                            return;
                        }
                    
                    1 Reply Last reply
                    0
                    • SGaistS SGaist

                      You have to transfer the descriptor to your pool and there in your run method create new sockets when descriptors are added.

                      R Offline
                      R Offline
                      rktech
                      wrote on last edited by
                      #18

                      @SGaist I have (probably) successfully rewritten the Pool add method, but I have another problem. When I add this:

                      protected:
                          void incomingConnection(qintptr socketDescriptor) override;
                      

                      to myserver.h I get this error:

                      ...\myserver.h:35: Chyba: only virtual member functions can be marked 'override'
                      

                      (Chyba is Error in my local)
                      What I am doing wrong?

                      mrjjM 1 Reply Last reply
                      0
                      • R rktech

                        @SGaist I have (probably) successfully rewritten the Pool add method, but I have another problem. When I add this:

                        protected:
                            void incomingConnection(qintptr socketDescriptor) override;
                        

                        to myserver.h I get this error:

                        ...\myserver.h:35: Chyba: only virtual member functions can be marked 'override'
                        

                        (Chyba is Error in my local)
                        What I am doing wrong?

                        mrjjM Offline
                        mrjjM Offline
                        mrjj
                        Lifetime Qt Champion
                        wrote on last edited by mrjj
                        #19

                        Hi
                        well it is virtual https://doc.qt.io/qt-5/qtcpserver.html#incomingConnection
                        so does Pool inherit QTcpServer ?
                        The error you get says "Hey, i dont see that funtion in base class, so you cant use override"

                        R 2 Replies Last reply
                        0
                        • mrjjM mrjj

                          Hi
                          well it is virtual https://doc.qt.io/qt-5/qtcpserver.html#incomingConnection
                          so does Pool inherit QTcpServer ?
                          The error you get says "Hey, i dont see that funtion in base class, so you cant use override"

                          R Offline
                          R Offline
                          rktech
                          wrote on last edited by
                          #20

                          @mrjj No, the server is build under the myserver class

                          R 1 Reply Last reply
                          0
                          • R rktech

                            @mrjj No, the server is build under the myserver class

                            R Offline
                            R Offline
                            rktech
                            wrote on last edited by
                            #21
                            This post is deleted!
                            1 Reply Last reply
                            0
                            • mrjjM mrjj

                              Hi
                              well it is virtual https://doc.qt.io/qt-5/qtcpserver.html#incomingConnection
                              so does Pool inherit QTcpServer ?
                              The error you get says "Hey, i dont see that funtion in base class, so you cant use override"

                              R Offline
                              R Offline
                              rktech
                              wrote on last edited by
                              #22

                              @mrjj the header of server look like:

                              #ifndef MYSERVER_H
                              #define MYSERVER_H
                              
                              #include <QObject>
                              #include <QDebug>
                              #include <QTcpServer>
                              #include <QTcpSocket>
                              #include <QString>
                              #include <QFile>
                              #include <QStandardPaths>
                              #include <QThread>
                              #include <QElapsedTimer>
                              #include <pool.h>
                              #include <QDateTime>
                              class MyServer : public QObject
                              {
                                  Q_OBJECT
                              public:
                                  explicit MyServer(QObject *parent = nullptr);
                              
                              signals:
                              
                              public slots:
                                  void newConnection();
                                  void onReadyRead();
                              
                              private:
                                  QTcpServer *server;
                                  QList<QTcpSocket*>  _sockets;
                                  QString a;
                                  QString com;
                                  QTcpSocket *socket;
                                  QList<QTcpSocket*> sl;
                              /*protected:
                                  void incomingConnection(qintptr socketDescriptor) override;*/
                              };
                              
                              #endif // MYSERVER_H
                              
                              
                              1 Reply Last reply
                              0
                              • Christian EhrlicherC Offline
                                Christian EhrlicherC Offline
                                Christian Ehrlicher
                                Lifetime Qt Champion
                                wrote on last edited by
                                #23

                                Sorry but please learn C++ first. If you want to override a function from a class you should inherit from this class. So inherit from QTcpServer, override the function and do whatever you want to. This is basic c++ stuff...

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

                                R 2 Replies Last reply
                                1
                                • Christian EhrlicherC Christian Ehrlicher

                                  Sorry but please learn C++ first. If you want to override a function from a class you should inherit from this class. So inherit from QTcpServer, override the function and do whatever you want to. This is basic c++ stuff...

                                  R Offline
                                  R Offline
                                  rktech
                                  wrote on last edited by
                                  #24

                                  @Christian-Ehrlicher That's the thing, that I didn't notice. Thanks

                                  1 Reply Last reply
                                  0
                                  • Christian EhrlicherC Christian Ehrlicher

                                    Sorry but please learn C++ first. If you want to override a function from a class you should inherit from this class. So inherit from QTcpServer, override the function and do whatever you want to. This is basic c++ stuff...

                                    R Offline
                                    R Offline
                                    rktech
                                    wrote on last edited by
                                    #25

                                    @Christian-Ehrlicher But I don't know, how to edit it.

                                    1 Reply Last reply
                                    0
                                    • R Offline
                                      R Offline
                                      rktech
                                      wrote on last edited by
                                      #26

                                      I have rewritten half of my project to solve the problem:
                                      myserver.h

                                      #ifndef MYSERVER_H
                                      #define MYSERVER_H
                                      #include <QStringList>
                                      #include <QTcpServer>
                                      #include <QDateTime>
                                      class MyServer : public QTcpServer
                                      {
                                          Q_OBJECT
                                      
                                      public:
                                          MyServer(QObject *parent = nullptr);
                                      
                                      protected:
                                          void incomingConnection(qintptr socketDescriptor) override;
                                      
                                      private:
                                          QStringList fortunes;
                                      };
                                      
                                      #endif // MYSERVER_H
                                      

                                      myserver.cpp

                                      #include "myserver.h"
                                      #include "pool.h"
                                      Pool p;
                                      
                                      MyServer::MyServer(QObject *parent)
                                          : QTcpServer(parent)
                                      {
                                          p.start();
                                      }
                                      
                                      void MyServer::incomingConnection(qintptr socketDescriptor)
                                      {
                                      QDateTime qdt;
                                      p.add(socketDescriptor,qdt.time());
                                      }
                                      

                                      pool.h

                                      #ifndef POOL_H
                                      #define POOL_H
                                      #include<QObject>
                                      #include<QThread>
                                      #include<QTcpSocket>
                                      #include<QDateTime>
                                      #include<QElapsedTimer>
                                      class Pool : public QThread
                                      {
                                          Q_OBJECT
                                      
                                      protected:
                                          void run();
                                      private:
                                          struct conn{
                                              QTcpSocket *s;
                                              QTime qdt;
                                          };
                                          QList<conn> x;
                                      public:
                                          void add(int socketDescriptor, QTime qdt);
                                      };
                                      #endif // POOL_H
                                      

                                      pool.cpp

                                      #include "pool.h"
                                      #include <QElapsedTimer>
                                      void Pool::run()
                                      {
                                      QElapsedTimer qet;
                                      qet.start();
                                      while (true) {
                                          if(qet.elapsed()>=5000){
                                              foreach (conn y, x) {
                                                  if(y.s==nullptr){
                                                      qDebug()<<"empty";
                                                      continue;
                                                  }
                                                  y.s->write("test");
                                                  y.s->flush();
                                              }
                                              qet.restart();
                                          }
                                      }
                                      }
                                      void Pool::add(int socketDescriptor, QTime qdt){
                                      QTcpSocket* s = new QTcpSocket;
                                      s->setSocketDescriptor(socketDescriptor);
                                      s->write("1\n");
                                      conn c;
                                      c.s=s;
                                      c.qdt=qdt;
                                      x.append(c);
                                      }
                                      

                                      But I have still the same error:

                                      QSocketNotifier: Socket notifiers cannot be enabled or disabled from another thread
                                      

                                      What's wrong?

                                      1 Reply Last reply
                                      0
                                      • SGaistS Offline
                                        SGaistS Offline
                                        SGaist
                                        Lifetime Qt Champion
                                        wrote on last edited by
                                        #27

                                        Because your add method is called in the thread of the tcp server.

                                        As I already told you, the socket creation must happen in the run function.

                                        Interested in AI ? www.idiap.ch
                                        Please read the Qt Code of Conduct - https://forum.qt.io/topic/113070/qt-code-of-conduct

                                        R 1 Reply Last reply
                                        1
                                        • SGaistS SGaist

                                          Because your add method is called in the thread of the tcp server.

                                          As I already told you, the socket creation must happen in the run function.

                                          R Offline
                                          R Offline
                                          rktech
                                          wrote on last edited by
                                          #28

                                          @SGaist I have solved it. I am creating a list of descriptors in add() method and then rewriting it like this:
                                          pool.cpp

                                          void Pool::run()
                                          {
                                          QElapsedTimer qet;
                                          qet.start();
                                          while (true) {
                                              if(!d.empty()){
                                                  qDebug()<<"rewriting";
                                                  for (int i = 0; i<d.size();i++) {
                                                      desc des = d[i];
                                                      conn con;
                                                      QTcpSocket* soc = new QTcpSocket;
                                                      soc->setSocketDescriptor(des.descriptor);
                                                      con.s=soc;
                                                      con.qdt=des.qt;
                                                      d.removeAt(i);
                                                      x.append(con);
                                                  }
                                                  qDebug()<<"done";
                                              }
                                              if(qet.elapsed()>=5000){
                                                  foreach (conn y, x) {
                                                      if(!y.s->isOpen()){
                                                          qDebug()<<"empty";
                                                          continue;
                                                      }
                                                      y.s->write("test");
                                                      qDebug()<<"l";
                                                      y.s->flush();
                                                  }
                                                  qet.restart();
                                              }
                                          }
                                          }
                                          void Pool::add(int socketDescriptor, QTime qdt){
                                          desc de;
                                          de.descriptor=socketDescriptor;
                                          de.qt=qdt;
                                          d.append(de);
                                          }
                                          

                                          definitions of structs and lists in pool.h:

                                            struct conn{
                                                  QTcpSocket *s;
                                                  QTime qdt;
                                              };
                                              struct desc{
                                                  qintptr descriptor;
                                                  QTime qt;
                                              };
                                              QList<conn> x;
                                              QList<desc> d;
                                          
                                          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