キャスト演算子:
型キャストは、特定の状況でオブジェクトの型を明示的に変換するためのメソッドを提供します。
構文
cast-expression:
unary-expression
(
type-name
)
cast-expression
注釈
単項式はキャスト式と見なされます。
コンパイラは、型キャストが行われた後、 cast-expression を型 type-name として扱います。 キャストは、任意のスカラー型のオブジェクトを他のスカラー型に変換したり、他のスカラー型から変換したりするために使用できます。 明示的な型キャストは、暗黙的な変換の影響を決定するのと同じ規則によって制約されます。 キャストに対するその他の制約は、実際のサイズまたは特定の型の表現に起因する可能性があります。
例示
組み込み型間の標準的なキャスト変換:
// expre_CastOperator.cpp
// compile with: /EHsc
// Demonstrate cast operator
#include <iostream>
using namespace std;
int main()
{
double x = 3.1;
int i;
cout << "x = " << x << endl;
i = (int)x; // assign i the integer part of x
cout << "i = " << i << endl;
}
ユーザー定義型で定義されたキャスト演算子:
// expre_CastOperator2.cpp
// The following sample shows how to define and use a cast operator.
#include <string.h>
#include <stdio.h>
class CountedAnsiString
{
public:
// Assume source is not null terminated
CountedAnsiString(const char *pStr, size_t nSize) :
m_nSize(nSize)
{
m_pStr = new char[sizeOfBuffer];
strncpy_s(m_pStr, sizeOfBuffer, pStr, m_nSize);
memset(&m_pStr[m_nSize], '!', 9); // for demonstration purposes.
}
// Various string-like methods...
const char *GetRawBytes() const
{
return(m_pStr);
}
//
// operator to cast to a const char *
//
operator const char *()
{
m_pStr[m_nSize] = '\0';
return(m_pStr);
}
enum
{
sizeOfBuffer = 20
} size;
private:
char *m_pStr;
const size_t m_nSize;
};
int main()
{
const char *kStr = "Excitinggg";
CountedAnsiString myStr(kStr, 8);
const char *pRaw = myStr.GetRawBytes();
printf_s("RawBytes truncated to 10 chars: %.10s\n", pRaw);
const char *pCast = myStr; // or (const char *)myStr;
printf_s("Casted Bytes: %s\n", pCast);
puts("Note that the cast changed the raw internal string");
printf_s("Raw Bytes after cast: %s\n", pRaw);
}
RawBytes truncated to 10 chars: Exciting!!
Casted Bytes: Exciting
Note that the cast changed the raw internal string
Raw Bytes after cast: Exciting
こちらも参照ください
単項演算子を含む式
C++ 組み込み演算子、優先順位、および結合規則
明示的な型変換演算子: ()
キャスト演算子 (C++)
キャスト演算子 (C)