龙盟编程博客 | 无障碍搜索 | 云盘搜索神器
快速搜索
主页 > 软件开发 > C/C++开发 >

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

时间:2011-04-12 23:18来源:未知 作者:admin 点击:
分享到:
在大多数情况下,把变量缓存在寄存器中是一个非常有价值的优化方法,如果不用的话很可惜。 C++编译器 提供了显式禁用这种缓存优化的机会。如果你声明变量是使用了volatile修饰符,

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

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

  1. class Gadget  
  2. {  
  3. public:  
  4.  void Foo() volatile{};  
  5.  void Bar() const{};   
  6.  void Doo(){};  
  7. //private:  
  8.     char name_;  
  9.     int state_;  
  10. }; 

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

  1. class Gadget  
  2. {  
  3. public:  
  4.  void Foo() volatile{};  
  5.  void Bar() const{};   
  6.  void Doo(){};  
  7. //private:  
  8.     char name_;  
  9.     int state_;  
  10. }; 

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

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

该运算符把expression转换为type-id类型,但没有运行时类型检查来保证转换的安全性。它主要有如下几种用法:
①用于类层次结构中基类和子类之间指针或引用的转换。进行上行转换(把子类的指针或引用转换成基类表示)是安全的;进行下行转换(把基类指针或引用转换成子类表示)时,由于没有动态类型检查,所以是不安全的。
②用于基本数据类型之间的转换,如把int转换成char,把int转换成enum。这种转换的安全性也要开发人员来保证。
③把空指针转换成目标类型的空指针。
④把任何类型的表达式转换成void类型。

注意:C++编译器不能转换掉expression的const、volitale、或者__unaligned属性。

精彩图集

赞助商链接