草庐IT

PARAM_STR

全部标签

c++ - 在临时字符串上使用 string::c_str

这个问题在这里已经有了答案:C++destructionoftemporaryobjectinanexpression(4个答案)关闭8年前。关于临时对象何时被销毁,这是否有效:FILE*f=fopen(std::string("my_path").c_str(),"r");是否会在计算完fopen的第一个参数后或fopen调用后立即销毁临时对象。使用以下代码进行测试:#includeusingnamespacestd;structA{~A(){printf("~A\n");}constchar*c_str(){return"c_str";}};voidfoo(constchar*s)

c++ - C++ 中是否有等效的 str_replace?

在PHP中,有一个str_replace基本上执行查找和替换的功能。在C++中是否有此函数的等效项? 最佳答案 不完全是,但看看BoostStringAlgorithmsLibrary-在本例中为replacefunctions:std::stringstr("aabbaadd");boost::algorithm::replace_all(str,"aa","xx");str现在包含"xxbbxxdd"。 关于c++-C++中是否有等效的str_replace?,我们在StackOve

c++ - 为什么要在函数中使用 c_str()

这个问题在这里已经有了答案:Whydon'tthestd::fstreamclassestakeastd::string?(10个答案)关闭8年前。我正在阅读《C++Primer》一书及其使用的文件输入输出章节:ifstreaminfile(ifile.c_str());打开名称在字符串ifile中的文件。我尝试了代码,即使没有c_str()也能完美运行。那么使用它有什么意义呢?当我尝试从命令行参数打开文件时,我应该使用c_str()吗?我的意思是正确的用法:ifstreamfin(argv[1])或ifstreamfin(argv[1].c_str())

c++ - "if (getline(fin, str)) {}"是否符合C++11标准?

我检查了C++11标准,发现了以下事实:std::getline(fin,str)返回一个basic_ios对象,其类有一个成员函数explicitoperatorbool()const;basic_ios类没有成员函数operatorvoid*()const;作为C++11之前的版本。所以,我认为if(getline(fin,str)){}不符合标准。应该写成if(bool(getline(fin,str)){}。(但是,VC++2012对此用法给出警告。即强制void*为bool)我说的对吗? 最佳答案 代码是一致的。当对象自动

c++ - 为什么 boost::call_traits<T>::param_type 是枚举类型的引用?

基本的C++03枚举类型只是一个具有奇特名称的整数值,因此我希望按值传递它....出于这个原因,我还期望boost::call_traits::param_type与T=SomeEnum确定最有效的传球方式T是按值(value)。从boost文档中查看CallTraits:Definesatypethatrepresentsthe"best"waytopassaparameteroftypeTtoafunction.当我使用boost::call_traits::param_type时与T=SomeEnum它确定SomeEnum应该通过引用传递。我也期待C++11classenums也

c++ - 从函数返回 'c_str'

这是我在网上找到的一个小型图书馆:constchar*GetHandStateBrief(constPostFlopState*state){staticstd::ostringstreamout;//...restofthefunction...returnout.str().c_str()}在我的代码中我这样做:constchar*d=GetHandStateBrief(&post);std::cout现在,起初d包含垃圾。然后我意识到我从函数中获取的C字符串在函数返回时被销毁,因为std::ostringstream是在堆栈上分配的。所以我补充说:returnstrdup(out

c++ - 调用空字符串的 c_str

这个代码片段是正确的还是会导致未定义的行为?std::strings;assert(strlen(s.c_str())==0);如果不是undefinedbehavior,上面的断言会通过吗? 最佳答案 这是完美定义的,断言通过了。c_str()函数将始终返回有效的以零结尾的C字符串。通常会使用empty()来测试空字符串。 关于c++-调用空字符串的c_str,我们在StackOverflow上找到一个类似的问题: https://stackoverflow

c++ - 尝试转换 str 字符串以用于 std::getline 定界符

我正在尝试获取std::string值并将其用作std::getline()函数中的分隔符但无论我做什么,编译器都会给我错误。这就是我想要做的:std::stringstreamss(s);std::stringitem;std::stringdelim="&&=";intssize=delim.size();intnewssize=ssize+1;chardel[SSIZE];//alsoherewhenitrygiveserrorstrcpy(del,delim.c_str());char*delrr[1024]=delim.c_str();//giveserrorwhile(st

c++ - 将 int vector 转换为 str vector

我正在尝试转换vector到vector.使用std::transform我用了std::to_string转换int至string但我不断收到错误消息。这是我的代码#include#include#include#includeintmain(){std::vectorv_int;std::vectorv_str;for(inti=0;i但是我收到了这个错误nomatchingfunctionforcallto'transform'std::transform(v_int.begin(),v_int.end(),v_str.begin(),std::to_string);^~~~~~

c++ - 使用 std::enable_if 作为模板时的默认模板参数。 param.: 为什么可以使用两个仅在 enable_if 参数上不同的模板函数?

在languagereferenceofstd::enable_ifatcppreference包括以下注释NotesAcommonmistakeistodeclaretwofunctiontemplatesthatdifferonlyintheirdefaulttemplatearguments.Thisisillegalbecausedefaulttemplateargumentsarenotpartoffunctiontemplate'ssignature,anddeclaringtwodifferentfunctiontemplateswiththesamesignaturei