欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页

C++程序设计兼谈对象模型(侯捷)——课程笔记(一)

程序员文章站 2022-04-27 10:20:25
...

本篇包含内容为转换函数(conversion)以及non-explicit one argument constructor。注意这里的one argument指的是“一个实参”就可以,而不一定只能是一个实参,比如说下文的实例构造函数里就包含一个默认实参。

一、转换函数

class Fraction
{
public:
    Fraction(int num, int den=1)
        : m_numerator(num), m_denominator(den) { }
    operator double() const{
        return (m_numerator / (double)m_denominator);
    }

private:
    int m_numerator;
    int m_denominator;
};

...
Fraction f(3, 5);
double d = 4 + f; //调用operator double()将f转为0.6

如上文实例所示,形如operator double()的东西就叫做转换函数,可以将一个类的对象转换为相应的类型(问题:转换函数支持哪些类型?)。 注意转换函数不需要声明返回类型,但是有返回值;转换函数必须是类的成员函数;转换函数没有参数。

另外,转换函数前面也可以加explicit关键字禁止隐式转换。

二、non-explicit-one-argument constructor

class Fraction
{
public:
    Fraction(int num, int den=1)
        : m_numerator(num), m_denominator(den) { }
    
    Fraction operator+(const Fraction& f){
        return Fraction(...);
    }
private:
    int m_numerator;
    int m_denominator;
};

...
Fraction f(3, 5);
Fraction d2 = f + 4; //调用non-explicit将4转换为Fraction
                     //然后调用operator+

在构造函数前加关键字explicit可以关闭这种隐式转换,也就是只允许显示转换

三、标准库中转换函数的例子

template <class Alloc>
class vector<bool, Alloc>//模板偏特化,以后会讲
{
public:
    typedef _bit_reference reference;
protected:
    reference operator[] (size_type n){
        return *(begin() + difference_type(n));    
    }
...

struct _bit_reference{
    unsigned int* p;
    unsigned int mask;
    ...
public:
    operator bool() const { return !(!(*p & mask)); }
...

如上面例子所示,_bit_reference里面就有一个转换为bool值的转换函数