草庐IT

new_string

全部标签

c++ - std::string 的转换运算符无法处理赋值

我正在使用代理类型来推迟工作,直到将结果分配给一个变量,它通过在代理类型上使用转换运算符来工作。为std::string添加转换运算符重载时,它适用于从代理构建字符串,但无法编译赋值,并显示以下错误消息:error:ambiguousoverloadfor'operator='虽然这个问题与operatorT()notusedinassignment的问题类似,这里的解决方案不适用,因为我也在使用模板化转换运算符。下面是片段:#include#includestructProxy{templateoperatorT(){Tres;std::cerr如何使这个代理与字符串赋值一起工作?

c++ - 处理 Xlib/Xt 中的 "new top level window"事件

因此,我需要知道何时创建顶级窗口。我在Xlib/Xt级别和不支持EWMH规范的窗口管理器上工作。我的想法是挂接到根窗口的SubstructureNotify事件。但事情并没有这么简单。问题是并非每个CreateNotify事件都对应于[b]顶级[/b]窗口的创建。所以我认为我需要做的是以某种方式测试我从事件中获得的窗口,以确认它是顶级窗口。我已经接近了,但一些虚假的窗口仍然通过我的网络。例如,在GTK应用程序中,如果您有一个下拉框并单击它,则会创建一个新窗口,我不知道如何捕捉和忽略它。这样的窗口很难与典型的顶级应用程序窗口区分开来。这是我目前所拥有的://Iamomiting(tons

c++ - std::string 的引用计数

我正在查看basic_string的代码(与g++4.2.1捆绑在一起)。复制构造函数使用grab()函数来“抓取”字符串的拷贝(增加其引用计数):_CharT*_M_grab(const_Alloc&__alloc1,const_Alloc&__alloc2){return(!_M_is_leaked()&&__alloc1==__alloc2)?_M_refcopy():_M_clone(__alloc1);}只有当两个字符串的分配器相同时,这才会增加引用计数——这是有道理的。但是,复制构造函数是:basic_string(constbasic_string&__str):_M_d

c++ - 有效 C++ : Item 52 and how to avoid hiding all normal operator new & delete versions

在Myer的EffectiveC++的第52项(自定义新的和删除的)的末尾,他讨论了如何在实现自定义版本时避免隐藏正常的新的和删除的版本,如下所示:Ifyoudeclareanyoperatornewsinaclass,you'llhideallthesestandardforms.Unlessyoumeantopreventclassclientsfromusingtheseforms,besuretomakethemavailableinadditiontoanycustomoperatornewformsyoucreate.Foreachoperatornewyoumakeava

c++ - STL Vectors 和 new 运算符

这个问题应该很简单,也许很愚蠢,但我就是找不到问题。基本上,我必须解析一些自然语言的句子。我需要实现一个简单的算法来操纵“block”。一个Block由2个Pseudosentences组成,Pseudosentences由20个单词(字符串)组成。代码如下:typedefvectorPseudosentence;#defineW20//APseudosentenceismadeofWwords#defineK2//AblockismadeofKPseudosentencesclassBlock{public:vectorp;multimapScoremap;Block(){p.res

C/C++内存管理:new、delete功能及原理实现

目录一、C/C++内存分布二、C++中内存管理方式2.1new/delete操作内置类型2.2new和delete操作自定义类型三、operatornew与operatordelete函数四、new和delete的实现原理4.1内置类型4.2自定义类型五、定位new一、C/C++内存分布intglobalVar=1;staticintstaticGlobalVar=1;voidTest(){ staticintstaticVar=1; intlocalVar=1; intnum1[10]={1,2,3,4}; charchar2[]="abcd"; constchar*pChar3="abcd

c++ - 如何*正确*地将 std::string 转换为无符号 char[] 数组。我想我做错了,有人指出我正确的方向吗?

我目前正在对网络协议(protocol)进行逆向工程,并且我编写了一个小型解密协议(protocol)。我曾经将数据包的字节定义为一个无符号字符数组,如下所示:unsignedcharbuff[]="\x00\xFF\x0A"etc.为了不对每个数据包多次重新编译程序,我制作了一个小型GUI工具,它可以从字符串中获取\xFF表示法中的字节。我通过以下方式做到了这一点:intlength=int(stencString.length());unsignedchar*buff=newunsignedchar[length+1];memcpy(buff,stencString.c_str()

c++ - 常规 "string"类与 "rwcstring"类之间的区别

谁能告诉我常规string类和roguewave的rwcstring类之间的确切区别。我的项目中的代码大量使用了rwcstring类。我的疑问是,如果两者都处理和操纵字符串,那么两者之间的确切区别是什么。还有为什么rwcstring类被认为比常规string类更有效? 最佳答案 RogueWave的RWCString使用一种称为惰性复制的技术来提高其性能。基本上,这意味着复制一个字符串(通过复制构造函数或复制赋值运算符)实际上并没有复制字符串的内容,而只是保留了一个指向原始字符串内容的指针。复制只有在真正需要的时候才进行(通常是因为

c++ - 在 C++ 中绕过 operator new 的重写

有没有办法绕过operatornew的覆盖?是这样的:void*::operatornew(std::size_tsize){void*p=(::operatornew(size));//Butoriginal,_not_infiniterecursion//dostuffwithpreturnp;}背景:我有一些遗留代码,我们最近切换到使用VisualStudio2012进行编译。现在,当malloc无法_heap_alloc足够的内存块时,我们会随机崩溃。(是的,代码到处都是小的内存泄漏和其他不良行为。但不幸的是,彻底清理是不现实的,大约有500000SLOC。)我目前的理论是,原

Python f-strings - PEP 498 - 字面字符串插值

Pythonf-strings或格式化字符串是格式化字符串的新方法。此功能是在Python3.6中引入的,属于PEP-498。它也被称为字面字符串插值。我们为什么需要f-strings?Python提供了各种格式化字符串的方式。让我们快速看一下它们以及它们存在的问题。%格式化-适用于简单的格式化,但对于字符串、整数、浮点数的支持有限。我们无法将其用于对象。模板字符串-它非常基础。模板字符串只能使用类似字典的关键字参数。我们不允许调用任何函数,参数必须是字符串。字符串format()-Python字符串format()函数是为了克服%-格式化和模板字符串的问题和有限功能而引入的。然而,它太啰嗦了