草庐IT

c++ - 使用 <spontaneous> 解释 gprof 输出

我试图在我的程序中找到性能问题,因此通过分析来检测代码。gprof创建一个像这样的平面配置文件:Flatprofile:Eachsamplecountsas0.01seconds.%cumulativeselfselftotaltimesecondssecondscallsms/callms/callname27.974.104.10std::_Deque_iterator::_Deque_iterator(std::_Deque_iteratorconst&)6.965.121.02std::_Deque_iterator::difference_typestd::operator-

c++ - Python 在加载 C++ 编写的扩展模块时收到 SIGSEGV

正确的代码示例:#include"Python.h"#includeexternconstintsomeConstant;voidsome_function(){constchar*begin=NULL;constchar*end=NULL;std::strings(begin,end);constintv=someConstant;}staticPyMethodDef_G_methods[]={{NULL,NULL,0,NULL}/*Sentinel*/};PyMODINIT_FUNCinitsf(){PyObject*module;if(!(module=Py_InitModule

c++ - 全局类型转换运算符重载?

我正在编写一些“可移植”代码(意味着它针对Linux上的32位和64位MSVC2k10和GCC),其中我或多或少有:typedefunsignedcharuint8;C字符串总是uint8;这是出于字符串处理的原因。遗留代码需要将char编译为带符号的,所以我无法将编译器开关设置为默认为无符号。但是如果我正在处理一个字符串,我就不能很好地索引一个数组:charfoo[500];char*ptr=(foo+4);*ptr=some_array_that_normalizes_it[*ptr];你不能在运行时索引一个带有负数的数组而不会有严重的后果。保持C字符串未签名可以更轻松地防止错误。

c++ - ‘const’ 错误之前的预期主表达式

请帮忙。我收到很多错误。sub2.cpp:在函数“intmain()”中:sub2.cpp:11:14:错误:从‘constchar*’到‘char’的无效转换[-fpermissive]sub2.cpp:12:14:错误:从‘constchar*’到‘char’的无效转换[-fpermissive]sub2.cpp:16:17:错误:'const'之前需要主表达式sub2.cpp:16:36:错误:'const'之前需要主表达式sub2.cpp:11:6:警告:未使用的变量“外部”[-Wunused-variable]sub2.cpp:12:6:警告:未使用的变量‘inner’[-W

c++ - 当 vector<char>&& 绑定(bind)到 vector<char>& 时编译器不会报错

我使用的是VisualStudio2013Express。classB{public:vector&a;int&b;B(vector&i,int&c):a(i),b(c){}};intmain(){intl=3;vectorh;shared_ptrbb(newB(std::move(h),l));return0;}为什么代码可以被接受?当我将参数l更改为std::move(l)时,编译器会报错“无法将参数2从'int'转换为'int&'”。 最佳答案 这是VisualC++编译器中可用的语言扩展,现在已经存在了很长一段时间。该扩展允

c++ - 使用对 const char * 的右值引用的重载解析

#includeusingnamespacestd;voidf(constchar*const&s){cout输出:rvaluervalue为什么输出不是“右值左值”? 最佳答案 字符串文字和s都不是指针(它们是数组),因此标准的相关部分是[conv.array]:Anlvalueorrvalueoftype"arrayofNT"or"arrayofunknownboundofT"canbeconvertedtoaprvalueoftype"pointertoT".Theresultisapointertothefirsteleme

c++ - 与 at() 或索引相比,为什么使用 C++ 迭代器会显着增加代码大小?

我一直在考虑在嵌入式系统(16KBSRAM和64KB闪存,CortexM4)上使用更新的C++语言功能,例如迭代器,但遇到了令人惊讶的障碍。为什么迭代器如此庞大?我的印象是它们基本上是一些指针运算或索引。STL是否引入了一些意外代码?这些是在Windows上使用KinetisDesignStudio和来自here的gcc-arm-none-eabi-4_9工具链使用以下标志。arm-none-eabi-g++-mcpu=cortex-m4-mthumb-mfloat-abi=hard-mfpu=fpv4-sp-d16-Os-fmessage-length=0-fsigned-char-

c++ - 列表初始化的 char 数组是否仍然以 null 结尾?

当我阅读LippmanC++Primer(第5版,C++11)时,我遇到了这段代码:charca[]={'C','+','+'};//notnullterminatedcout在ca上调用库strlen函数,它不是以null终止的,会导致未定义的行为。Lippman等人说,“这个调用最可能的效果是strlen将继续查找跟在ca之后的内存,直到它遇到一个空字符。”稍后的练习将询问以下代码的作用:constcharca[]={'h','e','l','l','o'};constchar*cp=ca;while(*cp){cout我的分析:ca是一个非空终止的字符数组。cp是一个指向char

c++ - 带有 const char* 变量的 printf 问题

我陷入了printf问题。如果我能在这里得到一些帮助,我将不胜感激:在下面的代码中,我可以看到字体系列在第一个printf()中被正确置换,但是如果我将它设置为变量,我只会得到一个空字符串。我怎样才能把它放在一个变量中并获得正确的值?我只是不想到处输入“font.family().family().string().utf8().data()”?我用同样的方法做了这个:voidmyMethod(){constchar*fontFamily=font.family().family().string().utf8().data();//getdisplayedcorrectlyprint

C++ 将一个 int 分配给一个 char - 为什么这个工作至少没有警告?

为什么C++(可能还有C)允许我在不给我警告的情况下将和int赋值给char?可以直接赋值吗,比如inti=12;charc=i;即做一个隐式转换,或者我应该使用static_cast?编辑顺便说一句,我正在使用gcc. 最佳答案 在发明显式强制转换语法之前,C中允许使用它。然后它仍然是一种常见的做法,所以C++继承了它,以免破坏大量代码。实际上大多数编译器都会发出警告。如果没有,请尝试更改其设置。 关于C++将一个int分配给一个char-为什么这个工作至少没有警告?,我们在Stack