草庐IT

c++ - 在 C++ 中将字符串 vector 转换为 char 数组

我正在尝试将字符串vector转换为C++中的字符数组。更具体地说,我正在尝试做的是使用以下命令拆分一个shell命令,例如“ls–latr”:istringstreamf(x);while(getline(f,x,'')){strings.push_back(x);}我相信这会给我strings[0]=="ls"和strings[1]=="-latr"。然后我正在尝试执行以下操作:execvp(strings[0],strings);但是,我得到这个错误:error:cannotconvert‘std::basic_string,std::allocator>’to‘constcha

c++ - 如何干净地使用:const char* 和 std::string?

tl:drHowcanIconcatenateconstchar*withstd::string,neatlyandelegantly,withoutmultiplefunctioncalls.Ideallyinonefunctioncallandhavetheoutputbeaconstchar*.Isthisimpossible,whatisanoptimumsolution?初始问题到目前为止,我在C++中遇到的最大障碍是它如何处理字符串。在我看来,在所有广泛使用的语言中,它处理字符串的能力最差。我见过其他与此类似的问题,这些问题的答案要么是“使用std::string”,要么只

C++ 从 char* 到 char 的无效转换 (char* = *string.begin() )

我有以下代码:std::stringextract(){fstreamopenfile("/home/name/Documents/testfile");std::stringteststring;longlocation=4;longlength=2;teststring.resize(length);char*begin=*teststring.begin();openfile.seekp(location);openfile.read(begin,length);returnteststring;}此代码应该返回在文件中找到的字符串。例如,如果文件的内容是StackOverflo

c++ - printf int 到带有左填充空格的 char 数组

我有一点脑死亡的时刻。我必须将int的字符串表示形式存储到char[]中,但ascii表示形式必须用空格填充。snprintf将完成这项工作。chardata[6];intmsg_len=10;std::snprintf(data,6,"%*d",5,msg_len);//"10"我只是想知道是否有更优雅的方法来做到这一点。我可以访问C++11还有一点问题,我认为snprintf也会添加一个终止符,我必须避免这种情况。我可以有一个中间缓冲区并将其复制到我的数据中,但这会增加额外的复杂性。我需要就地进行,因为这些数据结构是我必须发送到接受这种格式输入的服务器的消息的一部分。消息看起来像:

c++ - 将 std::shared_ptr<char> 转换为 std::shared_ptr<unsigned char>

有什么好的方法可以将shared_ptr转换为shared_ptr吗?我想到了以下但它看起来不是很干净。intmain(intargc,char**argv){std::shared_ptrp1=std::make_shared();std::shared_ptrp2=std::shared_ptr(reinterpret_cast(p1.get()),[p1](unsignedchar*){});} 最佳答案 你正在做的事情有一个现成的功能,reinterpret_pointer_cast:std::shared_ptrp2=st

c++ - 从 C++ 中的字符串文字返回 const char*?

这个问题在这里已经有了答案:Howlongdoesastringconstantliveinc++?(1个回答)关闭5年前。通常,我会从函数返回一个std::string,因为返回一个constchar*需要调用者提供一个输出内存缓冲区,而那个缓冲区不可调整大小。但是,如果返回一个constchar*是否有效,如果它来自字符串文字?constchar*generate_c_string(){return"ABC";}这样做(如果有效)可能会更快,因为我不需要动态分配内存来构造std::string。它可能是有效的,因为constchar*x="ABC";是有效的。是否有来自C++标准的

c++ - 在 WM_COMMAND 和 WM_LBUTTONDOWN 分支之间保持状态

我有一些关于WM_COMMAND的问题。如果我在WM_COMMAND的case分支中更改变量x是否有可能在WM_LBUTTONDOWN的case分支中获得这个新值?我总是在WM_LBUTTONDOWN分支中得到0,在WM_COMMAND分支中得到1。LRESULTCALLBACKWindowProcedure(HWNDhwnd,UINTmessage,WPARAMwParam,LPARAMlParam){intx=0;switch(message){caseWM_CREATE:break;caseWM_COMMAND:x=1;cout 最佳答案

c++ - char[](c-string) 的初始化标准

考虑以下代码:intmain(){charhi[5]="Hi!";printf("%d",hi[4]);}将打印什么?更重要的是,在最新C++标准中,标准中是否提及将打印的内容?如果有提及,它在哪里?由于某种原因,很难找到关于此的最新信息,而且各种来源的信息相互矛盾。我试过en.cppreference.com和cplusplus.com,前者没有任何信息,后者声称值未确定。然而,usingnamespacestd;intmain(){charmySt[1000000]="Hi!";for(inti=0;i这在我的系统上只打印0、1和2,所以我希望“rest”被初始化为“\0”。另外据

C++ 自动类型转换为 std::string 和 char* 的区别

作为学习练习,我一直在研究C++中的自动类型转换是如何工作的。我知道通常应该避免自动类型转换,但我还是想通过了解它的工作原理来增加我对C++的了解。我已经创建了一个可以自动转换为std::string的StdStringConverter类,但是编译器(Debian上的g++4.3.4)似乎没有这样做将对象与真实的std::string进行比较时的转换(请忽略缺少按引用传递和不必要地创建临时对象的情况):#includeclassStdStringConverter{public:explicitStdStringConverter(std::stringname):m_name(na

c++ - 按住鼠标左键时未生成 WM_MOUSELEAVE

在我的Win32应用程序中,当我按住鼠标左键并快速将鼠标指针移出窗口时,我没有收到WM_MOUSELEAVE消息。但是如果我按住鼠标左键,从窗口内部开始,慢慢移动到窗口边缘,它会生成一个WM_MOUSELEAVE。如果我没有按住鼠标左键,无论鼠标指针离开窗口的速度有多快,我每次都会收到WM_MOUSELEAVE消息。有什么区别?我该怎么做才能妥善处理这两种情况?编辑:如果我左键单击并按住,移出窗口,然后松开鼠标左键,我会收到WM_MOUSELEAVE消息。但为时已晚。 最佳答案 在Windows7上,我试图制作一个所有者绘制的按钮。