您的位置:首页 > 编程语言 > C语言/C++

阐述C++编译器变量进行优化说明

2011-04-04 18:31 211 查看
在大多数情况下,把变量缓存在寄存器中是一个非常有价值的优化方法,如果不用的话很可惜。C++编译器提供了显式禁用这种缓存优化的机会。如果你声明变量是使用了volatile修饰符,编译器就不会把这个变量缓存在寄存器里——每次访问都将去存取变量在内存中的实际位置。

防止了C++编译器对所修饰的变量进行优化。主要应用于多线程编程。volatile 可以用于修饰原生类型也可用于自定义类型。volatile 虽与const的语义不同但用法类似。

class Gadget  
{  
public:  
 void Foo() volatile{};  
 void Bar() const{};   
 void Doo(){};  
//private:  
    char name_;  
    int state_;  
};

若定义一个对象为const:const Gadget cGadget; 说明cGadget对象的成员变量的值不可更改。所以要求该对象只能调用接口中的const型的成员函数。即要求其可调用的接口不能修改其成员变量的值,该成员函数必须为const型。即:

class Gadget  
{  
public:  
 void Foo() volatile{};  
 void Bar() const{};   
 void Doo(){};  
//private:  
    char name_;  
    int state_;  
};

因为const型变量要求其可调用接口为const型,而对象之间赋值需要调用其赋值函数,C++编译器的赋值函数并非是const型,因此重载成了必然。可是有个可笑的问题是,const型对象是要求不能更改成员变量的值,但赋值是为了改变其值。

所以赋值函数(考贝构造函数)不能为变量赋值。只要不在赋值函数(考贝构造函数)里为变量赋值是可以编译通过的。但这毫无意义,说这个只是为volatile,因为volatile于const操作是一样的,只是volatile是可以更改成员变量值,所以这里不成问题。

该运算符把expression转换为type-id类型,但没有运行时类型检查来保证转换的安全性。它主要有如下几种用法:

①用于类层次结构中基类和子类之间指针或引用的转换。进行上行转换(把子类的指针或引用转换成基类表示)是安全的;进行下行转换(把基类指针或引用转换成子类表示)时,由于没有动态类型检查,所以是不安全的。

②用于基本数据类型之间的转换,如把int转换成char,把int转换成enum。这种转换的安全性也要开发人员来保证。

③把空指针转换成目标类型的空指针。



④把任何类型的表达式转换成void类型。



注意:C++编译器不能转换掉expression的const、volitale、或者__unaligned属性。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: