• static 和 const关键字的作用


    static 和 const关键字的作用

    • static 关键字至少有下列 n 个作用:
      1. 函数体内static 变量的作用范围为该函数体,不同于 auto 变量,该变量的内存 只被分配一次,因此其值在下次调用时仍维持上次的值;
      2. 在模块内的 static 全局变量可以被模块内所用函数访问,但不能被模块外其它函 数访问;
      3. 在模块内的 static 函数只可被这一模块内的其它函数调用,这个函数的使用范围 被限制在声明它的模块内;
      4. 在类中的 static 成员变量属于整个类所拥有,对类的所有对象只有一份拷贝;
      5. 在类中的 static 成员函数属于整个类所拥有,这个函数不接收 this 指针,因而只能访问类的 static 成员变量。
    • const 关键字至少有下列 n 个作用:
      1. 欲阻止一个变量被改变,可以使用 const 关键字。在定义该 const 变量时,通常 需要对它进行初始化,因为以后就没有机会再去改变它了;
      2. 对指针来说,可以指定指针本身为 const,也可以指定指针所指的数据为 const, 或二者同时指定为 const;
      3. 在一个函数声明中,const 可以修饰形参,表明它是一个输入参数,在函数内部 不能改变其值;
      4. 对于类的成员函数,若指定其为 const 类型,则表明其是一个常函数,不能修改类的成员变量;
      5. 对于类的成员函数,有时候必须指定其返回值为 const 类型,以使得其返回值不 为“左值”。

    惊讶吗?小小的 static 和 const 居然有这么多功能,我们能回答几个?如果只能回答 1~2 个,那还真得闭关再好好修炼修炼。 这个题可以考查面试者对程序设计知识的掌握程度是初级、中级还是比较深入,没有一定的知识广度和深度,不可能对这个问题给出全面的解答。大多数人只能回答出 static 和 const 关键字的部分功能

  • 相关阅读:
    Spark面试题汇总及答案(推荐收藏)
    kafka各个版本的特性
    resttemplate的ReadTimeout和ConnectTimeout
    Spark内存调优
    git 从远程仓库获取所有分支
    Flask 学习58.基于 Celery 的后台任务 上海
    Flask 学习64.current_app的使用与应用上下文(AppContext) 上海
    Flask 学习61.FlaskMail 发送邮件 上海
    Flask 学习56.FlaskRESTX 开发文件(FileStorage)上传功能接口 上海
    Flask 学习62.Cookies 设置与使用 上海
  • 原文地址:https://www.cnblogs.com/Chlik/p/13541222.html
Copyright © 2020-2023  润新知