草庐IT

c++ - std::string::c_str() 如何返回不会导致内存泄漏或未定义的 c 字符串内容的 c 字符串?

我正在为家庭作业编写一个类似于std::string的字符串类,但我无法弄清楚如何返回一个不会导致内存泄漏并保证保持不变的c字符串,直到它不再使用。我目前有:constchar*string::c_str(){charc[_size+1];strncpy(c,_data,_size);c[_size]='\0';returnc;}但是内容在调用后不久就被覆盖了。如果我进行动态分配,我要么会发生内存泄漏,要么在任何时候给定字符串中只能存在一个c字符串。我怎样才能避免这种情况? 最佳答案 但是c_str指向的字符串只有在std::str

c++ - 对 __cdecl 和 __stdcall 调用约定感到困惑

__cdecl调用约定说:callercleanupstack.__stdcall调用约定说:被调用者清理堆栈。所以我尝试测试下面的代码:#includechar*callee(){charstr[]="abcd";returnstr;}intmain(){char*str;str=callee();printf("%s\n",str);return0;}根据上面的两种调用约定,我认为:__cdecl调用者清理堆栈,因此printf("%s\n",str)应该输出“abcd”。__stdcall由被调用方清理堆栈,因此printf("%s\n",str)应该输出困惑的字符。但实际上,两

子过程“ TypeError:需要字节状的对象,而不是'str'”

我正在使用此代码几年前先前问的问题但是,我相信这已经过时了。尝试运行代码,我收到上面的错误。我仍然是Python的新手,因此我无法从类似问题中获得太多澄清。有人知道为什么会发生这种情况吗?importsubprocessdefgetLength(filename):result=subprocess.Popen(["ffprobe",filename],stdout=subprocess.PIPE,stderr=subprocess.STDOUT)return[xforxinresult.stdout.readlines()if"Duration"inx]print(getLength('be

c++ - std::ostringstream 未返回有效字符串

我正在尝试使用std::ostringstream将数字转换为字符串(char*),但它似乎不起作用。这是我的代码:#include#includeintmain(){std::ostringstreamout;out生成的消息框内根本没有文本。这让我相信对out.str().c_str()的调用返回了一个无效的字符串,但我不确定。由于到目前为止我已经对这个程序进行了缩减,但问题仍然存在,所以我一定是犯了一个令人尴尬的简单错误。感谢您的帮助! 最佳答案 out.str()返回一个std::string按值,这意味着您正在调用.c_s

c++ - 流内容与返回字符串 `str()` 的区别?

我正在使用asmallpieceofcode生成我在互联网上找到的PDF文件,并尝试(温和地)优化它,因为创建文件需要很长时间。分析后,我将其缩小为以下代码:std::ostringstreamtmp;tmp发现在一个紧密的循环中,out是一个ostringstream,它在写入文件之前基本上包含整个PDF内容。我发现tmp.str()是该循环中花费最多时间的行,并且在查找C++引用时看到str()会返回一个拷贝流的基础字符串。然后,我认为删除该拷贝并直接使用out会更快。所以我转储了tmp并直接做了:out但是现在,生成的PDF文件被认为是“损坏的”,无法用PDF阅读器打开,而以前的

c++ - getline 的实现(istream& is, string& str )

我的问题很简单,getline(istream,string)是怎么实现的?如何解决像getline(char*s,streamsizen)这样固定大小的char数组的问题?他们是否使用临时缓冲区和多次调用newchar[length]或其他整洁的结构? 最佳答案 getline(istream&,string&)以读取一行的方式实现。它没有明确的实现;每个库可能彼此不同。可能的实现:istream&getline(istream&stream,string&str){charch;str.clear();while(stream.

C++ 从字符串中去除非 ASCII 字符

开始之前;是的,我知道这是一个重复的问题,是的,我已经查看了已发布的解决方案。我的问题是我无法让他们工作。boolinvalidChar(charc){return!isprint((unsigned)c);}voidstripUnicode(string&str){str.erase(remove_if(str.begin(),str.end(),invalidChar),str.end());}我在“Prusæus,AEgyptians”上测试了这个方法,但它什么也没做我还尝试用isprint代替isalnum真正的问题发生在我程序的另一部分我转换string->wstring->

c++ - 字符串::c_str 查询

调用string::c_str()返回的指针指向哪里?在下面的代码片段中,我以为我会给出一个段错误,但它给了我正确的输出。如果string::c_str()返回的指针指向字符串对象内部的一个内部位置,那么当函数返回并调用对象析构函数时,我应该得到无效的内存访问。#include#includeusingnamespacestd;constchar*func(){stringstr("test");returnstr.c_str();}intmain(){constchar*p=func();cout 最佳答案 Wheredoesth

c++ - 'std::string' 没有名为 'front' 的成员

#include#include#includeintmain(){stringstr;stringstr1;inth=0;cin>>str;if(str.length()>10){str1+=str.front();h=str.length()-2;strings=to_string(h);str1+=s;str1+=str.back();cout在XCode中编译,但不在codeforces.ru/上编译сan'tcompileprogram.cpp:program.cpp:Infunction'intmain()':program.cpp:23:21:error:'std::st

c++ - 链接器错误 - 带有 libboost_thread 的 macOS 上 undefined symbol std::string::c_str() const?

我从homebrew安装了boost1.55.0在macos小牛队上。获取链接器异常-找不到std::string::c_str(),我不明白为什么。这可能是Homebrew软件的问题吗?我尝试直接从boost编译boost1.55.0,它甚至没有在macOS上构建。这段代码:#include#include#include#includetypedefstd::unordered_mapStringMap;staticboost::thread_specific_ptr>rlist;intmain(){return0;}使用此命令行编译:g++-std=c++11main.cpp-I