目次
工作HardwareHubからのお知らせ
テンポラリオブジェクトの生成箇所
インスタンス生成時
#include <iostream>
using namespace std;
class MyClass {
public:
MyClass(int intval);
MyClass(const MyClass& other);
void operator=(const MyClass& other);
public:
void Show() const;
private:
int m_intval;
};
MyClass::MyClass(int intval) :
m_intval(intval)
{
cout << "MyClass::MyClass" << endl;
}
MyClass::MyClass(const MyClass& other) {
cout << "MyClass::MyClass(copy)" << endl;
m_intval = other.m_intval;
}
void MyClass::operator=(const MyClass& other) {
cout << "MyClass::MyClass(=)" << endl;
m_intval = other.m_intval;
}
void MyClass::Show() const {
cout << m_intval << endl;
}
int main() {
// 形式 1
MyClass obj(0); //=> MyClass::MyClass
obj.Show(); //=> 0
// 形式 2
MyClass* ptr = new MyClass(1); //=> MyClass::MyClass
ptr->Show(); //=> 1
// 形式 3
// (テンポラリオブジェクトを生成してコピーコンストラクタで「初期化」)
MyClass objCopied = MyClass(2); //=> "MyClass::MyClass\nMyClass::MyClass(copy)"
// ↑一つ目はテンポラリオブジェクトの分
// or "MyClass::MyClass" ←コンパイラの最適化でコピーされない場合
objCopied.Show(); //=> 2
// 形式 4
// (テンポラリオブジェクトを生成して「代入」)
obj = MyClass(3); //=> "MyClass::MyClass\nMyClass::MyClass(=)"
obj.Show(); //=> 3
return 0;
}
関数からオブジェクトを返す際
#include <iostream>
using namespace std;
class MyClass {
public:
MyClass(int intval);
MyClass(const MyClass& other);
public:
void Show() const;
private:
int m_intval;
};
MyClass::MyClass(int intval) :
m_intval(intval)
{
cout << "MyClass::MyClass" << endl;
}
MyClass::MyClass(const MyClass& other) {
cout << "MyClass::MyClass(copy)" << endl;
m_intval = other.m_intval;
}
void MyClass::Show() const {
cout << m_intval << endl;
}
MyClass MyFunc() {
MyClass _obj(0); //=> "MyClass::MyClass"
return _obj;
}
int main() {
MyClass obj = MyFunc(); // テンポラリオブジェクトが生成されて、
// それをコピーコンストラクタの引数に使用
obj.Show(); //=> 0
return 0;
}
const参照でテンポラリオブジェクトを指す
テンポラリオブジェクトを指し示している参照が存在する限り、テンポラリオブジェクトは破壊されません。
#include <iostream>
using namespace std;
class MyClass {
public:
MyClass(int intval);
public:
void Show() const;
private:
int m_intval;
};
MyClass::MyClass(int intval) :
m_intval(intval)
{
}
void MyClass::Show() const {
cout << m_intval << endl;
}
void MyFunc(const MyClass& obj) {
obj.Show();
}
int main() {
// const参照を引数とする関数に渡す
MyFunc(MyClass(0)); //=> "0\nMyClass::~MyClass"
// 直接的にconst参照に指させる
const MyClass& ref = MyClass(1);
ref.Show(); //=> "1"
return 0;
} //=> "MyClass::~MyClass"
関連記事
- ダウンキャスト (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...