As can be seen in the above program, "name1" prints fine. But as part of the assignment operator function, i figured my object "name2" would work. But it doesn't. I'm guessing this is due to the fact the assigned variable is perceived as "char". I could be wrong. Can someone please point me in the right direction to fix this. Thank you.
you're trying to assign a r-value so, (a) you need to create the object first through its overloaded ctor and (b) use std::move() with the copy assignment operator (or overload the move assignment operator):
I apologize. I should have been a bit more specific. gunnerfunner's reply is more in tune with what I want to accomplish. I want to be able to use the overloaded assignment operator while accomplishing this task.
@gunnerfunner, while your reply works, I have a question .
Is it not possible to have the program work where I load 'name2' with just the name and have the assignment operator accordingly modified to take in just the name.
I want to be able to have the following work.
name2 = ("Peggy", "Olsen");
I believe the above can be done with necessary modifications to the assignment operator. I'm not sure how to modify the assignment operator.
Thanks gunnerfunner. The reason why I'm obsessing with this idea is because I'm studying using the book "C++ without Fear" by Brian Overland. In this he actually comes up with an option to do exactly what I want to do.
How he does it is ,
He uses the <string.h> header and uses the string class to add an assignment overloaded operator.
int main(){
String a;
a = "I";
system ("PAUSE");
return 0;
}
String::String(){
ptr = new char[1];
ptr[0] = '\0';
}
String::String(char *s){
int n = strlen(s);
ptr = new char[n+1];
strcpy(ptr, s);
}
String::String(const String &src){
int n = strlen(src.ptr);
ptr = new char[n+1];
strcpy(ptr, src.ptr);
}
String::~String(){
delete [] ptr;
}
void String::cpy(char *s){
delete [] ptr;
int n = strlen(s);
ptr = new char[n+1];
strcpy(ptr, s);
}
So i wanted to do was avoid the String class and String Header and come up with a new way to load the char/String directly using an assignment overloading operator and be able to do the following,
name2 = ("Peggy", "Olsen");
If I can do this, it will also go a long way to help me better understand/design assignment operators . So any help is appreciated.
p:s Even if it is a definite NO that it cannot be done, atleast I would have better understood how assignment operators function and their limitations.
Could do with trimming blanks off start and end, but that's for another day.
Your book is just showing you the rudiments of a new String class. The book I originally taught myself from did something similar: seems to be a standard challenge. In your example there is only one item on the RHS of the assignment, not two ... and therein lies the problem.
There's nothing wrong with your assignment operator - you can have multiple overloads, as long as they have different parameters. I would keep both. Operators are essentially just functions. BTW, there's plenty of potential validation flaws in my const char * version - may be blanks at start and/or end, may be only one name etc.
TBH, @coder777's solution is probably the easiest if you require two separate arguments. For something that has already been constructed and initialised, I can't work out whether it is implicitly creating a temporary outputname object and moving/copying, or whether this syntax is genuinely moving the items straight into the data members of name2. I'd love an explanation ... !
As a follow through I have another question with an update on the program. I appreciate any help .
The code is listed below. The question I have is trying to understand this one line.
if (this != &src)
I think I do, but please correct me if I am wrong.
I've been reading about this on different forums. I have read varying opinions of, if this line is actually necessary in the first place. Assuming this is necessary,
In reference to the following code, am I right in thinking that the purpose of this line is to check if the object being assigned to is not the same as the object invoking it. So in this example,
&src = refers to "name2" and 'this' refers to "name4".
Am I right in assuming so or have I got it all wrong ?
#include <iostream>
#include <string>
// class with strings & constructors
class outputname{
private:
std::string first_name, last_name, full_name;
public:
outputname(){first_name = " "; last_name = " ";}
outputname(std::string fn, std::string ln){
setname(fn, ln);
}
void printname(){std::cout << "The name is " << first_name << " .. " << last_name << ".\n";}
void printfullname(){std::cout << "The name is " << full_name << ".\n";}
void setname(std::string fn, std::string ln){first_name = fn; last_name= ln;}
> am I right in thinking that the purpose of this line is to check if the object being assigned to
> is not the same as the object invoking it on the right hand side of the assignment.
It is a check for self-assignment. this != /*&src*/ std::addressof(src) is true only if the lhs and the rhs of the assignment are two different objects.