带有const数组和initializer_list

时间:2017-08-19 13:26:53

标签: c++ arrays c++11 initializer-list

我有一个类,它将引脚的“列表”作为构造函数中的参数。 现在,这个“列表”只是一个const数组(const unsigned int (&pins)[N])。 我想以这样的方式重载构造函数,即你可以使用initializer_list和(const)数组。
我可以让它使用不同的类,但我无法将它们组合起来。

我的测试类的基本结构:

#include <iostream>
#include <cstring>
using namespace std;

class X
{
  public:
    X(... pins);
    ~X();
    void print() {
        for (unsigned int i = 0; i < length; i++)
            cout << pins[i] << ' ';
    }

  private:
    (const) unsigned int *pins;
    const size_t length;
};

A类(使用std :: initializer_list)

  public:   
    A(initializer_list<unsigned int> pins)
        : length(pins.size()) {
        this->pins = (unsigned int *)malloc(sizeof(unsigned int) * pins.size());
        memcpy(this->pins, pins.begin(), sizeof(unsigned int) * pins.size());
    }
    ~A() {
        free(pins);
    }
  private:
    unsigned int *pins;

B类(使用数组)

  public:
    template <size_t N>
    B(unsigned int (&pins)[N])
        : length(N) {
        this->pins = pins;
    }
  private:
    unsigned int *pins;

C类(使用const数组)

  public:
    template <size_t N>
    C(const unsigned int (&pins)[N])
        : length(N) {
        this->pins = pins;
    }
  private:
    const unsigned int *pins;

这允许我做以下事情:

A a({1, 2, 3});

unsigned int pb[] = {4, 5, 6};
B b(pb);

const unsigned int pc[] = {7, 8, 9};
C c(pc);

a.print();
b.print();
c.print();

这会按预期打印1 2 3 4 5 6 7 8 9

如何在一个类中组合这些不同的构造函数? 我希望能够以上面显示的三种方式中的任何一种初始化对象。

如果我将pins设为const,我就无法执行memcpy(pins, ...)之类的操作,如果我不将其设为const,我就不能使用const数组作为构造函数的参数。

(目标平台是Arduino,因此不支持大多数花哨且内存密集的C ++ 11技巧。)

1 个答案:

答案 0 :(得分:1)

这些方面的一些东西,也许是:

class X
{
  public:
    X(std::initializer_list<unsigned int> aPins)
        : storage(aPins), length(aPins.size()) {
      pins = length ? &storage[0] : nullptr;
    }

    template <size_t N>
    X(unsigned int (&aPins)[N])
        : length(N) {
        pins = aPins;
    }

    template <size_t N>
    X(const unsigned int (&aPins)[N])
        : length(N) {
        pins = aPins;
    }

    void print() {
        for (unsigned int i = 0; i < length; i++)
            std::cout << pins[i] << ' ';
    }

  private:
    const unsigned int* pins;
    const size_t length;
    std::vector<unsigned int> storage;
};

Demo