質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.48%
CMake

CMakeはクロスプラットフォームで作動するオープンソースのビルドシステムです。コマンドライン又は組み込まれた開発環境で使うことができる元のmakefileとプロジェクトファイルを生成します。

C++

C++はC言語をもとにしてつくられた最もよく使われるマルチパラダイムプログラミング言語の1つです。オブジェクト指向、ジェネリック、命令型など広く対応しており、多目的に使用されています。

Q&A

解決済

1回答

1192閲覧

Linux GCC Cmakeで複数のライブラリからのコンソール出力を正常に出したい

bjnes

総合スコア113

CMake

CMakeはクロスプラットフォームで作動するオープンソースのビルドシステムです。コマンドライン又は組み込まれた開発環境で使うことができる元のmakefileとプロジェクトファイルを生成します。

C++

C++はC言語をもとにしてつくられた最もよく使われるマルチパラダイムプログラミング言語の1つです。オブジェクト指向、ジェネリック、命令型など広く対応しており、多目的に使用されています。

0グッド

0クリップ

投稿2020/09/11 09:12

編集2020/09/15 04:55

前提・実現したいこと

テストコードと関数計測コードとデマングルコードをそれぞれ別のオブジェクトファイルとしてコンパイルしました。
最終的にテストコードを実行すると、コンソール上で何故か出力の”奪い合い?”みたいなものが起き、
コンソール上にうまく出力がされない。

リンカの設定が悪いのかもしれないのですがどうしたらいいのでしょうか。

発生している問題・エラーメッセージ

出力結果が以下のようになる。

Func IN Running main() from _deps/googletest-src/googletest/src/gtest_main.cc [==========] Running 1 test from 1 test suite. [----------] Global test environment set-up. [----------] 1 test from TimerTest [ RUN ] TimerTest.TestName [ OK ] TimerTest.TestName (4001 ms) [----------] 1 test from TimerTest (4001 ms total)                                                    #ここの出力がなかったりする [----------] Global test environment tear-down [==========] 1 test from 1 test suite ran. (4001 ms total) [ PASSED ] 1 test.

Func INと表示されて以降計測用コンパイルライブラリからの出力が止まっているのが謎です。

該当のソースコード

お手数ですが以下のリンク(私のGoogleDrive共有)からファイルをDLお願いします。
ビルドにはVSCodeとCmakeTooksとgccが必要になります。

ここからDL

補足情報(FW/ツールのバージョンなど)

VSCode 1.49.0
Extention 
・CMake
・CMake Tools
gcc -v
組み込み spec を使用しています。
COLLECT_GCC=gcc
COLLECT_LTO_WRAPPER=/usr/lib/gcc/x86_64-pc-linux-gnu/10.2.0/lto-wrapper
ターゲット: x86_64-pc-linux-gnu
configure 設定: /build/gcc/src/gcc/configure --prefix=/usr --libdir=/usr/lib --libexecdir=/usr/lib --mandir=/usr/share/man --infodir=/usr/share/info --with-bugurl=https://bugs.archlinux.org/ --enable-languages=c,c++,ada,fortran,go,lto,objc,obj-c++,d --with-isl --with-linker-hash-style=gnu --with-system-zlib --enable-__cxa_atexit --enable-cet=auto --enable-checking=release --enable-clocale=gnu --enable-default-pie --enable-default-ssp --enable-gnu-indirect-function --enable-gnu-unique-object --enable-install-libiberty --enable-linker-build-id --enable-lto --enable-multilib --enable-plugin --enable-shared --enable-threads=posix --disable-libssp --disable-libstdcxx-pch --disable-libunwind-exceptions --disable-werror gdc_include_dir=/usr/include/dlang/gdc
スレッドモデル: posix
Supported LTO compression algorithms: zlib zstd
gcc バージョン 10.2.0 (GCC)

Linux 5.8.7-arch1-1 #1 SMP PREEMPT Sat, 05 Sep 2020 12:31:32 +0000 x86_64 GNU/Linux

###分かったこと
・-ldlを追加すると、出力がおかしくなる。

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

yumetodo

2020/09/11 13:01

gtestの生成されてる実行ファイルを直接実行しても再現しますか?
bjnes

2020/09/14 08:59

はい、再現します。 何を気にされているのですか?
yumetodo

2020/09/15 06:35

CMake側かgtest以降かを切り分けたかったのです。CMake側じゃないようなのでちょっとお役にたてなさそう
bjnes

2020/09/15 06:46

私のリンカーへの理解が足りてないんだと思います。 -ldlをつけるとstd::coutの初期化ルーチンがおかしくなってるっぽいのですけど、これをどう対処したらいいのかわからないんですよね。
guest

回答1

0

自己解決

std::cout にヌルポを出していたことが原因でした。

しっかりと体調管理してヌルポ管理をしましょう。

投稿2020/09/18 05:07

bjnes

総合スコア113

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問