目次
工作HardwareHubからのお知らせ
デストラクタのサンプルコード
#include <iostream>
#include <algorithm>
using namespace std;
class MyClass {
public:
MyClass(int size);
~MyClass();
public:
int Get(int i);
private:
int m_size;
int* m_intarr;
};
MyClass::MyClass(int size) {
m_size = size;
m_intarr = new int[size];
fill_n(m_intarr, size, 0);
}
MyClass::~MyClass() {
delete[] m_intarr;
}
int MyClass::Get(int i) {
return m_intarr[i];
}
int main() {
{
MyClass obj(2);
cout << obj.Get(0) << endl;
cout << obj.Get(1) << endl;
} // デストラクタが呼ばれる
return 0;
}
分割コンパイル
上記のサンプルコードを分割コンパイルするためには以下のようにします。
main.cpp
#include <iostream>
class MyClass {
public:
MyClass(int size);
~MyClass();
public:
int Get(int i);
private:
int m_size;
int* m_intarr;
};
using namespace std;
int main() {
{
MyClass obj(2);
cout << obj.Get(0) << endl;
cout << obj.Get(1) << endl;
}
return 0;
}
sub.cpp
#include <algorithm>
class MyClass {
public:
MyClass(int size);
~MyClass();
public:
int Get(int i);
private:
int m_size;
int* m_intarr;
};
MyClass::MyClass(int size) {
m_size = size;
m_intarr = new int[size];
std::fill_n(m_intarr, size, 0);
}
MyClass::~MyClass() {
delete[] m_intarr;
}
int MyClass::Get(int i) {
return m_intarr[i];
}
コンパイル方法
$ g++ -Wall -o main.o -c main.cpp
$ g++ -Wall -o sub.o -c sub.cpp
$ g++ -Wall -o main main.o sub.o
ヘッダファイルを利用
クラスのプロトタイプ宣言が二回登場してしまっていました。この共通部分をヘッダファイル "sub.h" にまとめて、コンパイル直前にプリプロセッサで置換するように記述し直すとスッキリします。
その際、自作のヘッダファイルは標準ヘッダファイルよりも先に include するようにしましょう。自作ヘッダファイルで標準ヘッダファイルの include 忘れがあった場合にビルドエラーで検出できるためです。
main.cpp
#include "sub.h"
#include <iostream>
using namespace std;
int main() {
{
MyClass obj(2);
cout << obj.Get(0) << endl;
cout << obj.Get(1) << endl;
}
return 0;
}
sub.h
#ifndef SUB_H_
#define SUB_H_
class MyClass {
public:
MyClass(int size);
~MyClass();
public:
int Get(int i);
private:
int m_size;
int* m_intarr;
};
#endif // #ifndef SUB_H_
sub.cpp
#include "sub.h"
#include <algorithm>
MyClass::MyClass(int size) {
m_size = size;
m_intarr = new int[size];
std::fill_n(m_intarr, size, 0);
}
MyClass::~MyClass() {
delete[] m_intarr;
}
int MyClass::Get(int i) {
return m_intarr[i];
}
コンパイル方法
$ g++ -Wall -o main.o -c main.cpp
$ g++ -Wall -o sub.o -c sub.cpp
$ g++ -Wall -o main main.o sub.o
Makefileを利用
Makefile を利用するとコンパイルが楽になります。
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
コンパイル方法
$ make
仮想デストラクタ
なお、継承が発生する場合は仮想デストラクタを利用しましょう。
関連記事
- ダウンキャスト (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...