Effective C++ 条款27

尽量少做转型动作

尽量少做转型动作有什么目的?非常明显无非就是提高程序的稳定性。提高程序的运行效率。

那么。有哪些转型方式?每种方式都有什么弱点? 这是我们本节学习的重点。

C++有四种转型:

const_cast<T>(expression)
dynamic_cast<T>(expression)
reinterpret_cast<T>(expression)
static_cast<T>(expression)

每种转型的作用例如以下:

1.const_cast通常被用来将对象的常量特性转除(cast away the constness)。它也是唯一由此能力的C++-style转型操作符。

2.dynamic_cast主要用来运行“安全向下转型”(safe downcasting),也就是用来决定某对象是否归属继承体系中的某个类型。

它是唯一无法由旧式语法运行的动作。也是唯一可能耗费重大运行成本的转型动作(后面细讲)。

3.reinterpret_cast意图运行低级转型。实际动作(结果)可能 取决于编译器,这表明其不可移植。比如将pointer to int转为int,这类转型经常使用在低级代码。

比如。讨论讨论怎样针对原始内存(raw memory)写一个调试用的分配器(debugging allocator),见条款50.

4.static_cast运行强迫隐式转换(implicit conversions)。比如将int转为double,non-const转为constant等。

它也能够用来运行一些转换的反响转换。但无法将const转为non-const。

我来总结一下以上的四点。

首先对于const_cast是起到一个去除const特性的作用。

去掉const属性:const_case

class Window{
public:
    virtual void onResize(){……};
    ……
};
class specialWindow:public Window{
public:
    virtual void onResize(){
        static_cast<Window>(*this).onResize();//调用的是副本。

……
    }
};

上面代码的运行结果是基类中的数据没有变化,derived类中的数据发生变化。这是由于static_cast<Window>(*this).onResize();这句调用的是基类的副本,和当前对象无关。

作者非常强调这部分内容。但是,大家不要变傻。我们细致看一下代码,他转型的本来就是一个副本!仅仅需修改一点点就能实现一致性。

例如以下

class Window{
public:
    virtual void onResize(){……};
    ……
};
class specialWindow:public Window{
public:
    virtual void onResize(){
        static_cast<Window*>(this).onResize();//ok
        ……
    }
};
时间: 2024-10-18 03:52:31

Effective C++ 条款27的相关文章

Effective C++ 条款27 尽量少做转型操作

1. 转型语法有三种, C风格转型:(T)expression 函数风格转型:T(expression) 两种方式除了小括号位置不同没有差别,可以称为"旧式转型". C++提供四种新式转型: const_cast<T>(expression): 将const变量引用或指针转为非const引用或指针,移除变量的常量特性.T必须是指针或引用. 注:虽然经const_cast转型后的变量可以被更改,但由于"常量折叠"(c++编译器在编译时将const 变量替换

Effective C++ 阅读笔记_条款27 尽量少做转型动作

Effective C++ 阅读笔记_条款27 尽量少做转型动作 1.转型的三种形式,可以分为两大类. (1)旧式转型(old-style casts) (1.1) (T) expresstion (1.2) T (expression) (2) 新式转型(c++-style casts) (2.1)const_cast<T> (expression) (2.2)dynamic_cast<T> (expression) (2.3)reinterpret_cast<T>

Effective C++:条款27:尽量少做转型动作

(一)C风格旧式转型: (T)expression T(expression) (二)C++提供四种新式转型: (1)const_cast<T>(expression):去除表达式的常量性,是C++中唯一能做此操作的转型操作符. (2)dynamic_cast<T>(expression):主要用来执行"安全向下转型",即用来决定某对象是否归属继承体系中的某个类型.它是唯一无法由旧式语法执行的动作,也是唯一可能耗费重大运行成本的转型动作. (3)reinterp

More Effective C++ 条款35 让自己习惯于标准C++ 语言

(由于本书出版于1996年,因此当时的新特性现在来说可能已经习以为常,但现在重新了解反而会起到了解C++变迁的作用) 1. 1990年后C++的重要改变 1). 增加了新的语言特性:RTTI,namespaces,bool,关键词mutable和explicit,enums作为重载函数之自变量所引发的类型晋升转换,以及"在class 定义区内直接为整数型(intergral) const static class members设定初值"的能力. 2). 扩充了Templates的特性

More Effective C++ 条款32 在未来时态下发展程序

1. 所谓"在未来时态下发展程序",指的是是程序需要具有良好的可扩展性和可维护性,它要求程序:功能齐全,接口易用,代码泛化,以下原则有助于实现这一目标: 1). 以C++本身表现各种规范而不是仅仅依赖于注释:如果某个class不打算作为基类,那么就应该以C++语法阻止派生(条款26);如果一个class要求所有对象实体在heap内产生,就以C++语法严格厉行这项约束(条款27),如果copying和assignment对某个class没有意义,就声明为private... 2). 如果

effective c++ 条款4 make sure that objects are initialized before they are used

1 c++ 类的数据成员的初始化发生在构造函数前 class InitialData { public: int data1; int data2; InitialData(int a, int b) { data1 = a: //this is assignment data2 = b; //this is assignment } /* InitialData(int a, int b):data1(a),data2(b) //this is initial {} */ } 2 不同cpp文

More Effective C++ 条款34 如何在一个程序中结合C++和C

1. C++和C混合使用的前提之一就是编译器产生兼容的目标文件(.lib和.dll等).所谓"兼容",指的是编译器在"预编译器相依的特性上"一致,如int和double大小,参数压栈机制等,只有在这个基础上才能讨论结合使用C++和C模块的问题. 2. 在1的基础上,要结合使用C++和C的模块,主要有以下几点需要注意: 1). name mangling(名称重整) Name mangling是C++用于支持函数重载的机制,它对重载的函数名称进行一定改变,使得每个函数

Effective C++ 条款3 尽可能用const

1. const可被施加于任何作用域内的对象,函数参数,函数返回类型,成员函数本体.用const修饰指针,如果const出现在*之前,表明指针不能更改所指向的对象的内容,如果const出现在*之后,表明指针只能指向同一块内存.另外int const*p和const int*p含义相同.如果对象成员有普通指针,那么构造该类的一个const对象时,const修饰使得该指针只能指向同一块内存,但指针指向的内容可以改变. 2. 将某些东西声明为const可以帮助编译器侦测出错误用法. 3. 编译器强制实

effective c++ 条款13 use object to manage resources.

请求的系统资源需要最终还回系统,为了避免遗忘返还这个动作,可以利用析构函数在object销毁时自动调用的特点来实现. 简单说就是用object来管理资源. 以内存资源为例 class Investment {}; Investment* creatInvestment(){...} // factory function to produce investment object void main() { Investment* pInv = creatInvestment();//call t