目次
工作HardwareHubからのお知らせ
サンプルコード
プログラムはメモリ上に読み出されてその上で動いています。そのプログラム内で関数が使用されている場合、メモリ内には関数のアドレスも存在しています。関数を実行すると、関数の内容が読み出されているメモリのアドレスに処理のポイントが移動されます。この作業には多少の時間がかかるため、関数を実行した部分に関数の内容を直接埋め込んで、処理のポイントを移動させる必要のない状況を実現したいことがあります。これは、コンパイラに inline という要望を出すことで実現できることがあります。
感覚としてはマクロや #include と同じです。展開するためには実装が見える必要があるため、ファイル分割をするならばヘッダファイルに実装を記述する必要があります。また、直接埋め込み展開されるため、呼び出す場所が多ければそれだけプログラムのサイズも大きくなります。あまりにも肥大化すると判断されると、inlineが無視されてコンパイルされます。inline 展開するかどうかの判断はコンパイラに任せられています。
sub.h
#ifndef SUB_H_
#define SUB_H_
#include <iostream>
// インライン関数
inline void MyFunc() { // インライン関数化を要望
static int intval = 1; // 静的変数の実体はインライン関数であっても共通です。
std::cout << "MyFunc: " << intval << std::endl;
// ↑ヘッダファイル内では using は使用すべきではありません。
++intval;
}
// インラインメンバ関数
class MyClass {
public:
int Get() const;
public:
// クラス内に処理を記述すれば inline 要望できます
void Set(int intval) {
m_intval = intval;
}
public:
void _Set(int intval);
private:
int m_intval;
};
// クラス外に処理を書く場合は inline と記述します
// (前述の通り、ヘッダファイル内に処理を記述する必要があります)
inline void MyClass::_Set(int intval) {
m_intval = intval;
}
#endif // #ifndef SUB_H_
sub.cpp
#include "sub.h"
int MyClass::Get() const {
return m_intval;
}
main.cpp
#include "sub.h"
#include <iostream>
using namespace std;
int main() {
MyFunc(); //=> MyFunc: 1
// cout << "MyFunc" << endl; // と展開されます。
MyFunc(); //=> MyFunc: 2
MyClass obj;
obj.Set(0);
cout << obj.Get() << endl; //=> 0
obj._Set(1);
cout << obj.Get() << endl; //=> 1
return 0;
}
Makefile
CC = g++
CFLAGS = -g -Wall
ALL: main.o sub.o
$(CC) $(CFLAGS) -o main main.o sub.o
main.o: main.cpp
$(CC) $(CFLAGS) -o main.o -c main.cpp
sub.o: sub.cpp sub.h
$(CC) $(CFLAGS) -o sub.o -c sub.cpp
関連記事
- ダウンキャスト (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...