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. QtConcurrent::run Access violation reading location

QtConcurrent::run Access violation reading location

Scheduled Pinned Locked Moved General and Desktop
36 Posts 2 Posters 15.4k 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.
  • B Offline
    B Offline
    bagipro
    wrote on last edited by
    #3

    Yes, i can read ;)
    So 1h passed in debug mode, but the error doesn't appear.

    1 Reply Last reply
    0
    • B Offline
      B Offline
      bagipro
      wrote on last edited by
      #4

      !http://clip2net.com/clip/m0/1373023940-clip-17kb.png(Text)!

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

        Out of curiosity, why don't you use QMutex to protect your data access ?

        Also, I am surprised of this:

        @out = static_cast<QString>( reply->readAll() )@

        Why not use the QString::QString(const QByteArray) constructor ?

        static_cast doesn't transform the QByteArray into a QString

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

        1 Reply Last reply
        0
        • B Offline
          B Offline
          bagipro
          wrote on last edited by
          #6

          @void MainWindow::thread()
          {
          while(lastLink < countLinks)
          {
          mutex1.lock();
          int i = lastLink;
          incLastLink();
          mutex1.unlock();

              QString req = doRequest(links[i]);
              if(req.contains("something"))
              {
                  mutex2.lock();
                  out <&lt; links[i] &lt;&lt; endl;
                  incGoodLinks();
                  mutex2.unlock();
              }
          }
          

          }
          @

          @QString MainWindow::doRequest(QString url)
          {
          QString out;
          QTimer timer;
          QNetworkAccessManager* manager = new QNetworkAccessManager;
          QEventLoop loop;
          QObject::connect(&timer,SIGNAL(timeout()),&loop,SLOT(quit()));
          QObject::connect(manager,SIGNAL(finished(QNetworkReply*)),&loop,SLOT(quit()));
          QNetworkReply* reply = manager->get(QNetworkRequest(QUrl(url)));
          timer.start(TIMEOUT);
          loop.exec();
          if(!timer.isActive())
          {
          reply->abort();
          }
          else
          {
          if(reply->error() == QNetworkReply::NoError)
          {
          out = QString::QString( reply->readAll() );
          }
          reply->close();
          }
          delete manager;
          return out;
          }@

          !http://clip2net.com/clip/m0/1373130879-clip-19kb.png(1)!

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

            Is it the function you use to increment your lastLink variable ? (You might use a QAtomicInt for that)

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

            1 Reply Last reply
            0
            • B Offline
              B Offline
              bagipro
              wrote on last edited by
              #8

              Oh no, it's some system function

              Its my functions
              @void MainWindow::incLastLink()
              {
              lastLink++;
              ui->label_7->setNum(lastLink);
              }

              void MainWindow::incGoodLinks()
              {
              goodLinks++;
              ui->label_5->setNum(goodLinks);
              }@

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

                Since it's pointer related, try to replace delete manager with
                @manager->deleteLater();@

                And maybe check that reply is a valid pointer (could be something related to it since it's the only other pointer visible in your code).

                On a related note, I don't know for sure but I think It's your job to delete reply.

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

                1 Reply Last reply
                0
                • B Offline
                  B Offline
                  bagipro
                  wrote on last edited by
                  #10

                  How i can check reply pointer on valid? I didn't find some method like isValid. Or check like
                  @reply != NULL@

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

                    Since it's a pointer:

                    @if (reply)@

                    Unless something is wrong, reply should either be NULL or pointing to a valid QNetworkReply (AFAIK, It shouldn't be NULL, but it's better to check to ensure that's not that that is causing you the access violation)

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

                    1 Reply Last reply
                    0
                    • B Offline
                      B Offline
                      bagipro
                      wrote on last edited by
                      #12

                      I edit the code
                      @QString MainWindow::doRequest(QString url)
                      {
                      QString out;
                      QTimer timer;
                      QNetworkAccessManager* manager = new QNetworkAccessManager;
                      QEventLoop loop;
                      QObject::connect(&timer,SIGNAL(timeout()),&loop,SLOT(quit()));
                      QObject::connect(manager,SIGNAL(finished(QNetworkReply*)),&loop,SLOT(quit()));
                      QNetworkReply* reply = manager->get(QNetworkRequest(QUrl(url)));
                      timer.start(TIMEOUT);
                      loop.exec();
                      if(!timer.isActive())
                      {
                      reply->abort();
                      }
                      else
                      {
                      if(!reply) ::Beep(1000,1000);
                      if(reply->error() == QNetworkReply::NoError)
                      {
                      out = QString::QString( reply->readAll() );
                      }
                      reply->close();
                      }
                      reply->deleteLater();
                      manager->deleteLater();
                      return out;
                      }@

                      And i got error
                      !http://clip2net.com/clip/m0/1373183493-clip-9kb.png(1)!

                      So, i never heard beep

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

                        I would check reply sooner, you might be calling abort on an invalid reply (though it would be strange)

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

                        1 Reply Last reply
                        0
                        • B Offline
                          B Offline
                          bagipro
                          wrote on last edited by
                          #14

                          I edit
                          @loop.exec();
                          if(!reply)
                          {
                          ::Beep(10000,10000);
                          exit(123456);
                          }@
                          But i got same violation error
                          Maybe I need to create exeptions?

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

                            Are you sure everything you are accessing is valid (like links[i]) ?

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

                            1 Reply Last reply
                            0
                            • B Offline
                              B Offline
                              bagipro
                              wrote on last edited by
                              #16

                              I think yes, i get errors in the middle of work process

                              1 Reply Last reply
                              0
                              • B Offline
                                B Offline
                                bagipro
                                wrote on last edited by
                                #17

                                I runned it from cdb debugger. I see many errors, its showed at startup
                                @:0: предупреждение: Exception at 0x7c812aeb, code: 0x6ba: RPC server unavailable, flags=0x1 (execution cannot be continued) (first chance)

                                :0: предупреждение: Exception at 0x7c812aeb, code: 0x6ba: RPC server unavailable, flags=0x1 (execution cannot be continued) (first chance)

                                :0: предупреждение: Exception at 0x7c812aeb, code: 0x406d1388: Startup complete, flags=0x0 (first chance)

                                :0: предупреждение: Exception at 0x7c812aeb, code: 0x6ba: RPC server unavailable, flags=0x1 (execution cannot be continued) (first chance)

                                :0: предупреждение: Exception at 0x7c812aeb, code: 0x6a6: Invalid RPC server, flags=0x1 (execution cannot be continued) (first chance)@

                                So, on my pc RPC service is runned

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

                                  Then are you sure your server is running and that you can make as much connection that you are trying ?

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

                                  1 Reply Last reply
                                  0
                                  • B Offline
                                    B Offline
                                    bagipro
                                    wrote on last edited by
                                    #19

                                    Oh, i haven't server, i have only this code.
                                    And i don't click any buttons, i only run application and see errors

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

                                      Then I would :

                                      • First step: ensure the server is responding
                                      • Second step: try to access the server with one query
                                      • Third step: try with several queries in a row
                                      • Forth step: Try to parallelize your queries

                                      That might include refactoring your code so that for example you'll use QtConcurrent::map to call your function with all the queries from a QList rather than accessing them yourself

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

                                      1 Reply Last reply
                                      0
                                      • B Offline
                                        B Offline
                                        bagipro
                                        wrote on last edited by
                                        #21

                                        I have more than 100 servers, i can't do it ;(
                                        But when i use 1 thread all works correctly. Sometimes some servers are disabled

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

                                          Then I would refactor the code so that it doesn't use a while loop. Create a QList of queries and either use map or mapped (depending on wether you return a value or not, I think you do return a value)

                                          That would leave the entire parallelization to Qt and you'll only have to worry about retrieving the data.

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

                                          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