スポンサーリンク

このドキュメントの内容は、以下の通りです。

はじめに


g++ のコンパイルが遅いし、エラーが読みにくいので、clang++を試してました。

いろいろきになってきたので、超適当ですが、比較してみました。
  • コンパイル時間
  • バイナリサイズ
  • バイナリの実行速度
ソースは、 thrift ではきだした cassandra の C++ のコードです。

コンパイル時間


gmake した時間です。

clang++
Time spent in user mode   (CPU seconds) : 27.102s
Time spent in kernel mode (CPU seconds) : 12.999s
Total time                              : 0:40.17s
CPU utilisation (percentage)            : 99.8%
Times the process was swapped           : 0
Times of major page faults              : 0
Times of minor page faults              : 58942

g++
Time spent in user mode   (CPU seconds) : 16.149s
Time spent in kernel mode (CPU seconds) : 23.797s
Total time                              : 0:39.99s
CPU utilisation (percentage)            : 99.8%
Times the process was swapped           : 0
Times of major page faults              : 1
Times of minor page faults              : 142331

バイナリサイズ


clang でビルドしたのは a.out です。
g++ でビルドしたのは b.out です。

オプティマイズ設定はデフォルトです。

% ls -l a.out b.out
-rwxr-xr-x  1 k  users  1536191  2月 16 13:58 a.out*
-rwxr-xr-x  1 k  users  1109911  2月 16 13:59 b.out*


実行スピード


clang++
time a.out
Time spent in user mode   (CPU seconds) : 0.009s
Time spent in kernel mode (CPU seconds) : 0.027s
Total time                              : 0:00.07s
CPU utilisation (percentage)            : 28.5%
Times the process was swapped           : 0
Times of major page faults              : 0
Times of minor page faults              : 217

g++
time b.out
Time spent in user mode   (CPU seconds) : 0.017s
Time spent in kernel mode (CPU seconds) : 0.017s
Total time                              : 0:00.07s
CPU utilisation (percentage)            : 28.5%
Times the process was swapped           : 0
Times of major page faults              : 0
Times of minor page faults              : 215

まとめ


適当なので、あんまり意味ないような気がしてるのが、今回のケースだとコンパイルはgnuのほうが早かったです。
参照しているページ (サイト内): [2013-02-15-1]

スポンサーリンク
スポンサーリンク
 
いつもシェア、ありがとうございます!


もっと情報を探しませんか?

関連記事

最近の記事

人気のページ

スポンサーリンク
 

過去ログ

2020 : 01 02 03 04 05 06 07 08 09 10 11 12
2019 : 01 02 03 04 05 06 07 08 09 10 11 12
2018 : 01 02 03 04 05 06 07 08 09 10 11 12
2017 : 01 02 03 04 05 06 07 08 09 10 11 12
2016 : 01 02 03 04 05 06 07 08 09 10 11 12
2015 : 01 02 03 04 05 06 07 08 09 10 11 12
2014 : 01 02 03 04 05 06 07 08 09 10 11 12
2013 : 01 02 03 04 05 06 07 08 09 10 11 12
2012 : 01 02 03 04 05 06 07 08 09 10 11 12
2011 : 01 02 03 04 05 06 07 08 09 10 11 12
2010 : 01 02 03 04 05 06 07 08 09 10 11 12
2009 : 01 02 03 04 05 06 07 08 09 10 11 12
2008 : 01 02 03 04 05 06 07 08 09 10 11 12
2007 : 01 02 03 04 05 06 07 08 09 10 11 12
2006 : 01 02 03 04 05 06 07 08 09 10 11 12
2005 : 01 02 03 04 05 06 07 08 09 10 11 12
2004 : 01 02 03 04 05 06 07 08 09 10 11 12
2003 : 01 02 03 04 05 06 07 08 09 10 11 12

サイト

Vim入門

C言語入門

C++入門

JavaScript/Node.js入門

Python入門

FreeBSD入門

Ubuntu入門

セキュリティ入門

パソコン自作入門

ブログ

トップ


プライバシーポリシー