Okay I need some insight.
I am taking a C++ class and am working on my second project. I am trying to create a list of options that allow you to store emails in a string vector.
Now before taking the time to help me and look at the code I want to point out my problem. I made an object in the file "HughesProject2-1.cpp":
HughesEmail myhughesEmail();
Well the problem comes right after this when I used this object to run displayList():
myHughesEmail.displayList();
Visual 2010 keeps telling me "error: Expression must have class type"
Now I am using the book as a reference to doing this and they created an object the same way and used it the same way right after. I am confused at what I have wrong as my file is quite different past the basics of using the objects and what is being done. I understand there my be other errors as this is incomplete and I'm still learning, I need to know what is most likely causing me from using the object after I made it. Thanks in advance.
I have three files:
HughesEmail.cpp
// Classes for HughesProject2-1.cpp and HughesEmail.h
// Includes
#include <string>
#include <iostream>
#include <vector>
#include <iomanip>
#include "HughesEmail.h"
// Namespaces
using namespace std;
// Initializing Constructor
HughesEmail::HughesEmail()
{
vector< string > emailStorage( 100 );
emailMinimumLength = 9;
exitOption = 1;
emailOption = 1;
}
void HughesEmail::displayList()
{
// Check if exit is set, if not run.
if ( exitOption == 1 )
{
// Email list options
cout << "Choose from the list of options: \n"
"1 - Store an email address.\n"
"2 - Search an email address.\n"
"3 - List all email adresses.\n"
"4 - Delete an email address.\n"
"0 - Exit.\n" << endl;
while ( emailOption != 0 )
{
// Get user input for email list option
cout << "Option? : ";
cin >> option;
switch ( option )
{
case '0':
// set exitOption to 0
exitOption = 0;
emailOption = 0;
break;
case '1':
//Input email name
cout << "Please input email to be stored: " << endl;
cin >> emailName;
// run storeEmail
storeEmail( emailName );
break;
case '2':
// run searchEmail
break;
case '3':
// run listEmail
break;
case '4':
// run deleteEmail
break;
//Ignore
case '\n':
case '\t':
case ' ':
break;
default:
cout << "\nPlease choose a valid option." << endl;
break;
} // end switch
} // end while
} else {
exitOption = 0;
} // end else
}
void HughesEmail::storeEmail( string emailName )
{
// Initialize counter
int i;
i = 0;
// Check if input emailName meets emailMinimumLength
if( emailName.length() >= emailMinimumLength )
{
// if email in vector slot i is less than minimum length, then override with new email.
if ( emailStorage[ i ].length() < emailMinimumLength )
{
emailStorage[ i ] = emailName;
} else {
i++;
} // end else
} else {
cout << "Email does not meet the minimum length of: " << emailMinimumLength << " characters." << endl;
} // end else
}
HughesEmail.h
// In this project: HughesProject2.h
// Class header file.
//Includes
#include <string>
#include <iostream>
#include <vector>
//Namespaces
using namespace std;
class HughesEmail
{
public:
HughesEmail();
void displayList();
void storeEmail( string );
string searchEmail( string );
string listEmail();
void deleteEmail();
private:
vector< string > emailStorage;
int emailMinimumLength;
int emailOption;
int exitOption;
char option;
string emailName;
};
HughesProject2-1.cpp
// In this project: HughesProject2-1.cpp
// Class creation to store email adresses. Adding, deleting, searching and listing email addresses.
// Includes
#include <string>
#include <iostream>
#include <vector>
#include "HughesEmail.h"
// Namespaces
using namespace std;
int main()
{
//Create HughesEmail Object
HughesEmail myHughesEmail();
myHughesEmail.displayList();
}
You've run into something called the most vexing parse.
HughesEmail myHughesEmail();
This line does not construct a new HughesEmail
object on the stack. Rather, it declares a function that returns a HughesEmail
and takes nothing. You should remove the empty parentheses.
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With