泛型编程中的Concept, Model和Policy

A crude explanation

Concept

A set of requirements on a type, e.g. a RandomAccessible concept requires the type implements:operator[] (int) in O(1) time.

Model

When a type meet a concept, it's a model of that concept.

Policy

A unit of behaviour, which can combine with other units of behaviour to build complex classes. For illustration:

template<class T, class StoragePolicy>
class array : public StoragePolicy {
    public:
        T& operator[](int i) { return data[i]; };
};

// policy 1
template <class T, int N>
class fixed_storage {
    T data[N];
};

// policy 2
template<class T>
class dynamic_storage{
    T* data;
    public:
        void push_back(const T& val) {
            // code for dynamic array insertationk
        }
};

usage of policy:

int main(){
    array<int, fixed_storage<int, 10>> fixed_array;
    array<int, dynamic_storage<int>> dynamic_array;
}

Reference

More

posted @ 2014-12-18 23:16  n0p  阅读(387)  评论(0编辑  收藏  举报