这个 typedef 语法是如何工作的..

how does this typedef syntax works..?

本文关键字:工作 何工作 typedef 语法 这个      更新时间:2023-10-16
#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=”<<i<<endl;
    return o;
}
Base disp(int i)
{
    return base(odisp, i)
};

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

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

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

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

这将创建一个名为 Ttypedef,该指向具有以下属性的函数:

  • 返回对ostream的引用
  • 按此顺序接受两个参数:
    • ostream的引用
    • int

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

namespace std {
    typedef basic_ostream<char> ostream;
}

对象std::coutstd::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,它将以以下形式打印出传入的整数:

i=42

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

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

  • base可能意味着Base .在这种情况下,它将构造一个临时Base并将其返回。
  • 缺少分号。

这些问题在某种程度上是语言的基础。你可能想拿一本好的介绍性C++书来涵盖这些问题。