迪米特原则 - Least Knowledge Principle - LKP

博客介绍了类的最少知识原则,即一个类应对其他类保持最少了解,仅与直接的朋友通信。直接朋友指在成员变量、方法参数、方法返回值中的类。还通过校长了解学生名字的例子进行说明,给出了学生类、班主任类、校长类等相关内容及运行结果和源码地址。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

定义: 一个类应该对其他类保持最少的了解。
释义: 只有直接的朋友通信。
直接的朋友:出现在成员变量,方法参数,方法返回值中的类。出现在局部变量中的类则不是直接朋友。
举例:如校长想知道学校全体同学的名字,只需与各班主任沟通就行,无需与所有同学沟通
学生类

#include <string>
class Student
{
public:
	Student(std::string name);
	Student(const Student &st); // 因为使用vector和string, 需实现拷贝构造函数
	~Student();

	void showName();   // 显示名称
	
private:
	std::string name;
};

班主任类

#include <string>
#include <vector>
#include "Student.h"
// 班主任类
class HeadTeacher
{
public:
	HeadTeacher(std::string name);
	HeadTeacher(const HeadTeacher &ht); // 因为使用vector和string, 需实现拷贝构造函数
	~HeadTeacher();
	
	void addStudent(Student st);   // 添加同学
	void showStudentName();        // 显示所有同学名字
private:
	std::string name;
	std::vector<Student> students;  // 保存学生
};

校长类

#include <string>
#include <vector>
#include "HeadTeacher.h"
class HeadMaster
{
public:
	HeadMaster(std::string name);
	~HeadMaster();

	void addHeadTeacher(HeadTeacher ht);
	void showAllStudentName();

private:
	std::string name;
	std::vector<HeadTeacher> headTeachers;  // 保存班主任
};

客户端

#include "HeadMaster.h"

int main(int agrc, char* argv[])
{
	// 生成学生
	Student stW1("Wang1");
	Student stW2("Wang2");
	Student stW3("Wang3");
	Student stW4("Wang4");
	Student stL1("Li1");
	Student stL2("Li1");

	// 生成班主任
	HeadTeacher htW("Wang");
	HeadTeacher htL("Li");

	// 生成校长
	HeadMaster hm("Zhang");

	// 分配学生给班主任
	htW.addStudent(stW1);
	htW.addStudent(stW3);
	htW.addStudent(stL1);
	htW.addStudent(stL2);
	htL.addStudent(stW2);
	htL.addStudent(stW4);

	// 分配版主任给校长
	hm.addHeadTeacher(htW);
	hm.addHeadTeacher(htL);

	// 输出全校学生名称
	hm.showAllStudentName();

	getchar();
	return 0;
}

运行结果
在这里插入图片描述
源码地址

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值