这个问题试图收集每年出版的数十本不良C++书籍中的少数珍珠.
与许多其他编程语言不同,这些编程语言经常从互联网上的教程中随处获取,很少有人能够快速学习C++,而无需学习编写精良的C++书籍.这样做太复杂了.事实上,它是如此庞大和复杂,有很多非常糟糕的C++书籍.我们并不是在谈论糟糕的风格,而是体育明显的事实错误和促进糟糕的编程风格.
请编辑接受的答案,以提供高质量的书籍和近似的技能水平 - 最好 在 C++聊天室讨论您的添加后.(如果他们不同意建议,常客可能会毫不留情地撤销你的工作.)添加一篇关于你亲自阅读/受益的每本书的简短描述/描述.随意讨论质量,标题等.符合标准的书籍将被添加到列表中.由C和C++用户协会(ACCU)撰写评论的图书都有指向评论的链接.
*注意:常见问题和其他资源可以在C++标签信息和c ++ - faq中找到.
我有一个C++程序,它将读取二进制文件中的数据,最初我存储了数据std::vector<char*> data.我已经改变了我的代码,所以我现在使用字符串而不是char*,所以std::vector<std::string> data.一些变化,我不得不做出是从改变strcmp到compare的例子.
但是我看到我的执行时间急剧增加.对于示例文件,当我使用char*时需要0.38s,在转换为字符串后,我的Linux机器上花了1.72s.我在Windows机器上观察到类似的问题,执行时间从0.59s增加到1.05s.
我相信这个功能导致速度减慢.它是转换器类的一部分,请注意_在变量名末尾指定的私有变量.我显然在这里遇到了内存问题,并且陷入了C和C++代码之间.我希望这是C++代码,所以我更新了底部的代码.
我访问ids_并names_多次在其他功能了,所以访问速度是非常重要的.通过使用创建map而不是两个单独的向量,我已经能够使用更稳定的C++代码实现更快的速度.谢谢大家!
2515 ABC 23.5 32 -99 1875.7 1
1676 XYZ 12.5 31 -97 530.82 2
279 FOO 45.5 31 -96 530.8 3
Run Code Online (Sandbox Code Playgroud)
void converter::updateNewList(){
FILE* NewList;
char lineBuffer[100];
char* id = 0;
char* name = 0;
int l = 0;
int n;
NewList = fopen("NewList.txt","r");
if (NewList == NULL){
std::cerr << "Error in reading NewList.txt\n"; …Run Code Online (Sandbox Code Playgroud)