C++特有类型转换整理

通用的类型转换格式

                  (类型说明符)表达式     (int)(a+b)            a=1.4 ,b=1

 

其实通用的类型转换可以细分为三种类型转换,分别是static_cast, const_cast, reinterpret_cast.

static_cast:

            不具备去除const功能

 

 

const_cast:

        适用于将常指针转换为普通指针,将常引用转换普通引用。

                       1                                                 2

        1:string a = "sssssssssssss";       char *b;     b  = const_cast < char * > (a);

        2:   常引用转化为普通引用的例子大家能想想么,我实在是想不出。。。。

 

 

reinterpret_cast:

          该运算符的用法比较多。
          操作符修改了 操作数 类型,但仅仅是重新解释了给出的对象的比特模型而没有进行 二进制转换
          例如:int *n= new int ;
           double *d=reinterpret_cast<double*> (n);
          在进行计算以后, d 包含无用值. 这是因为 reinterpret_cast 仅仅是复制 n 的比特位到 d, 没有进行必要的分析。
           因此, 需要谨慎使用 reinterpret_cast.
           static_cast 与 reinterpret_cast
           reinterpret_cast是为了映射到一个完全不同类型的意思,这个关键词在我们需要把类型映射回原有类型时用到它。我们映射到的类型仅仅是为了故弄       玄     虚和其他目的,这是所有映射中最危险的。(这句话是C++编程思想中的原话)
            static_cast 和reinterpret_cast的区别主要在于 多重继承 ,比如
1
2
3
4
5
6
7
8
9
10
11
classA {
   public:
   int m_a;
};
classB {
   public:
   int m_b;
};
classC : public A, public B {};
            那么对于以下代码:
1
2
C c;
printf("%p, %p, %p", &c,reinterpret_cast<B*>(&c),static_cast <B*>(&c));
             前两个的输出值是相同的,最后一个则会在原基础上偏移4个字节,这是因为 static_cast 计算了父子类 指针 转换的 偏移量 ,并将之转换到正确的地址   (c        里面有m_a,m_b,转换为B*指针后指到m_b处),而reinterpret_cast却不会做这一层转换。
             因此, 要谨慎使用 reinterpret_cast.

 

 

 

你可能感兴趣的:(C++,String)