19 如何描述在Linux上运行的C ++代码? 我有一个正在Linux上运行的C ++应用程序,我正在对其进行优化。如何确定我的代码哪些区域运行缓慢? 1815 c++ linux profiling
17 为什么只能在头文件中实现模板? 引用来自C ++标准库:教程和手册: 目前使用模板的唯一可移植方法是通过使用内联函数在头文件中实现它们。 为什么是这样? (澄清:头文件不是唯一的可移植解决方案。但是它们是最方便的可移植解决方案。) 1775 c++ templates c++-faq
12 什么是移动语义? 我刚刚结束了对Scott Meyers进行的有关C ++ 0x的Software Engineering广播播客采访。大多数新功能对我来说都是有意义的,除了一个功能,我现在对C ++ 0x感到非常兴奋。我仍然没有移动语义 ……这到底是什么? 1700 c++ c++-faq c++11 move-semantics
24 图像处理:“可口可乐”识别的算法改进 我过去几年中最有趣的项目之一是关于图像处理的项目。目的是开发一个能够识别可口可乐“罐头”的系统(请注意,我强调的是“罐头”一词,稍后您会看到原因)。您可以在下面看到一个示例,该示例在带有刻度和旋转的绿色矩形中可以识别。 对项目的一些限制: 背景可能非常嘈杂。 该罐可以具有任何规模或旋转,甚至方向(在合理的限度内)。 图像可能有一定程度的模糊性(轮廓可能不完全笔直)。 图像中可能有可口可乐瓶,该算法只能检测到罐头! 图像的亮度可能相差很大(因此您不能“过多”依赖颜色检测)。 该罐可以部分地隐藏在两侧或中间,可能部分地隐藏了一瓶后面。 有可能是没有能在所有的图像中,在这种情况下,你必须找到什么,写一条消息这样说。 因此,您可能会遇到如下棘手的事情(在这种情况下,我的算法完全失败了): 我前一段时间做了这个项目,并且做起来很有趣,并且实现得很好。以下是有关我的实现的一些详细信息: 语言:使用OpenCV库在C ++中完成。 预处理:对于图像预处理,即将图像转换为更原始的形式以提供给算法,我使用了两种方法: 将颜色域从RGB更改为HSV,并基于“红色”色调进行过滤,饱和度高于特定阈值以避免产生类似橙色的颜色,而对低值进行过滤以避免产生深色。最终结果是一个二进制的黑白图像,其中所有白色像素将代表与该阈值匹配的像素。显然,图像中仍然有很多废话,但这减少了必须处理的尺寸数。 使用中值滤波进行噪声滤波(获取所有邻居的中值像素值,然后用该值替换像素)以减少噪声。 经过2个先验步骤后,使用Canny Edge Detection滤镜获取所有项目的轮廓。 算法:我为此任务选择的算法本身取材于这本很棒的书中有关特征提取的书,并称为通用霍夫变换(与常规霍夫变换完全不同)。它基本上说了几件事: 您可以在不知道其解析方程的情况下描述空间物体(此处就是这种情况)。 它可以抵抗缩放和旋转等图像变形,因为它将基本上测试图像的缩放因子和旋转因子的每种组合。 它使用算法将“学习”的基本模型(模板)。 轮廓图像中剩余的每个像素将投票给另一个像素,根据它从模型中学到的信息,该像素应该是对象的中心(就重力而言)。 最后,您将获得投票的热图,例如,此处罐头轮廓的所有像素都将为其重力中心投票,因此在与像素相对应的同一像素中将有很多投票居中,将会在热图中看到一个峰值,如下所示: 有了这些功能后,您就可以使用简单的基于阈值的启发式方法来确定中心像素的位置,从中可以得出比例尺和旋转角度,然后在其周围绘制一个小矩形(最终比例尺和旋转系数显然相对于您的原始模板)。理论上至少... 结果:现在,尽管此方法在基本情况下可行,但在某些领域却严重缺乏: 这是非常慢!我的压力还不够。处理30张测试图像几乎需要整整一天的时间,这显然是因为我对旋转和平移具有非常高的缩放系数,因为某些罐非常小。 当瓶子出现在图像中时,它完全丢失了,并且出于某种原因几乎总是找到瓶子而不是罐子(也许是因为瓶子更大,因此像素更多,投票更多) 模糊图像也不是很好,因为投票最终以像素为中心围绕中心的随机位置,从而以非常嘈杂的热图结束。 实现了平移和旋转的不变性,但没有实现定向,这意味着未识别未直接面对相机物镜的罐子。 您是否可以使用专有的OpenCV功能帮助我改善特定算法,以解决上述四个特定问题? 我希望有些人也能从中学到一些东西,毕竟我认为不仅提出问题的人也应该学习。:) 1657 c++ algorithm image-processing opencv
15 C ++中extern“ C”的作用是什么? extern "C"放入C ++代码到底能做什么? 例如: extern "C" { void foo(); } 1629 c++ c linkage name-mangling extern-c
21 为什么要使用指针而不是对象本身? 我来自Java背景,已经开始使用C ++处理对象。但是我想到的一件事是,人们经常使用指向对象的指针,而不是对象本身,例如以下声明: Object *myObject = new Object; 而不是: Object myObject; 或者,而不是使用函数testFunc(),像这样说: myObject.testFunc(); 我们必须写: myObject->testFunc(); 但是我不知道为什么我们要这样做。我认为这与效率和速度有关,因为我们可以直接访问内存地址。我对吗? 1598 c++ c++11 pointers c++-faq
18 家族树软件中的循环 已锁定。该问题及其答案被锁定,因为该问题是题外话,但具有历史意义。它目前不接受新的答案或互动。 我是一些家谱软件(用C ++和Qt编写)的开发人员。在我的一位客户向我发送错误报告之前,我没有遇到任何问题。问题是该客户有两个孩子,并且有自己的女儿,结果,由于错误,他无法使用我的软件。 这些错误是由于我对要处理的族图的各种断言和不变性导致的(例如,经过一个循环后,程序指出X不能同时是Y的父亲和祖父)。 如何在不删除所有数据断言的情况下解决这些错误? 1594 c++ graph cycle assertions family-tree
14 <快于<=吗? 是if( a < 901 )不是更快if( a <= 900 )。 与这个简单示例并不完全相同,但是循环复杂代码的性能稍有变化。我想这与生成的机器代码有关,以防万一。 1574 c++ performance assembly relational-operators
27 在C ++中将int转换为字符串的最简单方法 从C ++ 转换int为等效的最简单方法是什么string。我知道两种方法。有没有更简单的方法? (1) int a = 10; char *intStr = itoa(a); string str = string(intStr); (2) int a = 10; stringstream ss; ss << a; string str = ss.str(); 1573 c++ string int type-conversion
5 为什么将0.1f更改为0会使性能降低10倍? 为什么这段代码 const float x[16] = { 1.1, 1.2, 1.3, 1.4, 1.5, 1.6, 1.7, 1.8, 1.9, 2.0, 2.1, 2.2, 2.3, 2.4, 2.5, 2.6}; const float z[16] = {1.123, 1.234, 1.345, 156.467, 1.578, 1.689, 1.790, 1.812, 1.923, 2.034, 2.145, 2.256, 2.367, 2.478, 2.589, 2.690}; float y[16]; for (int i = 0; i … 1527 c++ performance visual-studio-2010 compilation floating-point
30 什么是未定义的引用/未解决的外部符号错误,如何解决? Наэтотвопросестьответына 堆栈溢出нарусском:Ссылкананеразрешенныйвнешнийсимвол(возможныепричины) 什么是未定义的参考/未解决的外部符号错误?常见原因是什么?如何解决/预防它们? 随意编辑/添加自己的。 1493 c++ linker-errors undefined-reference c++-faq unresolved-external
17 何时使用虚拟析构函数? 我对大多数面向对象理论有扎实的了解,但令我困惑的一件事是虚拟析构函数。 我以为无论链中的每个对象是什么,析构函数总是被调用。 您打算什么时候将它们虚拟化?为什么? 1485 c++ polymorphism shared-ptr virtual-destructor
9 什么是C ++ 11中的lambda表达式? 什么是C ++ 11中的lambda表达式?我什么时候用一个?在引入之前,他们无法解决什么问题? 一些示例和用例将很有用。 1485 c++ lambda c++11 c++-faq
23 编译用于高放射性环境的应用程序 我们正在编译一个嵌入式C / C ++应用程序,该应用程序部署在受到电离辐射轰击的环境中的屏蔽设备中。我们正在使用GCC并为ARM进行交叉编译。部署后,我们的应用程序会生成一些错误数据,并且崩溃的次数比我们想要的要多。硬件是为此环境设计的,我们的应用程序已在该平台上运行了几年。 我们是否可以对代码进行更改,或者可以进行编译时改进以识别/纠正由单个事件引发的软错误和内存损坏?其他开发人员是否在减少软错误对长期运行的应用程序的有害影响方面取得了成功? 1456 c++ c gcc embedded fault-tolerance