- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我有一个相当大的程序,但有一个小的内存问题。代码按预期运行,我得到了我想要的结果,但我想摆脱损坏。我运行了 valgrind,但我并不真正理解错误。
内容如下:
==11295==
==11295== HEAP SUMMARY:
==11295== in use at exit: 72,704 bytes in 2 blocks
==11295== total heap usage: 19,836 allocs, 19,834 frees, 1,247,711 bytes allocated
==11295==
==11295== 0 bytes in 1 blocks are definitely lost in loss record 1 of 2
==11295== at 0x4C2E80F: operator new[](unsigned long) (in /usr/lib/valgrind/vgpreload_memcheck-amd64-linux.so)
==11295== by 0x40197C: grid::setSize(int, int) (grid.cpp:75)
==11295== by 0x40B9AC: node::node() (node.cpp:17)
==11295== by 0x4032AF: main (main.cpp:15)
==11295==
==11295== 72,704 bytes in 1 blocks are still reachable in loss record 2 of 2
==11295== at 0x4C2DB8F: malloc (in /usr/lib/valgrind/vgpreload_memcheck-amd64-linux.so)
==11295== by 0x4EC3EFF: ??? (in /usr/lib/x86_64-linux-gnu/libstdc++.so.6.0.21)
==11295== by 0x40104E9: call_init.part.0 (dl-init.c:72)
==11295== by 0x40105FA: call_init (dl-init.c:30)
==11295== by 0x40105FA: _dl_init (dl-init.c:120)
==11295== by 0x4000CF9: ??? (in /lib/x86_64-linux-gnu/ld-2.23.so)
==11295==
==11295== LEAK SUMMARY:
==11295== definitely lost: 0 bytes in 1 blocks
==11295== indirectly lost: 0 bytes in 0 blocks
==11295== possibly lost: 0 bytes in 0 blocks
==11295== still reachable: 72,704 bytes in 1 blocks
==11295== suppressed: 0 bytes in 0 blocks
==11295==
==11295== For counts of detected and suppressed errors, rerun with: -v
==11295== ERROR SUMMARY: 1 errors from 1 contexts (suppressed: 1 from 1)
我知道我创建的唯一指针是在 grid.setSize() 函数中,但这些都应该由析构函数处理。此外,第一个 valgrind block 表示丢失了 0 个字节。
我感到困惑的是第二个街区。我没有在任何地方使用过 malloc,我真的不知道这个 block 需要我做什么。
感谢任何帮助!
根据要求,这里是一些代码。
网格.cpp
#include <iostream>
#include <cstdlib>
#include <cstddef>
#include "grid.h"
using namespace std;
// initializes the double pointer
grid::grid()
{
m_grid = NULL;
}
// destroys the 2D game array
grid::~grid()
{
for (int i = 0; i < m_width; i++)
{
delete[] m_grid[i];
}
delete[] m_grid;
}
cell** grid::getGrid()
{
return m_grid;
}
// returns width
int grid::getWidth()
{
return m_width;
}
// returns height
int grid::getHeight()
{
return m_height;
}
// returns radiation level of specified cell
int grid::getCellRad(const int x, const int y) const
{
return m_grid[x][y].m_rad;
}
int grid::getXRad() const
{
return m_x_rad;
}
int grid::getYRad() const
{
return m_y_rad;
}
// clears grid pointer
void grid::setGridNull()
{
m_grid = NULL;
}
// creates a grid of size width * height and makes all cells unoccupied
void grid::setSize(const int grid_width, const int grid_height)
{
m_width = grid_width;
m_height = grid_height;
m_grid = new cell* [m_width];
// from left to right
for (int i = 0; i < m_width; i++)
{
m_grid[i] = new cell [m_height];
// from top to bottom
for (int j = 0; j < m_height; j++)
{
m_grid[i][j].m_occupied = 0;
}
}
}
// calculates radiation value for all cells in the grid
void grid::setRadiation(const int x_coord, const int y_coord,
const int rad_mag, const int decay_factor)
{
m_x_rad = x_coord;
m_y_rad = y_coord;
// from left to right
for (int i = 0; i < m_width; i++)
{
// from top to bottom
for (int j = 0; j < m_height; j++)
{
// radiation (equals) max radiation (minus)
// Manhattan distance between source and current (times) decay factor
m_grid[i][j].m_rad = rad_mag -
(abs(m_x_rad - i) + abs(m_y_rad - j)) * decay_factor;
// minimum radiation
if (m_grid[i][j].m_rad < 1)
m_grid[i][j].m_rad = 1;
}
}
return;
}
// makes a specified cell unavailable
void grid::setOccupied(const int x, const int y)
{
m_grid[x][y].m_occupied = 1;
return;
}
// makes a specified cell available
void grid::setUnoccupied(const int x, const int y)
{
m_grid[x][y].m_occupied = 0;
return;
}
grid& grid::operator=(const grid& g)
{
m_x_rad = g.m_x_rad;
m_y_rad = g.m_y_rad;
m_width = g.m_width;
m_height = g.m_height;
m_grid = new cell* [m_width];
// from left to right
for (int i = 0; i < m_width; i++)
{
m_grid[i] = new cell [m_height];
// from top to bottom
for (int j = 0; j < m_height; j++)
{
m_grid[i][j].m_occupied = g.m_grid[i][j].m_occupied;
m_grid[i][j].m_rad = g.m_grid[i][j].m_rad;
}
}
return *this;
}
// checks whether specified cell is available
bool grid::isAvailable(const int x, const int y) const
{
return !(m_grid[x][y].m_occupied);
}
// displays a map of available/unavailable cells
void grid::printOccupied() const
{
cout << "--------------------Occupied\n";
// from top to bottom
for (int i = 0; i < m_height; i++)
{
// from left to right
for (int j = 0; j < m_width; j++)
{
cout << (m_grid[j][i].m_occupied ? "1" : "0") << " ";
}
cout << "\n";
}
}
// displays a map of every cell's radiation level
void grid::printRadiation() const
{
cout << "--------------------Radiation\n";
// from top to bottom
for (int i = 0; i < m_height; i++)
{
// from left to right
for (int j = 0; j < m_width; j++)
{
cout << m_grid[j][i].m_rad
<< (m_grid[j][i].m_rad >= DOUBLE_DIGIT ? " " : " ");
}
cout << "\n";
}
}
主要.cpp
#include "main.h"
using namespace std;
int main()
{
clock_t start = clock();
double duration;
queue<node> frontier;
node root; // node that grabs initial puzzle state
unordered_map<int, basic_node> node_map;
int grid_width, grid_height, x_coord, y_coord, rad_mag, decay_factor,
num_alligators, num_turtles, num_trees;
string orientation;
root.setNumItems(VECTOR_SHIFT + num_alligators + num_turtles + num_trees);
if (!getInitialPuzzle(root.getGrid(), root.getItems(),
grid_width, grid_height, rad_mag, decay_factor,
num_alligators, num_turtles, num_trees,
x_coord, y_coord, orientation))
{
return -1;
}
frontier.push(node(root));
breadthFirstTreeSearch(frontier, node_map, num_alligators, num_trees);
// put the root in the hash table
basic_node r;
r.node_id = frontier.back().getID();
r.node_parent = -1;
r.node_cost = frontier.back().getItems()[1]. // only the boat has a cost
calcItemCost(frontier.back().getGrid());
// no action taken to get here
r.node_action_item = '\0';
r.node_action_number = 0;
r.node_action_move = '\0';
node_map.insert({r.node_id, r});
int j = 0;
while (!frontier.empty())
{
++j;
if (frontier.front().isGoal())
break;
// only need to check boat, alligators, and turtles
for (int i = 1; i < frontier.front().getItems().size() - num_trees; i++)
{
// only the boat can rotate
if (i == 1)
{
// if the boat can rotate ccw in its own grid
if (frontier.front().getItems()[i].
canRotateCCW(frontier.front().getGrid()))
{
// enqueue a copy of the current node and rotate that boat ccw
frontier.push(frontier.front());
frontier.back().getItems()[i].rotateCCW(frontier.back().getGrid());
basic_node b;
b.node_id = frontier.back().getID();
b.node_parent = frontier.back().getParent();
b.node_cost = frontier.back().getItems()[1].
calcItemCost(frontier.back().getGrid());
b.node_action_item = frontier.back().getItems()[1].getType();
b.node_action_number = 0; // there's only one boat
b.node_action_move = 'N'; // counterclockwise
node_map.insert({b.node_id, b});
}
// if the boat can rotate cw in its own grid
if (frontier.front().getItems()[i].
canRotateCW(frontier.front().getGrid()))
{
// enqueue a copy of the current node and rotate that boat cw
frontier.push(frontier.front());
frontier.back().getItems()[i].rotateCW(frontier.back().getGrid());
basic_node b;
b.node_id = frontier.back().getID();
b.node_parent = frontier.back().getParent();
b.node_cost = frontier.back().getItems()[1].
calcItemCost(frontier.back().getGrid());
b.node_action_item = frontier.back().getItems()[1].getType();
b.node_action_number = 0; // there's only one boat
b.node_action_move = 'C'; // clockwise
node_map.insert({b.node_id, b});
}
}
// if the boat, alligator, or turtle can move forward
if (frontier.front().getItems()[i].
canMoveForward(frontier.front().getGrid()))
{
// enqueue a copy of the current node and move the item forward
frontier.push(frontier.front());
frontier.back().getItems()[i].moveForward(frontier.back().getGrid());
basic_node b;
b.node_id = frontier.back().getID();
b.node_parent = frontier.back().getParent();
b.node_cost = frontier.back().getItems()[1].
calcItemCost(frontier.back().getGrid());
// gets B, A, or T for the item that moves
b.node_action_item = frontier.back().getItems()[i].getType();
// need to shift for boat and goal, and alligator if necessary
b.node_action_number = i -
(b.node_action_item == 'B' ? 1 : VECTOR_SHIFT) - // shift 1 if boat
(b.node_action_item == 'A' ? 0 : num_alligators);
// this will get the movement; one of {U, D, L, R}
b.node_action_move = (frontier.back().getItems()[i].getOrientation());
node_map.insert({b.node_id, b});
}
// if the alligator or turtle can move backward
if (frontier.front().getItems()[i].
canMoveBackward(frontier.front().getGrid()))
{
// enqueue a copy of the current node and move the item forward
frontier.push(frontier.front());
frontier.back().getItems()[i].moveBackward(frontier.back().getGrid());
basic_node b;
b.node_id = frontier.back().getID();
b.node_parent = frontier.back().getParent();
b.node_cost = frontier.back().getItems()[1].
calcItemCost(frontier.back().getGrid());
// gets A or T for the item that moves
b.node_action_item = frontier.back().getItems()[i].getType();
// need to shift for boat and goal, and alligator if necessary
b.node_action_number = i - VECTOR_SHIFT -
(b.node_action_item == 'A' ? 0 : num_alligators);
// this will get the movement; one of {U, D, L, R}
b.node_action_move = (frontier.back().getItems()[i].getOrientation());
// this will get the movement; one of {U, D, L, R}
switch (frontier.back().getItems()[i].getOrientation())
{
case 'L':
b.node_action_move = 'R';
break;
case 'R':
b.node_action_move = 'L';
break;
case 'U':
b.node_action_move = 'D';
break;
case 'D':
b.node_action_move = 'U';
break;
}
node_map.insert({b.node_id, b});
}
}
// all possible moves completed for the current state of the board
frontier.pop();
}
root.getGrid().printOccupied();
cout << endl;
frontier.front().getGrid().printRadiation();
duration = double(clock() - start) / CLOCKS_PER_MS;
writeSolutions(duration, frontier.front(), node_map, rad_mag, decay_factor,
num_alligators, num_turtles, num_trees);
return 0;
}
和 node.cpp
#include <cstddef>
#include <iostream>
#include "node.h"
int node::class_id = 0;
int node::num_items = 0;
node::node()
{
m_grid.setGridNull();
m_grid.setSize(0, 0);
m_grid.setRadiation(0, 0, 0, 0);
m_id = 0;
m_parent = 0;
}
node::node(const node& n)
{
m_grid = n.m_grid;
m_items = n.m_items;
m_id = ++class_id;
m_parent = n.m_id;
/*for (int i = 0; i < n.getNumItems(); i++)
{
m_items[i] = n.m_items[i];
}*/
}
int node::getNumItems() const
{
return num_items;
}
grid& node::getGrid()
{
return m_grid;
}
vector<item>& node::getItems()
{
return m_items;
}
int node::getID() const
{
return m_id;
}
int node::getParent() const
{
return m_parent;
}
void node::setNumItems(const int n)
{
num_items = n;
return;
}
void node::setID(const int i)
{
m_id = i;
return;
}
void node::setParent(const int p)
{
m_parent = p;
return;
}
node& node::operator=(node& n)
{
m_grid = n.m_grid;
m_parent = n.m_parent;
m_id = ++class_id;
for (int i = 0; i < n.getItems().size(); i++)
{
cout << "yo\n";
m_items[i] = n.m_items[i];
cout << "hey\n";
}
return *this;
}
// this will compare the boat and goal locations to determine goal node
bool node::isGoal() const
{
bool found = false;
// if we don't have 2+, we don't have a goal and a boat
if (m_items.size() >= 2)
{
// item 1 is the boat
// back of the boat is in the goal
if ((m_items[1].getXCoord() == m_items[0].getXCoord()) &&
m_items[1].getYCoord() == m_items[0].getYCoord())
{
found = true;
}
else
{
switch (m_items[1].getOrientation())
{
case 'R':
if ((m_items[1].getXCoord() == m_items[0].getXCoord() - 1) &&
m_items[1].getYCoord() == m_items[0].getYCoord())
{
found = true;
}
break;
case 'U':
if ((m_items[1].getXCoord() == m_items[0].getXCoord()) &&
m_items[1].getYCoord() == m_items[0].getYCoord() + 1)
{
found = true;
}
break;
case 'L':
if ((m_items[1].getXCoord() == m_items[0].getXCoord() + 1) &&
m_items[1].getYCoord() == m_items[0].getYCoord())
{
found = true;
}
break;
case 'D':
if ((m_items[1].getXCoord() == m_items[0].getXCoord()) &&
m_items[1].getYCoord() == m_items[0].getYCoord() - 1)
{
found = true;
}
break;
}
}
}
return found;
}
最佳答案
线索是栈帧中的_dl_init
。这是共享库的初始化函数。任何时候加载共享库时,它的初始化函数都会运行。有问题的内存块是在共享库的初始化函数中分配的。
共享库在其初始化函数中为其内部数据结构分配内存是很常见的。这是 C++ 运行时库,预计将在进程的生命周期内保持加载状态。因此,这并不是真正的内存泄漏,特别是因为“可能丢失”的指示表明 valgrind 设法在某处找到了指向内存块的指针。
但是,您自己的代码中确实存在内存泄漏。 “肯定输了”就是这个意思:肯定输了。你的类泄漏了内存,而 valgrind 没有找到任何指向它的悬挂指针,否则它会属于“可能丢失”类别。
关于c++ - Valgrind 说 malloc 内存损坏,还没有使用 malloc,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/41916853/
#include using namespace std; class C{ private: int value; public: C(){ value = 0;
这个问题已经有答案了: What is the difference between char a[] = ?string?; and char *p = ?string?;? (8 个回答) 已关闭
关闭。此题需要details or clarity 。目前不接受答案。 想要改进这个问题吗?通过 editing this post 添加详细信息并澄清问题. 已关闭 7 年前。 此帖子已于 8 个月
除了调试之外,是否有任何针对 c、c++ 或 c# 的测试工具,其工作原理类似于将独立函数复制粘贴到某个文本框,然后在其他文本框中输入参数? 最佳答案 也许您会考虑单元测试。我推荐你谷歌测试和谷歌模拟
我想在第二台显示器中移动一个窗口 (HWND)。问题是我尝试了很多方法,例如将分辨率加倍或输入负值,但它永远无法将窗口放在我的第二台显示器上。 关于如何在 C/C++/c# 中执行此操作的任何线索 最
我正在寻找 C/C++/C## 中不同类型 DES 的现有实现。我的运行平台是Windows XP/Vista/7。 我正在尝试编写一个 C# 程序,它将使用 DES 算法进行加密和解密。我需要一些实
很难说出这里要问什么。这个问题模棱两可、含糊不清、不完整、过于宽泛或夸夸其谈,无法以目前的形式得到合理的回答。如需帮助澄清此问题以便重新打开,visit the help center . 关闭 1
有没有办法强制将另一个 窗口置于顶部? 不是应用程序的窗口,而是另一个已经在系统上运行的窗口。 (Windows, C/C++/C#) 最佳答案 SetWindowPos(that_window_ha
假设您可以在 C/C++ 或 Csharp 之间做出选择,并且您打算在 Windows 和 Linux 服务器上运行同一服务器的多个实例,那么构建套接字服务器应用程序的最明智选择是什么? 最佳答案 如
你们能告诉我它们之间的区别吗? 顺便问一下,有什么叫C++库或C库的吗? 最佳答案 C++ 标准库 和 C 标准库 是 C++ 和 C 标准定义的库,提供给 C++ 和 C 程序使用。那是那些词的共同
下面的测试代码,我将输出信息放在注释中。我使用的是 gcc 4.8.5 和 Centos 7.2。 #include #include class C { public:
很难说出这里问的是什么。这个问题是含糊的、模糊的、不完整的、过于宽泛的或修辞性的,无法以目前的形式得到合理的回答。如需帮助澄清此问题以便重新打开它,visit the help center 。 已关
我的客户将使用名为 annoucement 的结构/类与客户通信。我想我会用 C++ 编写服务器。会有很多不同的类继承annoucement。我的问题是通过网络将这些类发送给客户端 我想也许我应该使用
我在 C# 中有以下函数: public Matrix ConcatDescriptors(IList> descriptors) { int cols = descriptors[0].Co
我有一个项目要编写一个函数来对某些数据执行某些操作。我可以用 C/C++ 编写代码,但我不想与雇主共享该函数的代码。相反,我只想让他有权在他自己的代码中调用该函数。是否可以?我想到了这两种方法 - 在
我使用的是编写糟糕的第 3 方 (C/C++) Api。我从托管代码(C++/CLI)中使用它。有时会出现“访问冲突错误”。这使整个应用程序崩溃。我知道我无法处理这些错误[如果指针访问非法内存位置等,
关闭。这个问题不符合Stack Overflow guidelines .它目前不接受答案。 我们不允许提问寻求书籍、工具、软件库等的推荐。您可以编辑问题,以便用事实和引用来回答。 关闭 7 年前。
已关闭。此问题不符合Stack Overflow guidelines 。目前不接受答案。 要求我们推荐或查找工具、库或最喜欢的场外资源的问题对于 Stack Overflow 来说是偏离主题的,因为
我有一些 C 代码,将使用 P/Invoke 从 C# 调用。我正在尝试为这个 C 函数定义一个 C# 等效项。 SomeData* DoSomething(); struct SomeData {
这个问题已经有答案了: Why are these constructs using pre and post-increment undefined behavior? (14 个回答) 已关闭 6
我是一名优秀的程序员,十分优秀!