草庐IT

foo_string

全部标签

c++函数将time_t格式化为std::string:缓冲区长度?

我想要一个函数,它将接受一个time_t参数和一个任意格式的字符串并对其进行格式化。我想要这样的东西:std::stringGetTimeAsString(std::stringformatString,time_ttheTime){structtm*timeinfo;timeinfo=localtime(&theTime);charbuffer[100];strftime(buffer,100,formatString.c_str(),timeinfo);std::stringresult(buffer);returnresult;}但是我遇到的一个问题是缓冲区长度。我正在考虑做类似

c++ - 使用 string.at() 或 string[]

在C++中,使用string[x]获取特定位置的字符是否不好?大多数人使用string.at(x)但string[x]不好的原因是什么? 最佳答案 据我所知,大多数人不使用string.at()。如果您的代码编写得很好并且易于理解,那么您应该始终在字符串的范围内工作,因此不需要string.at()提供的运行时边界检查。使用.at()的其他序列容器也是如此。 关于c++-使用string.at()或string[],我们在StackOverflow上找到一个类似的问题:

c++ - std::to_string 与字符串流

下面的代码显示了2个解决方案(std::to_string和std::stringstream)转换intm_currentSoundTime到std::string。std::to_string或std::stringstream更快吗?//ComputecurrentsoundtimeinminuteandconverttostringstringstreamcurrentTime;currentTime或m_currentSoundTimeInMinute=to_string(m_currentSoundTime/60); 最佳答案

c++ - 如何迭代 std::string 中的所有正则表达式匹配及其在 c++11 std::regex 中的起始位置?

我知道两种从std::string获取正则表达式匹配的方法,但我不知道如何获取所有匹配及其各自的偏移量。#include#include#includeintmain(){usingnamespacestd;strings="123apples456oranges789bananasorangesbananas";regexr=regex("[a-z]+");constsregex_token_iteratorend;//hereIknowhowtogetalloccurences//butdon'tknowhowtogetstartingoffsetofeachonefor(sreg

c++ - 有什么方法可以在不复制的情况下从 std::ostringstream 获取 std::string_view ?

我知道你不能在不复制的情况下从std::ostringstream中提取std::string(Creatinganinputstreamfromconstantmemory)。但是有可能得到一个std::string_view吗? 最佳答案 字符串流不需要将它们的数据存储在一个连续的数组中。string_view当然是连续字符串的View。所以不,你想要的是不可能的。最好等到C++20,那时我们将支持移入/移出字符串流。 关于c++-有什么方法可以在不复制的情况下从std::ostri

c++ - 使用 std::string 在 switch-case block 中返回字符串常量

注意:这不是关于使用字符串来选择switch-caseblock中的执行路径。C++中的一个常见模式是使用switch-caseblock将整数常量转换为字符串。这看起来像:charconst*to_string(codescode){switch(code){casecodes::foo:return"foo";casecodes::bar:return"bar";}}但是,我们是在C++中,所以使用std::string更合适:std::stringto_string(codescode){switch(code){casecodes::foo:return"foo";caseco

c++ - std::string 删除最后一个字符失败?

我正在尝试将通配符形式的用户输入("*word*")更改为正则表达式格式。为此,我使用下面的代码去除输入开头和结尾的'*',以便我可以在两端添加正则表达式字符:string::iteratoriter_begin=expressionBuilder.begin();string::iteratoriter_end=expressionBuilder.end();iter_end--;if((char)*iter_begin=='*'&&(char)*iter_end=='*'){expressionBuilder.erase(iter_begin);expressionBuilder.

c++ - 从 "foo<T>"转换为 "const foo<const T>"- C++

我有一个类似的函数(请不要关心通过引用返回临时值。这只是一个解释问题的例子),constfoo&get_const(){foof;returnf;}这显然无法编译。我正在寻找一种方法来确保调用者不会更改T的foo.我怎样才能确保这一点?我已经看到boost::shared_ptr的类似行为.shared_ptr可转换为constshared_ptr.我不知道它是怎么做到的。任何帮助都会很棒。 最佳答案 编译器看到foo和foo作为两种完全不同且不相关的类型,所以foo与任何其他转换一样,类需要明确支持这一点。如果您可以控制foo类,

c++ - istream 中的 getline 和 basic_string 中的 getline

stringtext;getline(text.c_str(),256);1)我收到错误消息“错误:没有匹配函数来调用‘getline(constchar*,int)”上面有什么问题,因为text.c_str()也返回一个指向字符数组的指针。如果我这样写chartext[256]cin.getline(text,256,'\n');它工作正常。cin.getline和getline有什么区别?2)怎么会textstring;getline(cin,text,'\n')接受整行作为输入。这个字符数组的指针在哪里? 最佳答案 text.

c++ - std::string.npos 有效性

std::string.npos曾经有效吗?(与正确的std::string::npos相反。)我在我正在处理的一个旧项目中经常看到它,它不能用VS2010编译。它是前标准时代的东西吗? 最佳答案 用于命名类成员的带有类语法的C实际上是一个点:classX{public:voidf();};voidX.f()//adot!seeD&E2.3{}然而,::语法还没有被发明出来。std命名空间也不存在。因此,std::string.npos从未像Cwithclasses或标准C++那样有效。我怀疑std::string.npos纯粹是微