C++中的构造函数与析构函数及组合类的调用
// 构造函数与析构函数及类的组合
#include "stdafx.h"
#include <iostream>
using namespace std;
//枚举
enum CPU_Rank {P1=1,P2,P3,P4,P5,P6,P7};
class CPU
{
private:
CPU_Rank rank;
int frequency;
float voltage;
public:
CPU(CPU_Rank r, int f, float v)
{
rank = r;
frequency = f;
voltage = v;
cout << "构造了一个CPU!" << endl;
}
//CPU拷贝构造函数
CPU(const CPU &c){
rank = c.rank;
frequency = c.frequency;
voltage = c.voltage;
cout << "拷贝构造了一个CPU!" << endl;
}
//CPU析构函数
~CPU(){
cout << "析构了一个CPU!" << endl;
}
//函数API接口
CPU_Rank GetRank() const {return rank;}
int GetFrequency() const {return frequency;}
float GetVoltage() const {return voltage;}
void SetRank(CPU_Rank r) {rank = r;}
void SetFrequnecy(int f) {frequency = f;}
void SetVoltage(float v) {voltage = v;}
void Run() {cout << "CPU开始运行!" << endl;}
void Stop() {cout << "CPU停止运行!" << endl;}
};
//枚举
enum RAM_Type{DDR2 = 2, DDR3, DDR4};
class RAM{
private:
enum RAM_Type type;
unsigned int frequency;
unsigned int size;
public:
RAM(RAM_Type t, unsigned int f, unsigned int s){
type = t;
frequency = f;
size = s;
cout << "构造一个RAM!" << endl;
}
//RAM拷贝构造函数
RAM(const RAM &c){
type = c.type;
frequency = c.frequency;
size = c.size;
cout << "拷贝构造了一个RAM!" << endl;
}
//RAM析构函数
~RAM(){cout << "析构一个RAM!" << endl;}
//函数API接口
RAM_Type GetType() const {return type;}
unsigned int GetFrequency() const {return frequency;}
unsigned int GetSize() const {return size;}
void SetRank(RAM_Type t) {type = t;}
void SetFrequnecy(unsigned int f) {frequency = f;}
void SetSize(unsigned int s) {size = s;}
void Run() {cout << "RAM开始运行!" << endl;}
void Stop() {cout << "RAM停止运行!" << endl;}
};
//枚举
enum CDROM_Interface{SATA, USB};
enum CDROM_Install_type{exteral, built_in};
class CD_ROM
{
private:
enum CDROM_Interface interface_type;
unsigned int cache_size;
CDROM_Install_type install_type;
public:
CD_ROM(CDROM_Interface i, unsigned int s, CDROM_Install_type it){
interface_type = i;
cache_size = s;
install_type = it;
cout << "构造了一个CD_ROM!" << endl;
}
//CD_ROM拷贝构造函数
CD_ROM(const CD_ROM &c){
interface_type = c.interface_type;
cache_size = c.cache_size;
install_type = c.install_type;
cout << "拷贝构造了一个CD_ROM!" << endl;
}
//CD_ROM析构函数
~CD_ROM(){
cout << "析构了一个CD_ROM!" << endl;
}
//函数API接口
CDROM_Interface GetInterfaceType() const {return interface_type;}
unsigned int GetSize() const {return cache_size;}
CDROM_Install_type GetInstallType() const {return install_type;}
void SetInterfaceType(CDROM_Interface i) {interface_type = i;}
void SetSize(unsigned int s) {cache_size = s;}
void SetInstallType(CDROM_Install_type it) {install_type = it;}
void Run() {cout << "CD_ROM开始运行!" << endl;}
void Stop() {cout << "CD_ROM停止运行!" << endl;}
};
class COMPUTER
{
private:
CPU my_cpu;
RAM my_ram;
CD_ROM my_cdrom;
unsigned int storage_size;
unsigned int bandwidth;
public:
COMPUTER(CPU c, RAM r, CD_ROM cd, unsigned int s, unsigned int b);
//COMPUTER析构函数
~COMPUTER(){cout << "析构一个COMPUTER!" << endl;}
void Run(){
my_cpu.Run();
my_ram.Run();
my_cdrom.Run();
cout << "COMPUTER开始运行!" << endl;
}
void Stop(){
my_cpu.Stop();
my_ram.Stop();
my_cdrom.Stop();
cout << "COMPUTER停止运行!" << endl;
}
};
//COMPUTER构造函数的函数体 {类名::函数名:初始化列表} 此处需要调用两次拷贝构造函数分别是:CPU c, RAM r, CD_ROM cd
COMPUTER::COMPUTER(CPU c, RAM r, CD_ROM cd, unsigned int s, unsigned int b):my_cpu(c),my_ram(r),my_cdrom(cd),storage_size(s),bandwidth(b){
//storage_size = s;
//bandwidth = b;
cout << "构造了一个COMPUTER!" <<endl;
}
int _tmain(int argc, _TCHAR* argv[])
{
CPU a(P6,300,2.8);
a.Run();
a.Stop();
cout << "*********************************************" << endl;
RAM b(DDR3, 1600, 8);
b.Run();
b.Stop();
cout << "*********************************************" << endl;
CD_ROM c(SATA, 2, built_in);
c.Run();
c.Stop();
cout << "*********************************************" << endl;
COMPUTER my_computer(a, b, c, 128, 10);
cout << "*********************************************" << endl;
my_computer.Run();
my_computer.Stop();
cout << "*********************************************" << endl;
//system("pause"); //此语句会提前中止程序,会导致程序不能顺利的调用析构函数
return 0;
//在执行完return 0; 语句后调用析构函数
}
C++中的构造函数与析构函数及组合类的调用的更多相关文章
- python中的构造函数和析构函数
python中的特殊方法,其中两个,构造函数和析构函数的作用: 比说“__init__”这个构造函数,具有初始化的作用,也就是当该类被实例化的时候就会执行该函数.那么我们就可以把要先初始化的属性放到这 ...
- (转载)C++中, 构造函数和析构函数能不能被显示调用?
(转载)http://blog.csdn.net/zhangxinrun/article/details/6056321 代码: view plaincopy to clipboardprint?#i ...
- C++中的构造函数和析构函数
构造函数: 在类实例化对象时自动执行,对类中的数据进行初始化.构造函数可以从载,可以有多个,但是只能有一个缺省构造函数. 析构函数: 在撤销对象占用的内存之前,进行一些操作的函数.析构函数不能被重载, ...
- 菜鸟谈谈C#中的构造函数和析构函数
本节说明对象的创建.初始化和销毁过程.本节介绍下列主题: l 类构造函数 l 结构构造函数 l 析构函数 类构造函数 本节将讨论三种类构造函数: 类构造 ...
- 005_python中的构造函数和析构函数
python中的特殊方法,其中两个,构造函数和析构函数的作用: 比说“__init__”这个构造函数,具有初始化的作用,也就是当该类被实例化的时候就会执行该函数.那么我们就可以把要先初始化的属性放到这 ...
- C# 中的构造函数与析构函数
C# 中的构造函数 类的 构造函数 是类的一个特殊的成员函数,当创建类的新对象时执行. 构造函数的名称与类的名称完全相同,它没有任何返回类型. 下面的实例说明了构造函数的概念: using Syste ...
- php中的构造函数与析构函数
PHP面向对象——构造函数.析构函数 __construct.__destruct__construct 构造方法,当一个对象创建时调用此方法,使用此方法的好处是:可以使构造方法有一个独一无二的名称, ...
- C++类继承中的构造函数和析构函数 调用顺序
思想: 在C++的类继承中,构造函数不能被继承(C11中可以被继承,但仅仅是写起来方便,不是真正的继承) 建立对象时,首先调用基类的构造函数,然后在调用下一个派生类的构造函数,依次类推: 析构对象时, ...
- (C++)C++类继承中的构造函数和析构函数
思想: 在C++的类继承中, 建立对象时,首先调用基类的构造函数,然后在调用下一个派生类的构造函数,依次类推: 析构对象时,其顺序正好与构造相反: 例子: #include <iostream& ...
随机推荐
- python面向对象继承
class A(object):pass # 括号中可称为父类,基类,超类 class B:pass # 父类,基类,超类 class A_son(A,B):pass # 子类,派生类 class A ...
- Ubuntu -- unknown error: Chrome failed to start: exited abnormally (Driver info: chromedriver=...)
#添加沙盒模式 chrome_options.add_argument("--no-sandbox")
- python window窗口
from Tkinter import * root=Tk() root.title('我是root窗口!') L=Label(root,text='我属于root') L.pack() f=Topl ...
- Zygote启动及其作用
目录 1.Zygote简介 2.Zygote进程如何启动 2.1 init.zygote64_32.rc文件 2.2 查看ps信息 2.3 启动 3.Zygote作用 3.1 启动system_ser ...
- 系统中sshd进程的查看,数量统计,进程号输出,进程清理命令
1. 查看sshd进程 ps -ef|grep sshd ps -ef:打开所有的进程 grep sshd:过滤出含有“sshd”字符的进程. 2. 查看sshd进程中的sftp进程,不含查询的进程 ...
- Mybatis自定义控制台打印sql的日志工具
调试mybatis源码时,想要更改日志的的实现工具,首先需要了解其原理. 源码包里有这部分的解释,翻译如下: Mybatis 的内置日志工厂提供日志功能,内置日志工厂将日志交给以下其中一种工具作代理: ...
- 使用 CircleCI 2.0 进行持续集成/持续部署
使用 CircleCI 2.0 进行持续集成/持续部署 - 简书https://www.jianshu.com/p/36af6af74dfc Signup - CircleCIhttps://circ ...
- StringBuffer & StringBuilder的区别
StringBuffer是线程安全的,内部有锁.所以比StringBuilder慢一点. 在单线程生成字符串的情况下,优先使用StringBuilder. 这就是为啥有时候IntelliJ Idea会 ...
- mailgun php 邮件发送 实例
步骤如下: 通过 composer 获取代码库 获取 API Key 以及 domain 编写代码发送邮件 1. 首先通过 composer 获取依赖代码库,参考官网给的命令 https://docu ...
- centos7设置rsyslog日志服务集中服务器
centos7设置rsyslog日志服务集中服务器 环境:centos6.9_x86_64,自带的rsyslog版本是7.4.7,很多配置都不支持,于是进行升级后配置 # 安装新版本的rsyslog程 ...