g ++を使用したマルチスレッドコードのコンパイル


89

私はこれまでで最も簡単なコードを持っています:

#include <iostream>
#include <thread>

void worker()
{
    std::cout << "another thread";
}

int main()
{
    std::thread t(worker);
    std::cout << "main thread" << std::endl;
    t.join();
    return 0;
}

まだコンパイルしg++て実行することはできませんが。

詳細:

$ g++ --version
g++ (Ubuntu/Linaro 4.8.1-10ubuntu8) 4.8.1
Copyright (C) 2013 Free Software Foundation, Inc.
This is free software; see the source for copying conditions.  There is NO
warranty; not even for MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.

コンパイルするコマンド:

$ g++ main.cpp -o main.out -pthread -std=c++11

ランニング:

$ ./main.out 
terminate called after throwing an instance of 'std::system_error'
  what():  Enable multithreading to use std::thread: Operation not permitted
Aborted (core dumped)

そして今、私は立ち往生しています。インターネット上のすべての関連スレッドでは、-pthreadすでに持っている間に追加することをお勧めします。

私は何が間違っているのですか?

PS:それは真新しいubuntu13.10インストールです。g++パッケージのみがインストールされ、マイナーなものchromiumなど

PPS:

$ ldd ./a.out 
linux-vdso.so.1 => (0x00007fff29fc1000) 
libstdc++.so.6 => /usr/lib/x86_64-linux-gnu/libstdc++.so.6 (0x00007fb85397d000) 
libgcc_s.so.1 => /lib/x86_64-linux-gnu/libgcc_s.so.1 (0x00007fb853767000) 
libc.so.6 => /lib/x86_64-linux-gnu/libc.so.6 (0x00007fb85339e000) 
libm.so.6 => /lib/x86_64-linux-gnu/libm.so.6 (0x00007fb85309a000) 
/lib64/ld-linux-x86-64.so.2 (0x00007fb853c96000)

PPPS:clang++(v3.2)を使用すると、コンパイルして正常に実行されます

PPPPS:みんな、それは重複ではありませんLinuxのGCCでstd :: threadを使用するための正しいリンクオプション何ですか?

PPPPPS:

$ dpkg --get-selections | grep 'libc.*dev'
libc-dev-bin                    install
libc6-dev:amd64                 install
libclang-common-dev             install
linux-libc-dev:amd64                install

libpthread-2.17.so同じディレクトリ内へのシンボリックリンクです。
zerkms 2013年

はい、それは正しいリンクです。これが私のディレクトリlrwxrwxrwxです。1ルートルート
189

@Jason Enochs:それは私にとってはうまくいくでしょう-バグのあるgccバージョンを使用しなかった場合は同意します
zerkms 2013年

ええ、あなたのライブラリはすべて私のものより少し新しいです:gccバージョン4.7.2 20121109(Red Hat 4.7.2-8)(GCC)
Jason Enochs 2013年

@ジェイソンエノックス:へへ。私自身はすでに「バグだ」という答えに満足しており、おそらく完全に確実にするために、明日は古いubuntuで実行しようとします
zerkms 2013年

回答:


75

答えは、SO C ++チャットの親切なメンバーによって提供されました。

この動作はgccのバグが原因のようです。

そのバグディスカッションの最後のコメントで提供された回避策機能し、問題を解決します。

-Wl,--no-as-needed

8
SOとあなたのような人がいなければ私は何をしますか?あなたは私に一杯の髪を引っ張って救った。ありがとう:)これは(少なくとも私にとっては)わかりにくいです
scorpiodawg 2014年

@scorpiodawg:あなたのコメントは私の夜になりました、ありがとう:-)
zerkms 2014年

1
-pthread -lpthread -Wl,--no-as-neededこの作業を行うには、すべてのフラグを追加する必要がありました。
常磁性クロワッサン2015年

34

追加-lpthreadすると、同じ問題が修正されました。

 g++ -std=c++11 foo.cpp -lpthread -o foo

1
うん、これは答えであり、完全に合理的でもあります。「-Wl、-no-as-needed」は奇妙に聞こえ、私にとっても機能しません。
聖人2015年

3
あなたは間違いなく必要-lpthreadです。あなたは可能性がある必要がある-pthread -Wl,--no-as-neededコンパイラのバージョンに応じて、。gcc-4.8.2はそれを必要としています。
cdunn2001 2016年

12

私はもう少し高度なバージョン(4.8.1ではなく4.8.4)を使用しており、上記の3つの回答すべてをテストしました。実際には:

-pthread 単独で動作します:

g ++ -std = c ++ 11 -o main -pthread main.cpp

-Wl,--no-as-needed単独では機能しません

-lpthread単独では機能しません

-Wl,--no-as-neededそして-lpthread 一緒に働く:

g ++ -std = c ++ 11 -o main -Wl、-no-as-needed main.cpp -lpthread

私のバージョンは「g ++(Ubuntu 4.8.4-2ubuntu1〜14.04.1)4.8.4」です。


さて、ソリューションは異なるバージョンに提供されており、チェックした瞬間にチェックした回答が機能したことを確認できます。とにかく、実際の情報をありがとう。
zerkms 2016年

9

qtcreatorの回答はすでに作成されています:

LIBS += -pthread
QMAKE_CXXFLAGS += -pthread
QMAKE_CXXFLAGS += -std=c++11

コンソールg ++の場合:ここ

g++ -c main.cpp -pthread -std=c++11         // generate target object file
g++ main.o -o main.out -pthread -std=c++11  // link to target binary

1
ありがとうございます。-pthreadをコンパイラとリンカに渡す必要があることを明確にするのはあなたの答えだけです。
デニム
弊社のサイトを使用することにより、あなたは弊社のクッキーポリシーおよびプライバシーポリシーを読み、理解したものとみなされます。
Licensed under cc by-sa 3.0 with attribution required.