草庐IT

heap_string_malloc

全部标签

c++ - Clang:将 bind 或 mem_fn 与 string::c_str 和 transform 结合使用时出现问题

尝试将std::stringvector转换为constchar*vector:#include#include#include#includeintmain(intargc,char**argv){std::vectorvalues;values.push_back("test1");values.push_back("test2");values.push_back("test3");std::vectorc_values(values.size());std::transform(values.begin(),values.end(),c_values.begin(),std::

c++ - "std::string + char"表达式是否创建另一个 std::string?

下面的表达式是否创建了另一个std::string然后将其添加到s1?std::strings1="abc",s2="xyz";s1+=s2+'b';它是否应该防止这种情况(它们无需额外工作就可以添加到s1)?std::strings1="abc",s2="xyz";s1+=s2;s1+='b';这些规则是否也适用于“std::string+std::string”表达式? 最佳答案 所有涉及std::string的重载+运算符都会返回一个新的std::string对象。这是您在youfinallydecipherthereleva

c++ - 带有 std::string 的文字类仅适用于模板特化?

我的编译器不允许以下定义,因为std::string有一个非平凡的析构函数(这说明teststr不能有平凡的析构函数成员(member)没有):classteststr{private:std::string_m;public:constexprteststr(std::stringvalue):_m(value){};constexprstd::stringm()const{return_m;}voidm(std::stringvalue){_m=value;}};但是,teststr的以下等价定义(据我所知)是允许的:templateclasstest{private:T_m;pu

c++ - 检查类型是否可以作为 boost::lexical_cast<string> 的参数

我有以下特征类(IsLexCastable)来检查是否可以通过调用boost::lexical_cast将类型转换为字符串.它错误地返回true对于vector.#include#include#include#include#include#includeusingnamespacestd;usingnamespaceboost;namespacestd{///AddingtostdsincethesearegoingtobepartofitinC++14.templateusingenable_if_t=typenamestd::enable_if::type;}templates

c++ - Visual Studio 2010 上的 VC++ : Release builds using debug heap

我正在对一个慢速C++应用程序进行基准测试/优化,在拍摄一些堆栈快照时,我发现我的应用程序的发布版本正在使用调试堆,因为找到的一些堆栈跟踪表明:ntdll.dll!string"Enablingheapdebugoptions\n"()+0x11056bytes这是一个在Windows7上运行的64位应用程序。我在完全相同的在线环境中看到两三个关于此问题的其他投诉,但没有任何回应。有没有人知道为什么Windows或VisualStudio会使用调试堆来发布构建C++项目? 最佳答案 Thedebugheapisusedwhenapr

c++ - 如何确定带有制表符扩展的 std::string 的(打印)长度?

给定一个包含制表符的C++std::string变量,是否有可能确定该字符串的长度,因为它会出现在“屏幕”上?即:std::stringvar="\t\t\t";std::cout 最佳答案 不容易。如果不了解所涉及的“屏幕”(实际上是驱动输出的软件)的具体知识,这是不可能的,因为选项卡扩展差异很大。有四种相当明显的可能性,基于固定扩展与扩展到某物的倍数,以及基于字符单元与其他一些固定测量(例如,对于比例字体)。还有具有更复杂标准的“智能选项卡”,其中一个选项卡的扩展可能取决于另一个选项卡。在典型的“控制台”上,将扩展mod8个字符

c++ - C 风格字符串到 std::string 的转换说明

我有几个问题,我认为对于有C++经验的人来说很容易回答,我会用粗体显示TL;DR的问题给定以下代码:voidstringTest(conststd::string&s){std::cout希望有人能在这里指出我思维过程中的错误:为什么在传递C风格字符串时,stringTest中的参数必须标记为const?是否没有使用其cstyle字符串构造函数隐式转换为std::string,因此“s”不再是对文字的引用(并且不需要是常量)。此外,cstyle字符串构造函数会是什么样子,编译器如何知道在看到时调用它:stringTest("HelloWorld");它是否简单地将字符串文字识别为类似c

c++ - static const string 成员变量是否总是在使用前初始化?

在C++中,如果我想定义一些non-localconststring,可以在不同的类、函数、文件中使用,我知道的方法是:使用定义指令,例如#defineSTR_VALUE"some_string_value"const类成员变量,例如classDemo{public:staticconststd::stringConstStrVal;};//thenincppstd::stringDemo::ConstStrVal="some_string_value";const类成员函数,例如classDemo{public:staticconststd::stringGetValue(){ret

二进制安全虚拟机Protostar靶场(7)heap2 UAF(use-after-free)漏洞

前言这是一个系列文章,之前已经介绍过一些二进制安全的基础知识,这里就不过多重复提及,不熟悉的同学可以去看看我之前写的文章heap2程序静态分析https://exploit.education/protostar/heap-two/#include#include#include#include#includestructauth{#定义了一个名为auth的结构体charname[32];#定义了一个名叫name的变量,能存储32字节数据intauth;#定义了一个整数变量auth};structauth*auth;#auth指针用来指向structauth类型的对象char*service;

c++ - 如果 std::string::substr 返回 std::string_view 会有什么缺点?

看看这个例子(取自here):classfoo{std::stringmy_str_;public:std::string_viewget_str()const{returnmy_str_.substr(1u);}};这段代码不好,因为substr返回一个临时的std::string,所以返回的std::string_view指的是一个已经存在的-被摧毁的物体。但是,如果substr返回std::string_view,这个问题就不存在了。此外,如果substr返回std::string_view而不是std::string对我来说似乎合乎逻辑,因为返回的字符串是字符串的View,它的