From 33613a85afc4b1481367fbe92a17ee59c240250b Mon Sep 17 00:00:00 2001 From: Sven Eisenhauer Date: Fri, 10 Nov 2023 15:11:48 +0100 Subject: add new repo --- .../Prog1/examples/ch07/Fig07_06_10/Employee1.cpp | 72 ++++++++++++++++++++++ 1 file changed, 72 insertions(+) create mode 100644 Bachelor/Prog1/examples/ch07/Fig07_06_10/Employee1.cpp (limited to 'Bachelor/Prog1/examples/ch07/Fig07_06_10/Employee1.cpp') diff --git a/Bachelor/Prog1/examples/ch07/Fig07_06_10/Employee1.cpp b/Bachelor/Prog1/examples/ch07/Fig07_06_10/Employee1.cpp new file mode 100644 index 0000000..6cc742a --- /dev/null +++ b/Bachelor/Prog1/examples/ch07/Fig07_06_10/Employee1.cpp @@ -0,0 +1,72 @@ +// Fig. 7.9: employee1.cpp +// Member-function definitions for class Employee. +#include + +using std::cout; +using std::endl; + +#include // strcpy and strlen prototypes + +#include "employee1.h" // Employee class definition +#include "date1.h" // Date class definition + +// constructor uses member initializer list to pass initializer +// values to constructors of member objects birthDate and +// hireDate [Note: This invokes the so-called "default copy +// constructor" which the C++ compiler provides implicitly.] +Employee::Employee( const char *first, const char *last, + const Date &dateOfBirth, const Date &dateOfHire ) + : birthDate( dateOfBirth ), // initialize birthDate + hireDate( dateOfHire ) // initialize hireDateba +{ + // copy first into firstName and be sure that it fits + int length = strlen( first ); + length = ( length < 25 ? length : 24 ); + strncpy( firstName, first, length ); + firstName[ length ] = '\0'; + + // copy last into lastName and be sure that it fits + length = strlen( last ); + length = ( length < 25 ? length : 24 ); + strncpy( lastName, last, length ); + lastName[ length ] = '\0'; + + // output Employee object to show when constructor is called + cout << "Employee object constructor: " + << firstName << ' ' << lastName << endl; + +} // end Employee constructor + +// print Employee object +void Employee::print() const +{ + cout << lastName << ", " << firstName << "\nHired: "; + hireDate.print(); + cout << " Birth date: "; + birthDate.print(); + cout << endl; + +} // end function print + +// output Employee object to show when its destructor is called +Employee::~Employee() +{ + cout << "Employee object destructor: " + << lastName << ", " << firstName << endl; + +} // end ~Employee destructor + +/************************************************************************** + * (C) Copyright 1992-2003 by Deitel & Associates, Inc. and Prentice * + * Hall. All Rights Reserved. * + * * + * DISCLAIMER: The authors and publisher of this book have used their * + * best efforts in preparing the book. These efforts include the * + * development, research, and testing of the theories and programs * + * to determine their effectiveness. The authors and publisher make * + * no warranty of any kind, expressed or implied, with regard to these * + * programs or to the documentation contained in these books. The authors * + * and publisher shall not be liable in any event for incidental or * + * consequential damages in connection with, or arising out of, the * + * furnishing, performance, or use of these programs. * + *************************************************************************/ -- cgit v1.2.3