前提・実現したいこと
テストコードと関数計測コードとデマングルコードをそれぞれ別のオブジェクトファイルとしてコンパイルしました。
最終的にテストコードを実行すると、コンソール上で何故か出力の”奪い合い?”みたいなものが起き、
コンソール上にうまく出力がされない。
リンカの設定が悪いのかもしれないのですがどうしたらいいのでしょうか。
発生している問題・エラーメッセージ
出力結果が以下のようになる。
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が必要になります。
補足情報(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を追加すると、出力がおかしくなる。
回答1件
あなたの回答
tips
プレビュー