草庐IT

const-string

全部标签

c++ - 为什么我不能将 string::back 分配给 string?

我写了一个简单的程序:获取string1的最后一个字符并将其分配给string2。就像:#include#includeintmain(intargc,charconst*argv[]){std::strings1="abc!";std::strings2=s1.back();std::cout但是,我得到一个编译错误:conversionfrom‘__gnu_cxx::__alloc_traits>::value_type{akachar}’tonon-scalartype‘std::__cxx11::string{akastd::__cxx11::basic_string}’req

c++ - 如何使用可变数量的 std::string_view 参数正确实现函数?

期望的行为我基本上想要的是创建一个这样的函数:voidfunc(std::string_view...args){(std::cout它应该能够只与可转换为std::string_view的类一起工作。例子:intmain(){constchar*tmp1="Hello";conststd::stringtmp2="World";conststd::string_viewtmp3="!";func(tmp1,tmp2,tmp3,"\n");return0;}应该打印:HelloWorld!完成的行为到目前为止,我到了这里:templateusingare_strings=std::co

c++ - std::basic_string 完全特化(g++ 冲突)

我正在尝试定义std::basic_string,allocator>的完全特化这是由定义的(在g++中)标题。问题是,如果我包含首先,g++将typedef视为basic_string的实例化并给我错误。如果我先进行特化,那么我就没有问题。我应该能够在之后定义我的特化已经包括了。我必须做什么才能做到这一点?我的代码:#include//#include//classbasic_string,allocator>{public:intblah(){return42;}size_tsize(){return0;}constchar*c_str(){return"";}voidreserv

c++ - 通过类的 const 引用传递

voidfoo(constClassName&name){...}如何访问类实例名的方法?name.method()无效。然后我尝试了:voidfoo(constClassName&name){ClassNametemp=name;.......}我可以使用temp.method,但是在执行foo之后,原来的名字搞砸了,知道吗?顺便说一句,name的成员变量并没有搞砸,而是类的子类的成员变量搞砸了。 最佳答案 根据您提供的描述,ClassName中的method()似乎是一个非常量方法。如果您尝试在const对象上调用非const方

c++ - string::compare 多余的参数?

在C++referenceonstring::compare,有以下重载:intcompare(size_tpos1,size_tn1,conststring&str,size_tpos2,size_tn2)const;它有两个参数n1和n2在我看来应该总是相等的或者函数返回一个int等于true(string::compare返回值0(false)表示相等的字符串)。这个对吗?如果不是,您能否提供一个示例来说明如果比较的长度不等(n1!=n2),则比较结果为false?谢谢! 最佳答案 inmyeyesshouldalwaysbe

c++ - 在 std::string 中,是否可以在不使用循环的情况下找到一组字符串中的第一个?

在std::string中,是否可以在不使用循环的情况下找到一组字符串中的第一个?例如:std::stringstr("aaabbbcccdddeeefffggg");std::vectorvs;vs.push_back("ccc");vs.push_back("fff");size_tpos=0pos=str.find(vs,pos);//谢谢! 最佳答案 您可以将字符串(使用字符串流)拆分为一个vector,然后将std::find_first_of与四个迭代器一起使用。这是一个完整的代码示例#include#include#i

c++ - 当你有一个 std::string 时如何使用 basic_istream

我有一个使用basic_istream作为参数的函数,我有一个std::string和我需要传递给它的数据。我该怎么做? 最佳答案 您可以将字符串数据放入流中:std::stringx;std::stringstreamss(x);//putstringintostreamfunction_taking_stream(ss); 关于c++-当你有一个std::string时如何使用basic_istream,我们在StackOverflow上找到一个类似的问题:

c++ - vector<shared_ptr<Foo>> 到 vector<shared_ptr<const Foo>> 的隐式转换

根据thispage您可以隐式转换shared_ptr至shared_ptr.这很有道理。但是,当我尝试转换std::vector时遇到错误包含shared_ptr到一个包含shared_ptr的.有没有什么好的方法可以实现这种转化? 最佳答案 编号:std::vector>和std::vector>是不同的类型,因此您不能将一种类型的对象视为另一种类型的对象。如果你真的需要std::vector>,你可以很容易地用shared_ptr创建一个s到与原始元素相同的元素:std::vector>v;std::vector>cv(v.b

C++ 从 LPCTSTR 转换为 const char *

我在MSVC2008MFC中遇到了这个问题。我正在使用unicode。我有一个函数原型(prototype):MyFunction(constchar*)我称它为:MyfunFunction(LPCTSTRwChar).error:CannotConvertParameter1From'LPCTSTR'to'constchar*'如何解决? 最佳答案 由于您使用的是MFC,您可以轻松地让CString自动将char转换为TCHAR:MyFunction(CString(wChar));无论您的原始字符串是基于char还是基于wcha

C++:函数返回指针不应该是 const 的任何原因?

我想知道返回指针的函数是否有任何理由不应该是常量。我正在处理一些在大多数地方似乎是const正确的代码,但由于某种原因没有将返回指针的函数声明为const。例如,它写virtualJoint*getJointByID(unsignedintid);代替virtualJoint*getJointByID(unsignedintid)const;如果getJointByID函数本身实际上没有更改类的任何成员,那么有什么理由不应该存在const吗? 最佳答案 这实际上是有道理的。如果函数要用const声明,则意味着它可以用于常量实例(co