35-函数对象分析

35-函数对象分析

客户需求

编写一个函数:

  • 函数可以获得非伯纳骑术列每项的值
  • 每调用一次返回一个值
  • 函数可根据需要重复使用

【范例代码】第一个解决方案

#include <iostream>
#include <string>

using namespace std;

int fib() {
    static int a0 = 0;
    static int a1 = 1;

    int ret = a1;

    a1 = a0 + a1;
    a0 = ret;

    return ret;
}

int main(int argc, const char* argv[]) {
    for (int i = 0; i < 10; i++) {
        cout << fib() << endl;
    }

    cout << endl;

    for (int i = 0; i < 5; i++) {
        cout << fib() << endl;
    }

    return 0;
}

存在的问题

函数一旦开始调用就无法重来:

  • 静态局部变量处于函数内部,外界无法改变
  • 函数为全局函数,是唯一的,无法多次独立使用
  • 无法指定某个具体的数列项作为初始值

解决方案

函数对象:

  • 使用具体的类对象取代函数
  • 该类的对象具备函数调用的行为
  • 构造函数指定具体数列项的起始位置
  • 多个对象相互独立的求解数列项

函数调用操作符(( )):

  • 只能通过类的成员函数重载
  • 可以定义不同参数的多个重载函数

【范例代码】最终的解决方案

#include <iostream>
#include <string>

using namespace std;

class Fib {
    int a0;
    int a1;
public:
    Fib() {
        a0 = 0;
        a1 = 1;
    }

    Fib(int n) {
        a0 = 0;
        a1 = 1;

        for (int i = 2; i <= n; i++) {
            int t = a1;

            a1 = a0 + a1;
            a0 = t;
        }
    }

    int operator () () {
        int ret = a1;

        a1 = a0 + a1;
        a0 = ret;

        return ret;
    }
};

int main(int argc, const char* argv[]) {
    Fib fib;

    for (int i = 0; i < 10; i++) {
        cout << fib() << endl;
    }

    cout << endl;

    for (int i = 0; i < 5; i++) {
        cout << fib() << endl;
    }

    cout << endl;

    Fib fib2(10);

    for (int i = 0; i < 5; i++) {
        cout << fib2() << endl;
    }

    return 0;
}

猜你喜欢

转载自blog.csdn.net/qq_19247455/article/details/80338327