zoukankan      html  css  js  c++  java
  • 从c到c++<四>

     

     总结一下:内联函数实际上就是用inline修饰的函数,这些函数会在编译时由编译器来将代码展开,而不用像上面第二点提到的人工展开,它的使用场景:代码很短、使用频率高

    具体代码如下:

    对于这两者实际上还是有区别的,如下面:

     

    对于宏来说有它有两个作用:常量带参数的宏(类似于函数调用)

    C++推荐常量用const、enum来替换宏;带参数的宏由inline来替换。

    所以在c++高层次编程中,推荐使用const、enum、inline替换宏;而在底层次编程中宏还是很灵活的。 

    • (T)expr
    • T(expr)

    • const_cast<T>(expr)
      ①、用来移除对象的常量性(cast away the constness)。
      怎么来理解上面的话呢?下面用程序来进行说明:

      既然val是常量,怎么可能将其转换为变量呢?这明显是矛盾的,而n跟val貌似没一点关系,val本身是无法改变的,那这个移除常量性貌似没一点意义,编译一下:


      ②、const_cast一般用于指针或者引用,所以下面来举例来说明:

      编译运行:

      接下来就可以用const_cast去除const限定:

      那这时如果更改值,如下:

      结果如下:

      那指针p和&val是同一个地址么?

      见证奇迹:

      可见地址是一样的,为啥指针是同一个,而更改不了指针指向的内容呢?可以这样理解:*p这个会产生一个临时的空间,而更改它的内容实际更改的是临时空间的内容,而非val所指向的空间内容。
      这就是第三点要说明的:
      ③、使用const_cast去除const限定的目的不是为了修改它的内容。
      下面举一个引有的例子:

      这个很显示应该会报错,跟指针一样:

      如非要这样使用,这时则用cast_cast去除const限定:

      输出结果:

      其中val2的值也是不会被更改的,所以进一步说明const_cast不是为了修改它的内容。它的主要目的是下面这点:
      ④、使用const_cast去除const限定,通常是为了函数能够接受这个实际参数。
      结合代码来理解:

      这时就需要用到const_cast来解决:

      再编译运行:

      val2本来的值是100的,为啥是200呢?其实这里的实参应该是临时变量,而临时变量在上面改成了200,“refval2 = 200;”,所以传给形参时,数据就是200了。
    • static_cast<T>(expr)
      ①、编译器隐式执行的任何类型转换都可以由static_cast完成。
      所谓编译器隐式类型转换:也就是自动进行转换的,结合代码来说就是:
      int a;
      short b:
      a = b;//它就是隐式转换,它可以由static_cast完成,但是一般不会这样做。
      ②、当一个较大的算术类型赋值给较小的类型时,可以用static_cast进行强制转换,也就是显示转换,下面用代码说明下:

      ③、可以将void*指针转换为某一类型的指针。

      ④、可以将基类指针转成派生类指针。【这个在之后学习类的时候再说】
      ⑤、无法将const转化为nonconst,这个只有const_cast才可以办得到。
    • reinterpret_cast<T>(expr) 【需要慎用它!】
    • dynamic_cast<T>(expr)【这个是在派生类中进行转型的,等之后学到类再来学习】
      执行“安全向下”转型操作,也就是说支持运行时识别指针或所指向的对象,这是唯一个无法用旧式语来进行的转型操作。

    【注意】:

    1、尽可能避免强制类型转换。

    2、如果无法避,推荐使用新式类型转换。

  • 相关阅读:
    sql中的并、交、差
    白水的sql需求:每个病人的对应最小诊断类别|partition|
    |转|oracle行转列点评oracle11g sql新功能pivot/unpivot
    oracle wm_concat(column)函数的使用不同公司支付同一客商(行转列)|转|
    记录那些删除的伴我成长的触发器
    PL/SQL Developer使用技巧|F=Forwarding|
    手工创建数据库 ocp课程 wait for
    Oracle数据库监听配置|转|
    最新解决的sql:病人相邻两次看病小于3天
    tns的一些常见错误分析实例 |转|
  • 原文地址:https://www.cnblogs.com/webor2006/p/4896191.html
Copyright © 2011-2022 走看看