我想在一个类的构造函数中初始化一个(指向一个)map 的指针。我编写的程序可以编译,但由于段错误而在运行时失败。我可以通过为 map 动态分配内存来解决问题,但是 Valgrind 通知我内存泄漏。如何正确初始化类?
举个例子
#include <iostream>
#include <map>
#include <string>
#include <vector>
class MemoryLeak {
public:
MemoryLeak(std::vector<std::string>& inp) {
int i = 0;
std::map<std::string, int>* tmp = new std::map<std::string, int>;
for (std::string& s : inp) {
//(*problem_map)[s] = i++; // Line 12: causes a seg fault
(*tmp)[s] = i++;
}
problem_map = tmp; // Line 15: memory leak
}
std::map<std::string, int>* problem_map;
};
int main() {
std::vector<std::string> input{"a", "b"};
MemoryLeak mem = MemoryLeak(input);
for (auto const& it : *(mem.problem_map)) {
std::cout << it.first << ": " << it.second << "\n";
}
return 0;
}
当我取消注释 第 12 行(并注释掉 第 15 行)时,程序编译但似乎发生内存泄漏。有人可以告诉我我做错了什么吗?更合适的构造函数会是什么样子?
最佳答案
对于段错误:
您的指针 problem_map 在第 12 行未初始化。
这就是段错误的原因。
你不需要 tmp 你可以这样做:
problem_map = new std::map<std::string, int>;
for (std::string& s : inp) {
(*problem_map)[s] = i++;
}
现在对于泄漏,您有两个选择:
1) 添加析构函数、复制构造函数和复制赋值运算符(或删除它们)。见规则 three
class MemoryLeak {
public:
~MemoryLeak() {
delete problem_map;
}
MemoryLeak(const MemoryLeak& ) = delete;
MemoryLeak& operator=(const MemoryLeak& ) = delete;
MemoryLeak(std::vector<std::string>& inp) {
int i = 0;
problem_map = new std::map<std::string, int>;
for (std::string& s : inp) {
(*problem_map)[s] = i++;
}
}
std::map<std::string, int>* problem_map;
};
2) 不存储指针,而是映射
class MemoryLeak {
public:
MemoryLeak(std::vector<std::string>& inp) {
int i = 0;
for (std::string& s : inp) {
problem_map[s] = i++;
}
}
std::map<std::string, int> problem_map;
};
关于c++ - 在类的构造函数中初始化映射时如何避免内存泄漏?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/56090788/
作为我的Rails应用程序的一部分,我编写了一个小导入程序,它从我们的LDAP系统中吸取数据并将其塞入一个用户表中。不幸的是,与LDAP相关的代码在遍历我们的32K用户时泄漏了大量内存,我一直无法弄清楚如何解决这个问题。这个问题似乎在某种程度上与LDAP库有关,因为当我删除对LDAP内容的调用时,内存使用情况会很好地稳定下来。此外,不断增加的对象是Net::BER::BerIdentifiedString和Net::BER::BerIdentifiedArray,它们都是LDAP库的一部分。当我运行导入时,内存使用量最终达到超过1GB的峰值。如果问题存在,我需要找到一些方法来更正我的代
在我的gem中,我需要yaml并且在我的本地计算机上运行良好。但是在将我的gem推送到rubygems.org之后,当我尝试使用我的gem时,我收到一条错误消息=>"uninitializedconstantPsych::Syck(NameError)"谁能帮我解决这个问题?附言RubyVersion=>ruby1.9.2,GemVersion=>1.6.2,Bundlerversion=>1.0.15 最佳答案 经过几个小时的研究,我发现=>“YAML使用未维护的Syck库,而Psych使用现代的LibYAML”因此,为了解决
我的瘦服务器配置了nginx,我的ROR应用程序正在它们上运行。在我发布代码更新时运行thinrestart会给我的应用程序带来一些停机时间。我试图弄清楚如何优雅地重启正在运行的Thin实例,但找不到好的解决方案。有没有人能做到这一点? 最佳答案 #Restartjustthethinserverdescribedbythatconfigsudothin-C/etc/thin/mysite.ymlrestartNginx将继续运行并代理请求。如果您将Nginx设置为使用多个上游服务器,例如server{listen80;server
我想在一个没有Sass引擎的类中使用Sass颜色函数。我已经在项目中使用了sassgem,所以我认为搭载会像以下一样简单:classRectangleincludeSass::Script::FunctionsdefcolorSass::Script::Color.new([0x82,0x39,0x06])enddefrender#hamlengineexecutedwithcontextofself#sothatwithintemlateicouldcall#%stop{offset:'0%',stop:{color:lighten(color)}}endend更新:参见上面的#re
我在Rails工作并有以下类(class):classPlayer当我运行时bundleexecrailsconsole然后尝试:a=Player.new("me",5.0,"UCLA")我回来了:=>#我不知道为什么Player对象不会在这里初始化。关于可能导致此问题的操作/解释的任何建议?谢谢,马里奥格 最佳答案 havenoideawhythePlayerobjectwouldn'tbeinitializedhere它没有初始化很简单,因为你还没有初始化它!您已经覆盖了ActiveRecord::Base初始化方法,但您没有调
我正在尝试用ruby中的gsub函数替换字符串中的某些单词,但有时效果很好,在某些情况下会出现此错误?这种格式有什么问题吗NoMethodError(undefinedmethod`gsub!'fornil:NilClass):模型.rbclassTest"replacethisID1",WAY=>"replacethisID2andID3",DELTA=>"replacethisID4"}end另一个模型.rbclassCheck 最佳答案 啊,我找到了!gsub!是一个非常奇怪的方法。首先,它替换了字符串,所以它实际上修改了
我有一些代码在几个不同的位置之一运行:作为具有调试输出的命令行工具,作为不接受任何输出的更大程序的一部分,以及在Rails环境中。有时我需要根据代码的位置对代码进行细微的更改,我意识到以下样式似乎可行:print"Testingnestedfunctionsdefined\n"CLI=trueifCLIdeftest_printprint"CommandLineVersion\n"endelsedeftest_printprint"ReleaseVersion\n"endendtest_print()这导致:TestingnestedfunctionsdefinedCommandLin
ruby如何管理内存。例如:如果我们在执行过程中采用C程序,则以下是内存模型。类似于这个ruby如何处理内存。C:__________________|||stack|||------------------||||------------------|||||Heap|||||__________________|||data|__________________|text|__________________Ruby:? 最佳答案 Ruby中没有“内存”这样的东西。Class#allocate分配一个对象并返回该对象。这就是程序
我有用于控制用户任务的Rails5API项目,我有以下错误,但并非总是针对相同的Controller和路由。ActionController::RoutingError:uninitializedconstantApi::V1::ApiController我向您描述了一些我的项目,以更详细地解释错误。应用结构路线scopemodule:'api'donamespace:v1do#=>Loginroutesscopemodule:'login'domatch'login',to:'sessions#login',as:'login',via::postend#=>Teamroutessc
我正在阅读一本关于Ruby的书,作者在编写类初始化定义时使用的形式与他在本书前几节中使用的形式略有不同。它看起来像这样:classTicketattr_accessor:venue,:datedefinitialize(venue,date)self.venue=venueself.date=dateendend在本书的前几节中,它的定义如下:classTicketattr_accessor:venue,:datedefinitialize(venue,date)@venue=venue@date=dateendend在第一个示例中使用setter方法与在第二个示例中使用实例变量之间是