第61讲
能用递归解决的问题,一定可以用迭代(循环)解决,二者的区别在于:递归使用的是选择结构,而迭代使用的是循环结构,递归结构更加清晰,但由于每次递归的结构都要暂存,所以这种方法占用的内存多
第62讲
注意,函数的声明中,可以省略形参名,但必须保留形参类型
函数的定义中,不可省略形参名
对于函数使用默认参数的情形,如果在声明中写了默认实参,则定义中不能写默认实参(如下图);同理,如果在定义中写了默认实参,则声明中不能写默认实参,建议写在函数声明里
第63回
如下图所示,在函数结束后,静态局部对象仍然会保存下来,当第二次调用该函数时,C++发现这个 i 值已经有了,不需要再创建新的,所以 i 值就用上次留下来的那个,所以第二次调用该函数时,不会对该静态局部对象初始化
全局对象的作用域是从定义开始到程序结束;局部对象的作用域只限于函数内部(注意:形参也是局部对象),静态局部对象
i = 1;
return i++;
上面的代码return的是 1 ;
i = 1;
return ++i;
上面的代码return的是 2 ;
第64回
内联函数比普通函数调用速度快,编译时,函数调用处就会被展开为内联函数的表达式
内联函数的声明和定义整合在一起,必须都写在头文件中
注意:头文件中不要写 using namespace std
第65回
const成员函数表示这个函数不对类中的数据成员做任何修改
#include <iostream>
#include <string>
using namespace std;
// Sales_item 是一个类;item1,item2是类对象,isbn,unit_sold,revenue是类的公有数据成员,same_isbn()
// 是类的公有成员函数
class Sales_item
{
public:
double avg_price() const; //函数原型声明,对应的函数体写在类的外面
//const 表示这个成员函数不能对类的数据成员进行修改
bool same_isbn(const Sales_item& rhs) const //这个函数的函数体是写在类里面的
{ //this 表示当前对象
return this->isbn == rhs.isbn;
}
public:
std::string isbn;
unsigned units_sold;
double revenue;
};
double Sales_item::avg_price() const //这个函数的函数体是写在类外面的
{
if (this->units_sold)
return (this->revenue / this->units_sold);
else
return 0;
}
int main()
{
Sales_item item1, item2;
item1.isbn = "0-201-78345-X";
item1.units_sold = 10;
item1.revenue = 300;
cout << item1.avg_price() << endl;
item2.isbn = "0-201-78345-X";
item2.units_sold = 2;
item2.revenue = 70;
cout << item2.avg_price() << endl;
if (item1.same_isbn(item2))
cout << "这两个sales_item是同一种书" << endl;
else
cout << "这两个sales_item不是同一种书" << endl;
return 0;
}