C++第7周(春)项目4 友元类

2024-03-03 09:32
文章标签 c++ 项目 友元类

本文主要是介绍C++第7周(春)项目4 友元类,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

课程首页在:http://blog.csdn.net/sxhelijian/article/details/11890759,内有完整教学方案及资源链接


【项目4-友元类】
  定义下面两个类的成员函数(为体验友元类,实际上本例并不一定是一个好的设计,将两个类的合并为一个DateTime,日期、时间都处理更好)

class Date; //对Date类的提前引用声明  
class Time  
{  
public:  Time(int,int,int);  void add_a_second(Date &);  //增加1秒,1秒后可能会到了下一天,乃到下一月、下一年  void display(Date &);  //显示时间,格式:月/日/年 时:分:秒  
private:  int hour;  int minute;  int sec;  
};  class Date  
{  
public:  Date(int,int,int);  friend class Time; //Time为Date的友元类  
private:  int month;  int day;  int year;  
};  int main( )  
{  Time t1(23,59,32);  Date d1(12,31,2013);   //测试时,再试试Date d1(2,28,2013)会如何  for(int i=0; i<=100; i++)  {  t1.add_a_second(d1);  t1.display(d1);  }  return 0;  
}  
//下面定义两个类中的成员函数,要求不得再增加成员函数  
//注意体会在Time的成员函数中可以调用Date类的私有数据成员   

参考解答:

#include <iostream>
using namespace std;
class Date; //对Date类的提前引用声明
class Time
{
public:Time(int,int,int);void add_a_second(Date &);  //增加1秒,1秒后可能会到了下一天,乃到下一月、下一年void display(Date &);  //显示时间,格式:月/日/年 时:分:秒
private:int hour;int minute;int sec;
};class Date
{
public:Date(int,int,int);friend class Time;  //Time定义为Date的友元类
private:int month;int day;int year;
};int main( )
{Time t1(23,59,32);Date d1(2,28,2013);for(int i=0; i<=100; i++){t1.add_a_second(d1);t1.display(d1);}return 0;
}
//下面定义两个类中的成员函数,要求不得再增加成员函数
//注意体会在Time的成员函数中可以调用Date类的私有数据成员
Time::Time(int h,int m,int s)
{hour=h;minute=m;sec=s;
}
Date::Date(int m,int d,int y)
{month=m;day=d;year=y;
}
int days(int m, int y);  //days函数返回y年m月的天数
void Time::add_a_second(Date &d)
{if(++sec>=60) ++minute,sec-=60;if(minute>=60) ++hour,minute-=60;if(hour>=24) ++d.day,hour-=24;if(d.day>days(d.month,d.year)) ++d.month,d.day=1;if(d.month>12) ++d.year,d.month-=12;
}
void Time::display(Date &d)
{cout<<d.year<<"年"<<d.month<<"月"<<d.day<<"日";cout<<hour<<":"<<minute<<":"<<sec<<endl;
}int days(int m, int y)  //days函数返回y年m月的天数
{int d[]={0,31,28,31,30,31,30,31,31,30,31,30,31};if((y%100==0&&y%4!=0)||(y%400==0)) d[2]=29;return d[m];
}


  






==================== 迂者 贺利坚 CSDN博客专栏=================
|== IT学子成长指导专栏 专栏文章的分类目录(不定期更新) ==|
|== C++ 课堂在线专栏  贺利坚课程教学链接(分课程年级) ==|
|== 我写的书——《逆袭大学——传给IT学子的正能量》    ==|
===== 为IT菜鸟起飞铺跑道,和学生一起享受快乐和激情的大学 =====




这篇关于C++第7周(春)项目4 友元类的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/769197

相关文章

C++快速排序超详细讲解

《C++快速排序超详细讲解》快速排序是一种高效的排序算法,通过分治法将数组划分为两部分,递归排序,直到整个数组有序,通过代码解析和示例,详细解释了快速排序的工作原理和实现过程,需要的朋友可以参考下... 目录一、快速排序原理二、快速排序标准代码三、代码解析四、使用while循环的快速排序1.代码代码1.由快

VSCode中C/C++编码乱码问题的两种解决方法

《VSCode中C/C++编码乱码问题的两种解决方法》在中国地区,Windows系统中的cmd和PowerShell默认编码是GBK,但VSCode默认使用UTF-8编码,这种编码不一致会导致在VSC... 目录问题方法一:通过 Code Runner 插件调整编码配置步骤方法二:在 PowerShell

C/C++随机数生成的五种方法

《C/C++随机数生成的五种方法》C++作为一种古老的编程语言,其随机数生成的方法已经经历了多次的变革,早期的C++版本使用的是rand()函数和RAND_MAX常量,这种方法虽然简单,但并不总是提供... 目录C/C++ 随机数生成方法1. 使用 rand() 和 srand()2. 使用 <random

Ubuntu中Nginx虚拟主机设置的项目实践

《Ubuntu中Nginx虚拟主机设置的项目实践》通过配置虚拟主机,可以在同一台服务器上运行多个独立的网站,本文主要介绍了Ubuntu中Nginx虚拟主机设置的项目实践,具有一定的参考价值,感兴趣的可... 目录简介安装 Nginx创建虚拟主机1. 创建网站目录2. 创建默认索引文件3. 配置 Nginx4

Win32下C++实现快速获取硬盘分区信息

《Win32下C++实现快速获取硬盘分区信息》这篇文章主要为大家详细介绍了Win32下C++如何实现快速获取硬盘分区信息,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 实现代码CDiskDriveUtils.h#pragma once #include <wtypesbase

SpringBoot项目启动错误:找不到或无法加载主类的几种解决方法

《SpringBoot项目启动错误:找不到或无法加载主类的几种解决方法》本文主要介绍了SpringBoot项目启动错误:找不到或无法加载主类的几种解决方法,具有一定的参考价值,感兴趣的可以了解一下... 目录方法1:更改IDE配置方法2:在Eclipse中清理项目方法3:使用Maven命令行在开发Sprin

Nginx实现高并发的项目实践

《Nginx实现高并发的项目实践》本文主要介绍了Nginx实现高并发的项目实践,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧... 目录使用最新稳定版本的Nginx合理配置工作进程(workers)配置工作进程连接数(worker_co

C++ Primer 标准库vector示例详解

《C++Primer标准库vector示例详解》该文章主要介绍了C++标准库中的vector类型,包括其定义、初始化、成员函数以及常见操作,文章详细解释了如何使用vector来存储和操作对象集合,... 目录3.3标准库Vector定义和初始化vector对象通列表初始化vector对象创建指定数量的元素值

C++实现回文串判断的两种高效方法

《C++实现回文串判断的两种高效方法》文章介绍了两种判断回文串的方法:解法一通过创建新字符串来处理,解法二在原字符串上直接筛选判断,两种方法都使用了双指针法,文中通过代码示例讲解的非常详细,需要的朋友... 目录一、问题描述示例二、解法一:将字母数字连接到新的 string思路代码实现代码解释复杂度分析三、

Vue项目的甘特图组件之dhtmlx-gantt使用教程和实现效果展示(推荐)

《Vue项目的甘特图组件之dhtmlx-gantt使用教程和实现效果展示(推荐)》文章介绍了如何使用dhtmlx-gantt组件来实现公司的甘特图需求,并提供了一个简单的Vue组件示例,文章还分享了一... 目录一、首先 npm 安装插件二、创建一个vue组件三、业务页面内 引用自定义组件:四、dhtmlx