I’ve got a couple questions that I think will be quite easy for someone with C++ experience to answer, I’ll bold the quesitons for the TL;DR
Given the following code:
void stringTest(const std::string &s)
{
std::cout << s << std::endl;
}
int main()
{
stringTest("HelloWorld");
}
Hopefuly someone can point out the error in my thought process here:
Why does the parameter in stringTest have to be marked const when passed a C-Style string? Isn’t there an implicit conversion to an std::string that takes place using its cstyle string constructor, therefore “s” is no longer a reference to a literal (and is not required to be const).
Furthermore, what would a cstyle string constructor look like, and how does the compiler know to invoke this upon seeing:
stringTest("HelloWorld");
Does it simply recognize a string literal to be something like a char*?
I’ve stumbled upon these questions while studying copy constructors. Another quick quesiton for my own clarification…
In the case of something like:
std::string s = "HelloWorld";
Is the cstyle string constructor used to instantiate a temporary std::string, and then the temporary string is copied into “s” using the string copy constructor?:
std::string(const std::string&);
It only has to when the parameter is a reference, since a temporary
std::stringis constructed from thechar const*you pass in and a non-constreference to a temporary is illegal.A string literal is a
char constarray, which decays tochar const*. From that, the compiler infers that it should use the non-explicitconstructorstd::string::string(char const *)to construct the temporary.It’s a bit more complicated than that. Yes, a temporary is created. But the copy constructor may or may not be called; the compiler is allowed to skip the copy construction as an optimization. The copy constructor must still be provided, though, so the following won’t compile:
Also, in C++11 the move constructor will be used, if provided; in that case, the copy constructor is not required.