コマンドライン引数
#include <iostream>
using namespace std;
int main(int argc, char* argv[]) {
for (int i = 0; i < argc; ++i) {
cout << argv[i] << endl;
}
return 0;
}
system関数
#include <iostream>
#include <cstdlib> // system() を使用するため
using namespace std;
int main() {
system("pwd"); //=> /path/to/here
return 0;
}
強制終了
#include <iostream>
#include <cstdlib>
using namespace std;
int main() {
exit(EXIT_FAILURE); // 引数を持つ。静的変数の後片付けを行う
abort(); // 引数を持たない。静的変数の後片付けを行わない
return 0;
}
ヘッダファイルのプリコンパイル
$ g++ pch.h
とすると pch.h.gch が生成されます。
#include "pch.h"
において pch.h ではなく pch.h.gch が優先的に利用されるようになります。コンパイル時間の短縮が期待できます。
アラインメント
32ビット機はメモリに 32bit (4バイト) 単位でアクセスします。バイト境界には N バイト境界 (N=2,4,8,...) があり、32ビット機については N=4 が重要です。4バイト境界をまたぐデータがある場合、たとえ合計で4バイトであったとしても二回のメモリアクセスが発生して非効率です。これを避けるためバイト境界を揃える (alignment) 処理がなされます。例えば合計4バイトの int 型変数の領域は4バイト境界に揃えて確保されます。構造体やクラスのメンバそれぞれが独自にアラインメントされた結果、メンバ間に隙間がが発生することがあります。この隙間はパディングとよばれる意味のないデータで埋められます。
最適化の抑制
CPUは変数を利用する際に、変数の格納されたアドレスのメインメモリ領域からCPUのレジスタにデータを読み出します。頻繁にアクセスするデータに関しては、キャッシュメモリに保存しておくことでメインメモリへのアクセス回数を減らします。キャッシュメモリへのアクセスはメインメモリと比較すれば十分に高速ですがレジスタへのアクセスと比較すると低速です。そこで、コンパイラはメインメモリに格納しておく必要がないと判断した変数について、その存在を削除したりレジスタ上だけで扱ったりします。これは最適化の一種です。この最適化を抑制するためには volatile 修飾子を使用します。
#include <iostream>
using namespace std;
void MyFunc() {
volatile int intval = 0;
cout << intval << endl;
// cout << 0 << endl; // 左記のコードに最適化されることを抑制
}
int main() {
MyFunc(); //=> 0
return 0;
}
オンラインコンパイラ
関連記事
- ダウンキャスト (C++をもう一度)実行時型情報 RTTI #include <iostream> #include <typeinfo> using namespace std; class MyClass { public: virtual ~MyClass() {} // typeid で正しい RTTI // (RunTime Type Information; 実行時型情報) ...
- 競技プログラミングの基本処理チートシート (C++)限られた時間の中で問題を解くために必要となる、競技プログラミングにおける基本的な処理のチートシートです。競プロにおけるメジャー言語 C++ を利用します。その際 C++11 の機能は利用せず C++03 の機能の範囲内で記述します。 頻度高く定期的に開催されるコンテスト AtCoder Codeforces main.cpp #include <iostream>
- 構造体と列挙体 (C++をもう一度)構造体 #include <iostream> using namespace std; struct MyStruct { char charval; int intval; }; void Show(MyStruct* obj) { cout << obj->intval << endl; } int main() { ...
- Valgrind による C/C++ メモリリーク検出JVM メモリリークでは JDK の jstat や jmap で原因を調査できます。C/C++ では valgrind の Memcheck ツールが利用できます。valgrind には複数のツールが含まれており既定のツールが Memcheck です。他のツールを利用する場合は --tool オプションで指定します。 [簡単な利用例](h
- クラスの基本/初期化 (C++をもう一度)構造体のように初期化する (非推奨) #include <iostream> using namespace std; const int MAX_STR = 16; class MyClass { public: int m_integer; char m_str[MAX_STR + 1]; void Show(); }; void MyClass::Show...