#include <iostream.h>
#include <conio.h>
正如已经指出的那样,iostream.h
并且conio.h
不是 C++ 程序的标准头文件。IO 流库的正确标头包含语句是#include <iostream>
,不带扩展名。
typedef ostream& (*T)(ostream& , int);
这将创建一个typedef
named T
,它是一个指向具有以下属性的函数的指针:
- 返回对的引用
ostream
- 接受两个参数,顺序如下:
ostream
,假设它指的是std::ostream
,它本身就是 的一个typedef
,std::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++ 书籍来涵盖这些问题。