string screen(int hz=24,int wid=80,char c='')
window=screen( , ,'?');//错误!,只有尾部的实参可以省,变为默认实参
window=screen('?');//不报错,但是与本身期望不符合,把?的ASCII码赋值给hz了
在给定的作用域中一个形参只能被赋予一次默认实参
局部变量不能作为默认实参,函数结束就销毁,无法当作默认实参。
除此之外,只要表达式的类型可转换成形参所需要的类型,则可以作为默认实参
int ht();
string screen(int w=hrt());//正确,非局部变量
将函数定义为内联函数,即加上inline,在编译时内联展开代替函数
inline const string& shorterString(const string& s1,const string& s2)
{
return s1.size()<=s2.size()? s1:s2;
}
cout<<shorterString(s1,s2)<<endl;
在编译时自动展开为
cout<<( s1.size()<=s2.size()? s1:s2)<<endl;
在编译时就能得到这个函数的返回值
constexpr int new_sz(){return 42;}
constexpr int foo=new_sz();
预处理器由预编译器处理
assert就是可以打印报错信息
#include<cassert>//无需using
int main()
{
int n1,n2;
cin>>n1>>n2;
assert(n2/n1);//为真什么都不做,为假打印错误信息
//为真则是n1不为0时,无除数为0错误
//为假是有除数错误
cout<<n2/n1<<endl;//可由assert检测出除数错误
}
就是一个开关:决定assert是不是要检查出错误
-D NDEBUG main.cpp
使用命令行开启ndbug开关:不检查,assert不生效,节省开销
assert只是调试手段,只会详细告诉程序员错误信息并终止程序,但不会处理错误
寻找最佳作为匹配,若是两个都可以是最佳,编译器会报二义性错误
无需要重点强调的