表达式_BLOCK_TYPE_IS_VALID(pHead->nBlockUse) 错误
Expression _BLOCK_TYPE_IS_VALID(pHead->nBlockUse) Error
通过引用"_BLOCK_TYPE_IS_VALID(pHead->nBlockUse("添加参数后,调试断言失败。
class Stack
{
private:
const std::uint32_t m_maxElement;
protected:
std::uint32_t m_currentElement;
int *m_tab;
public:
Stack(std::uint32_t p_maxElement);
virtual ~Stack();
void push(int p_element);
std::int32_t pop(void);
std::uint32_t size(void) const;
};
Stack::Stack(std::uint32_t p_maxElement) : m_maxElement(p_maxElement), m_tab(new int[m_maxElement]), m_currentElement(0u)
{}
Stack::~Stack()
{
if (m_tab) delete[] m_tab;
}
void Stack::push(int p_element)
{
if (m_currentElement < m_maxElement)
{
m_tab[m_currentElement] = p_element;
++m_currentElement;
}
}
std::int32_t Stack::pop()
{
if (m_currentElement > 0u)
{
return m_tab[--m_currentElement];
}
}
std::uint32_t Stack::size() const
{
return m_currentElement;
}
/*************************************************************************/
std::int32_t median(Stack p_stack)
{
std::vector<std::int32_t> l_container(p_stack.size());
while (p_stack.size())
{
l_container.push_back(p_stack.pop());
}
std::sort(l_container.begin(), l_container.end());
int l_containerSize = l_container.size();
int l_middleIndex = l_containerSize / 2;
if (l_containerSize % 2 == 0)
{
int l_firstMiddleElement = l_container[l_middleIndex - 1];
int l_secondMiddleElement = l_container[l_middleIndex];
return (l_firstMiddleElement + l_secondMiddleElement) / 2;
}
else
{
return l_container[l_middleIndex];
}
return 0;
}
std::int32_t arithmeticAverage(Stack p_stack)
{
std::int32_t l_sum = 0;
int l_stackSize = p_stack.size();
while (p_stack.size())
{
l_sum = p_stack.pop();
}
return l_sum / l_stackSize;
}
int main()
{
Stack firstStack(10);
firstStack.push(2);
firstStack.push(4);
firstStack.push(8);
std::cout << "firstStack.pop() = " << firstStack.pop() << std::endl;
std::cout << "median(firstStack) = " << median(firstStack) << std::endl
std::cout << "arithmeticAverage(firstStack) = " << arithmeticAverage(firstStack) << std::endl;
return 0;
}
在的情况下
std::int32_t median(Stack &p_stack)
是可以的。而不是std::int32_t中值(堆栈p_Stack(在出现"_BLOCK_TYPE_IS_VALID(pHead->nBlockUse("行之后。
如果median
函数按值取Stack
,编译器必须复制原始Stack
。因为您没有在Stack
中定义复制构造函数,所以编译器生成了自己的复制构造函数,它执行成员复制,这意味着它只复制指针的值,这样Stack
的两个实例现在就指向同一内存位。然后,当median
函数完成执行时,会调用副本的析构函数并删除内存,因此现在主目录中的原始Stack
指向导致错误的已释放块。
当median
引用时,不会进行复制——它会引用main
中的原始Stack
,并且不会调用析构函数。
我建议您更改代码,使median
和其他函数以const
引用Stack
作为参数。
相关文章:
- EASTL矢量<向量<int>>连续的
- C - 创建矢量&lt; vector&lt; double&gt;&gt;矩阵具有分配而不是inizializ
- C 字符串比较“祝您好运”&gt;“再见”
- 为什么将此对向量&lt; map&lt; int,int&gt;&gt;中的地图进行更新.失败
- C :对矢量进行排序&lt; struct&gt;(结构有2个整数)基于结构的整数之一
- C 操作员&gt;&gt;与突变器过载
- 明确的专业化“ CheckIntmap&lt;&gt;”实例化
- 是否需要使用 - &gt;运算符在C 中调用成员函数时
- 什么是模板&lt;&gt;inline bla bla
- 编辑C Qlist&lt; object*&gt; gt;QML代码和一些QML警告中的模型
- eigen :: llt&lt;eigen :: matrixxd&gt;具有不完整的类型
- 错误,包括&lt; ctype&gt;在原子上使用C 11
- 错误c++visual studio c2227左侧'->;Init';必须指向类/结构/联合/泛型类型
- std::vector<;uint8_t>;当C++11/14启用时,手动复制而不是调用memcpy
- ``这个''不能用this-&gt;指针变量
- 如何加入向量&lt; int&gt;到C 中的单个INT
- 是std :: set&lt; std :: future&gt;不可能存在
- 调试断言失败 BLOCK_TYPE_IS_VALID (pHead->nblockuse) 从解构函数
- 使用shared_ptr<字符串>转换为一个无序集合<字符串>
- 是numeric_limits&lt; int&gt; :: is_modulo从逻辑上矛盾