Richard Kettlewell wrote on 06/09/2015 10:16 AM:
"U.Mutlu" <for-gm...@mutluit.com> writes:
Hi,
on this page:
http://en.cppreference.com/w/cpp/thread/recursive_mutex/try_lock
they give the following C++11 example:

#include <iostream>
#include <mutex>

int main()
{
     std::mutex test;
     if (test.try_lock()==true) {
         std::cout << "lock acquired" << std::endl;
         test.unlock();    //now unlock the mutex
     } else {
         std::cout << "lock not acquired" << std::endl;
     }

     test.lock();    //to lock it again
     if (test.try_lock()) {  //true can be left out
         std::cout << "lock acquired" << std::endl;
     } else {
         std::cout << "lock not acquired" << std::endl;
     }
     test.unlock();
}

and they say it would give this output:
Output:
lock acquired
lock not acquired

I wonder why my compiler (g++ 4.9.2 from Debian repo) gives a different output:
lock acquired
lock acquired

Which compiler is wrong, and why?

AIUI, neither is wrong.  The code violates the preconditions of
try_lock(), and therefore results in undefined behavior.

Mystery solved: when using such concurrency/thread objects,
then one has to link with pthread (-lpthread):
 g++ -Wall -O2 -std=gnu++11 file.cpp -lpthread
Now my compiler gives the same result.




_______________________________________________
help-gplusplus mailing list
help-gplusplus@gnu.org
https://lists.gnu.org/mailman/listinfo/help-gplusplus

Reply via email to