如何计算实例数组中未删除的实例?
how to count not deleted instances in array of instances?
我的代码中有一个实例数组,如下所示:
class Squad : public ISquad
{
public:
Squad(void);
Squad(Squad const & src);
virtual ~Squad(void);
int getCount(void) const;
int push(ISpaceMarine*);
ISpaceMarine* getUnit(int) const;
ISpaceMarine** getUnits(void) const;
int getCapacity(void) const;
Squad & operator=(Squad const & rhs);
private:
ISpaceMarine **_units; // HERE IS THE ARRAY OF INSTANCES
int const _squadCapacity;
};
在构造函数中这样初始化
Squad::Squad(void) : _units(new ISpaceMarine*[64]), _squadCapacity(64)
{
return;
}
首先,这是好方法吗?
如果是,我尝试计算数组中有效实例的数量(不是 NULL
,不是 deleted
)但我不知道如何检查是否 _units[20]
例如被删除。
我该怎么做?
他是我现在的做法:
int Squad::getCount(void) const
{
int count = 0;
while (this->_units[count] != NULL && count < this->_squadCapacity)
count++;
return count;
}
ISpaceMarine **_units; // HERE IS THE ARRAY OF INSTANCES
int const _squadCapacity;
- 首先,这是好的方法吗?
不,这不是一个好的方法,它清楚地展示了为什么 std 容器和智能指针是一个很大的改进。
使用智能指针,您可以自动表达和处理所有权。
我的印象是 Squad
管理 SpaceMarines
,在这种情况下,您应该使用 std::unique_ptr
。你的 Squad
看起来像
class Squad : public ISquad
{
public:
size_t getCount() const;
void push(ISpaceMarine&&);
using SpaceMarineIterator = std::vector<std::unique_ptr<SpaceMarine>>::iterator;
// A typedef/using for this iterator would be appropriate.
SpaceMarineIterator getUnit(int) const;
// And this
SpaceMarineIterator begin() const;
SpaceMarineIterator end() const;
size_t getCapacity() const;
// no need for copy assign either.
//Squad & operator=(Squad const & rhs);
private:
std::vector<std::unique_ptr<ISpaceMarine>> units;
// No need for capacity.
};
现在,如果您需要不同的所有权模型,可以查看 std::shared_ptr
和 std::weak_ptr
。不过,您的模型应该努力使用 std::unique_ptr
。
注意:不要放弃使用
的可能性
std::vector<SpaceMarine> units;
我的代码中有一个实例数组,如下所示:
class Squad : public ISquad
{
public:
Squad(void);
Squad(Squad const & src);
virtual ~Squad(void);
int getCount(void) const;
int push(ISpaceMarine*);
ISpaceMarine* getUnit(int) const;
ISpaceMarine** getUnits(void) const;
int getCapacity(void) const;
Squad & operator=(Squad const & rhs);
private:
ISpaceMarine **_units; // HERE IS THE ARRAY OF INSTANCES
int const _squadCapacity;
};
在构造函数中这样初始化
Squad::Squad(void) : _units(new ISpaceMarine*[64]), _squadCapacity(64)
{
return;
}
首先,这是好方法吗?
如果是,我尝试计算数组中有效实例的数量(不是 NULL
,不是 deleted
)但我不知道如何检查是否 _units[20]
例如被删除。
我该怎么做?
他是我现在的做法:
int Squad::getCount(void) const
{
int count = 0;
while (this->_units[count] != NULL && count < this->_squadCapacity)
count++;
return count;
}
ISpaceMarine **_units; // HERE IS THE ARRAY OF INSTANCES
int const _squadCapacity;
- 首先,这是好的方法吗?
不,这不是一个好的方法,它清楚地展示了为什么 std 容器和智能指针是一个很大的改进。
使用智能指针,您可以自动表达和处理所有权。
我的印象是 Squad
管理 SpaceMarines
,在这种情况下,您应该使用 std::unique_ptr
。你的 Squad
看起来像
class Squad : public ISquad
{
public:
size_t getCount() const;
void push(ISpaceMarine&&);
using SpaceMarineIterator = std::vector<std::unique_ptr<SpaceMarine>>::iterator;
// A typedef/using for this iterator would be appropriate.
SpaceMarineIterator getUnit(int) const;
// And this
SpaceMarineIterator begin() const;
SpaceMarineIterator end() const;
size_t getCapacity() const;
// no need for copy assign either.
//Squad & operator=(Squad const & rhs);
private:
std::vector<std::unique_ptr<ISpaceMarine>> units;
// No need for capacity.
};
现在,如果您需要不同的所有权模型,可以查看 std::shared_ptr
和 std::weak_ptr
。不过,您的模型应该努力使用 std::unique_ptr
。
注意:不要放弃使用
的可能性std::vector<SpaceMarine> units;