1
#include<iostream.h>
#include<conio.h>

typedef ostream& (*T)(ostream& , int);
class Base
{
    T fun;
    int  var;
    public:
    Base(T func, int arg): fun(func) , var(arg)
    {};
    friend ostream& operator<<(ostream& o, Base& obj)
    {
        return obj.fun(o,obj.var);
    }
};

ostream& odisp(ostream& o, int i);
{
    o<<”i=”&lt;<i<<endl;
    return o;
}
Base disp(int i)
{
    return base(odisp, i)
};

从第一行开始我就完全卡住了,因为我无法弄清楚这个 typedef 是如何工作的。它看起来像一个指向函数语法的指针,但 ostream 又让我感到困惑..??请解释一下整个代码是如何工作的..??

4

1 回答 1

5
#include <iostream.h>
#include <conio.h>

正如已经指出的那样,iostream.h并且conio.h不是 C++ 程序的标准头文件。IO 流库的正确标头包含语句是#include <iostream>,不带扩展名。

typedef ostream& (*T)(ostream& , int);

这将创建一个typedefnamed T,它是一个指向具有以下属性的函数的指针:

  • 返回对的引用ostream
  • 接受两个参数,顺序如下:
    • 一个参考ostream
    • int价值

ostream,假设它指的是std::ostream,它本身就是 的一个typedefstd::basic_ostream它可以在 C++ 标准库中找到。它被定义为:

namespace std {
    typedef basic_ostream<char> ostream;
}

对象std::cout是 的实例std::ostream

class Base
{
    T fun; // (1)
    int var; // (2)
public:
    Base(T func, int arg): fun(func) , var(arg) {}; // (3)

    friend ostream& operator<<(ostream& o, Base& obj) // (4)
    {
        return obj.fun(o, obj.var);
    }
};

这是一个包含两件事的类:(1) 指向上述函数的指针和 (2) 整数。构造函数 (3) 允许该类的用户使用函数指针和整数对其进行实例化。

友元函数声明 (4) 重载了左移位运算符<<。这种重载称为运算符重载。按照约定,操作<<符在 IO 流的上下文中也称为流插入操作符。

请注意,以这种方式定义的友元函数实际上不是 的成员Base,因此不接收this指针(因此需要单独的Base&参数)。

ostream& odisp(ostream& o, int i);
{
    o << "i=" << i << endl;
    return o;
}

这是一个名为 的函数odisp。它接受对一个ostream和一个整数的引用。如果你传入整数 42,它会以这种形式打印出传入的整数:

我=42

Base disp(int i)
{
    return base(odisp, i)
};

此函数有多个语法错误,不会按原样运行:

  • base可能是Base. 在这种情况下,它将构造一个Base临时的并返回它。
  • 少了一个分号。

这些问题对语言来说有些基础。您可能想选择一本很好的介绍性 C++ 书籍来涵盖这些问题。

于 2013-01-06T08:38:56.290 回答