C++各种转换
来源:互联网 发布:苏州碟科数据恢复 编辑:程序博客网 时间:2024/06/09 18:05
1. 隐式和显式初始化
1.1 C++隐式初始化
int ival(1024);
string hello("Hello world.")
1.2 C++显式初始化
int ival = 1024;
string hello = "Hello world."
*PS: 注意这里"=" 语法是拷贝构造函数而不是赋值运算!
因为一个新对象被定义一定要有一个构造函数而不不是一个赋值操作
string hello;
hello = "Hello world"; <- 这里hello 已经被定义了,才是赋值操作.
2.隐式和显式类型转换.
2.1
C++隐式转换发生在四种情况下
* 在混合类型的算术表达式中
int ival = 3;
double dval = 3.1415
ival + dval; //ival 被提升为double 类型:3.0
* 用一种类型的表达式赋值
int *pi = NULL; // NULL(0)被转换成了int* 类型的空指针值
* 用一个表达式传递给一个函数调用
extern double sqrt(double);
sqrt(2); //2被提升为double类型: 2.0
* 从一个函数返回一个表达式
double difference(int ival1, int ival2)
{
return ival1 - ival2; //返回值被提升为double 类型.
}
2.2
C++内建类型(char,int,short,double etc.)对像之间默认含有隐式转换
2.3
C++用户定义类对象之间可以含有隐式转换.
void dosomething(A aObject);
class A {
public:
A(int x = 0);
}
dosomething(20); // Ok 隐式转换
2.4
C++显式转换包含四种转换
static_cast : 编译期的转化,不能转换掉exdivssion的const、volitale、或者__unaligned属性
*所有内建类型对象之间的隐式转换都可用static_cast.
*把空指针转换成目标类型的空指针用static_cast。
*把任何类型的表达式转换成void类型用static_cast。
*类层次间的上行转换和下行转换也可以用static_cast,但下行转换即当把基类指针或引用转换成子类表示时,由于没有动态类型检查,所以是不安全的.反之是安全的.
dynamic_cast : 运行期的转换,类层次间的上行转换和下行转换
* dynamic_cast具有类型检查的功能,下行转换的效果跟static_cast是一样的,但下行转换比static_cast更安全。
* dynamic_cast还支持交叉转换,两个类如果有共同的祖先,他们的指针就可以用dynamic_cast.
const_cast :
- 标准c++中主要有四种强制转换类型运算符:
- const_cast,reinterpret_cast,static_cast,dynamic_cast等等。
- 1)static_cast<T*>(a)
- 将地址a转换成类型T,T和a必须是指针、引用、算术类型或枚举类型。
- 表达式static_cast<T*>(a), a的值转换为模板中指定的类型T。在运行时转换过程中,不进行类型检查来确保转换的安全性。
- 例子:
- class B { ... };
- class D : public B { ... };
- void f(B* pb, D* pd)
- {
- D* pd2 = static_cast<D*>(pb); // 不安全, pb可能只是B的指针
- B* pb2 = static_cast<B*>(pd); // 安全的
- ...
- }
- class B { ... };
- class D : public B { ... };
- void f(B* pb, D* pd)
- {
- D* pd2 = static_cast<D*>(pb); // 不安全, pb可能只是B的指针
- B* pb2 = static_cast<B*>(pd); // 安全的
- ...
- }
- class B { ... };
- class D : public B { ... };
- void f(B* pb, D* pd)
- {
- D* pd2 = static_cast<D*>(pb); // 不安全, pb可能只是B的指针
- B* pb2 = static_cast<B*>(pd); // 安全的
- ...
- }
- 2)dynamic_cast<T*>(a)
- 完成类层次结构中的提升。T必须是一个指针、引用或无类型的指针。a必须是决定一个指针或引用的表达式。
- 表达式dynamic_cast<T*>(a) 将a值转换为类型为T的对象指针。如果类型T不是a的某个基类型,该操作将返回一个空指针。
- 例子:
- class A { ... };
- class B { ... };
- void f()
- {
- A* pa = new A;
- B* pb = new B;
- void* pv = dynamic_cast<A*>(pa);
- // pv 现在指向了一个类型为A的对象
- ...
- pv = dynamic_cast<B*>(pb);
- // pv 现在指向了一个类型为B的对象
- }
- 3)const_cast<T*>(a)
- 去掉类型中的常量,除了const或不稳定的变址数,T和a必须是相同的类型。
- 表达式const_cast<T*>(a)被用于从一个类中去除以下这些属性:const, volatile, 和 __unaligned。
- 例子:
- class A { ... };
- void f()
- {
- const A *pa = new A;//const对象
- A *pb;//非const对象
- //pb = pa; // 这里将出错,不能将const对象指针赋值给非const对象
- pb = const_cast<A*>(pa); // 现在OK了
- ...
- }
- class A { ... };
- void f()
- {
- const A *pa = new A;//const对象
- A *pb;//非const对象
- //pb = pa; // 这里将出错,不能将const对象指针赋值给非const对象
- pb = const_cast<A*>(pa); // 现在OK了
- ...
- }
- class A { ... };
- void f()
- {
- const A *pa = new A;//const对象
- A *pb;//非const对象
- //pb = pa; // 这里将出错,不能将const对象指针赋值给非const对象
- pb = const_cast<A*>(pa); // 现在OK了
- ...
- }
- 4)reinterpret_cast<T*>(a)
- 任何指针都可以转换成其它类型的指针,T必须是一个指针、引用、算术类型、指向函数的指针或指向一个类成员的指针。
- 表达式reinterpret_cast<T*>(a)能够用于诸如char* 到 int*,或者One_class* 到 Unrelated_class*等类似这样的转换,因此可能是不安全的。
- 例子:
- class A { ... };
- class B { ... };
- void f()
- {
- A* pa = new A;
- void* pv = reinterpret_cast<A*>(pa);
- // pv 现在指向了一个类型为B的对象,这可能是不安全的
- ...
- }
- c实现各种进制间转换
- c/c++各种字符、字符串类型转换
- c/c++各种字符、字符串类型转换
- C语言各种数值类型转换函数
- C语言各种数值类型转换函数
- C语言各种数据类型自动转换
- c/c++各种字符、字符串类型转换
- C/ C++字符串的各种转换
- C语言中的各种进制转换
- C/C++各种数据类型转换汇总
- C/C++各种数据类型转换汇总
- C/C++各种数据类型转换汇总
- Objective-C中的BOOL类型各种转换
- c/c++,windows中各种字符的转换
- 各种转换
- 各种转换
- c#.net函数和方法集(各种值类型转换)
- C++各种数据类型之间的相互转换
- 验证码!!无法显示
- 小技巧 ASP.NET 持续更新中
- 客户端NIO实践分析
- 数字艺术的朋友太有才了,赞~
- 学习AS3最值得看的三本书
- C++各种转换
- AIX 启动 ORACLE实例
- 括号匹配
- 从今天开始混CSDN
- 在VC6中使用GDI+
- Microsoft IIS 解析文件名“x.asp;x.jpg/x.php;x.jpg”漏洞
- c# 开源一览表
- javax.el-api not found
- spagoBI 国际化