内容简介:转载请注明文章出处:按修饰符的位置分为函数名前与函数名后两种,以下分别做介绍。
转载请注明文章出处: https://tlanyan.me/cpp-function-modifier-summary/
C++
博大精深,而且不断拥抱新的变化。本文简要总结一下 C++
中函数的修饰符,其中部分在实际中极少用到。
按修饰符的位置分为函数名前与函数名后两种,以下分别做介绍。
函数名前
-
返回值类型
返回值类型是
C++
中定义函数的必备部分,这些修饰符包括void
,(unsigned) int
,bool
等内置基本数据类型和自定义类型,也包括修饰返回值const
关键字(如const int*
),还包括C++11
中新增的类型自动推导auto
关键字。 -
template
template
关键字声明函数是 模板函数 。 -
virtual
virtual
关键字声明函数是 虚函数 ,可被子类覆盖。 -
inline
inline
关键字提示编译器应将函数 内联 。 -
static
static
修饰类的成员函数时指示函数是 静态成员函数 ,不从属于具体对象;修饰单独的函数时,限定函数的 可见范围为本文件内 。 -
extern
extern
关键字声明一个定义在 外部 的函数 -
explicit
explicit
关键字在C++11
新增,只用于 构造函数 ,指定构造函数要 显式定义 ,不能 隐式转换 。 -
friend
friend
关键字声明类的友元函数,在函数内可 直接访问 对象的私有或受保护成员及成员函数。 -
constexpr
C++11
中新增,指示函数返回 常量表达式 (可以简单理解为返回 字面量 )。
函数名后
置于函数名后的修饰符有两种,第一种使用等号( =
),第二种直接修饰。
-
使用等号
此类较为简单,总共有三种:
-
=0
:只能用于虚函数,表示函数为 纯虚函数 。 -
=default
:C++11
新增,只能用于编译器提供默认实现的 特殊成员函数 ,指示 使用默认实现 。 -
=delete
:C++11
新增,只能用于编译器提供默认实现的 特殊成员函数 ,指示编译器应该 删除该函数的默认实现 。
-
-
直接修饰
种类繁多,本人已知的修饰符包括:
-
const
表示函数不会修改对象(或者说调用期间对象不变),注意不包括
mutable
修饰的成员变量,可参考本人之前文章: C++中的mutable和volatile 。 -
volatile
类似于
const
修饰的函数,表示对象状态 可能随时会改变 ;const
修饰的函数内只能调用自身的const
成员方法,同理volatile
函数内也只能调用自身volatile
成员函数。 -
&
C++11
引入的功能, 左值引用限定符 ,指示函数只能被 左值 对象调用。 -
&&
C++11
引入, 右值引用限定符 ,指示函数只能被 右值 调用。如果函数没有引用限定符修饰,左值和右值均可调用。一个引用限定例子:#include <iostream> struct S { void f() & { std::cout << "lvalue\n"; } void f() &&{ std::cout << "rvalue\n"; } }; int main(){ S s; s.f(); // 打印“ lvalue ” std::move(s).f(); // 打印“ rvalue ” S().f(); // 打印“ rvalue ” }
-
override
C++11
引入的功能,声明成员函数 覆盖 父类的虚函数。声明为override
后,子类声明时可不写virtual
。 -
final
C++11
引入,指示函数是 最终 实现,子类不应当再定义或覆盖,可与override
同时使用。 -
noexcept
C++11
引入,修饰函数是否会抛出 异常 。 -
throw
指示函数抛出异常及类型,
C++11
起被 废弃 。
-
总结
本文简要概括的列出了 C++
定义函数的修饰符。需要注意的是,严格来说上述内容中并不全是修饰符,部分仅是语法结构。
以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,也希望大家多多支持 码农网
猜你喜欢:- C++ 中const修饰虚函数实例详解
- c# – 为什么具有受保护修饰符的函数可以被覆盖并且可以在每个位置访问?
- Go语言的修饰器编程
- GO语言的修饰器编程
- decrator(修饰器)的业务应用
- 《Python有什么好学的》之修饰器
本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
白帽子讲浏览器安全
钱文祥 / 电子工业出版社 / 2016-3 / 79.00元
浏览器是重要的互联网入口,一旦受到漏洞攻击,将直接影响到用户的信息安全。作为攻击者有哪些攻击思路,作为用户有哪些应对手段?在《白帽子讲浏览器安全》中我们将给出解答,带你了解浏览器安全的方方面面。《白帽子讲浏览器安全》兼顾攻击者、研究者和使用者三个场景,对大部分攻击都提供了分析思路和防御方案。《白帽子讲浏览器安全》从攻击者常用技巧的“表象”深入介绍浏览器的具体实现方式,让你在知其然的情况下也知其所以......一起来看看 《白帽子讲浏览器安全》 这本书的介绍吧!