草庐IT

new_strings

全部标签

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

C++ "new T[size]"不起作用?

我有一个模板类定义为:#include#includeusingnamespacestd;templateclasstbufferpool{private:constintm_initial;constintm_size;constintm_total;T*m_buffer;vectorm_queue;public://constructortbufferpool(intinitial,intsize):m_initial(initial),m_size(size),m_total(initial*size){m_buffer=newT[m_total];T*next_buffer=m

c++ - 将 operator new 和 operator delete 与自定义内存池/分配器一起使用

我正在研究一个内存池/内存分配器实现,我正在一个庄园中设置它,只有一个特殊的“客户端”对象类型可以从池中提取。客户端可以直接构建到池中,或者它可以使用池进行动态内存调用,或者理论上它可以同时进行。我希望能够以调用我的池“alloc()”和“free()”函数的方式重载operatornew和operatordelete,以便获取构建对象所需的内存。我遇到的主要问题之一是让我的运算符(operator)删除以便能够通过调用我编写的pool->free()函数来释放内存。我想出了一个hack,通过将池传递到构造函数并让析构函数执行释放工作来修复它。这一切都很好而且花花公子,直到有人需要从这

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,它的

uniapp 小程序 使用 new FormData 报错,is not defined 问题解决(没解决)

newFormData只适用于web端,uniapp小程序不适用,这里当时也卡了一下,随便用个js文件发现其实FormData也使用不了,所以如果要配置formData的格式无法使用FormData,会报FormDataisnotdefined.解决原文原文原文1.安装fly:npminstallflyio2.使用renderjs3.Content-Type:‘application/x-www-form-urlencoded’最终代码:viewclass="nav_title"@click="custom.taskSycn">test/view>//注意renderjs方法的调用custom

c++ - 为什么数字类型只有一个 `to_string()`?

我刚刚知道C++有一个std::to_string()在中定义.现在我想知道为什么to_string()仅适用于数字类型。有什么特别的原因,为什么没有更一般的templatestd::stringto_string(constT&t);?可以这样实现:templatestd::stringto_string(constT&t){std::ostringstreams;s我怀疑是这样的将军to_string不存在,因为自己编写很容易,但同样的论点适用于to_string()服用int,double等 最佳答案 因为std::to_st

c++ - 消除 std::vector<std::string> 的列表初始化歧义

我的代码中有一个带有类型签名的重载函数:voidfoo(std::string);voidfoo(std::vector);我希望foo的用户能够使用字符串或字符串列表来调用它//Usecase1foo("str");//Usecase2foo({"str1","str2","str3"});foo({"str1","str2","str3","str4"});问题是当调用者将两个字符串传入foo的初始化列表时。//Problem!foo({"str1","str2"});这个对foo的调用是不明确的,因为它匹配两个类型签名。这是因为显然{"str1","str2"}是std::str

c++ - 内存碎片会减慢 New/Malloc 的速度吗?

短背景:我正在开发一个应该运行数月并使用动态分配的系统。问题:我听说内存碎片会减慢new和malloc运算符的速度,因为它们需要在我留下的“漏洞”之一中“找到”一个位置在内存中,而不是简单地在堆中“前进”。我读过以下问题:Whatismemoryfragmentation?但是没有一个答案提到任何关于性能的事情,只是分配大内存块失败。那么内存碎片是不是让new需要更多的时间来分配内存呢?如果是,增加多少?我怎么知道new是否正在“艰难”地寻找堆上的内存?我试图找到GCC用来在内存中找到要在内部分配的“洞”的数据结构/算法是什么。但找不到任何血统解释。 最佳答

c++ - 创建内联 std::string

是否可以在不创建变量的情况下初始化std::string?我希望完成的事情:throwstd::runtime_error("Error:"+strerror(errno));我目前在做什么:std::stringerror="Error:";std::stringerrmsg(strerror(errno));throwstd::runtime_error(error+errmsg); 最佳答案 只是用其中之一做一个临时的:throwstd::runtime_error(std::string("Error:")+strerror

c++ - typedef a std::string - 最佳实践

我正在用标准C++编写一个库来进行语音转换。到目前为止,我已经使用了std::string。但将来我可能不得不将其更改为其他内容(std::wstring或其他内容)。所以我需要以一种可以轻松切换的方式编写我的库。到目前为止,我已经完成了以下工作。创建了一个将被所有CPP文件使用的头文件为此添加了“typedefstd::string”,并在文件中各处使用了新名称。如果我需要改变类型,我可以简单地在头文件中改变,它会在所有地方反射(reflect)出来。如果有人能看出这是正确的方法或者有更好的方法来做到这一点,我将不胜感激?谢谢 最佳答案