c++沉思录第十章的例子

2023-12-06 10:19
文章标签 c++ 第十章 例子 沉思

本文主要是介绍c++沉思录第十章的例子,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

关于虚函数和纯虚函数的知识需要我们好好注意。
#ifndef NEWPICTURE_H
#define NEWPICTURE_H
#include<iostream>
using namespace std;
class P_Node
{friend class Picture;
protected:P_Node();virtual ~P_Node(){};virtual int width()const=0;virtual int height()const=0;	virtual void display(ostream &, int, int)const=0;int max(int x, int y)const { return x > y ? x : y; }void pad(ostream & os, int x, int y)const ;
private:int use;
};
class Picture
{friend class String_Pic;friend class Frame_Pic;friend class Hcat_Pic;friend class Vcat_Pic;
public:Picture();Picture(const char * const *, int);Picture(const Picture &);~Picture();Picture & operator =(const Picture &);P_Node * p;Picture(P_Node * m);int height()const;int width()const;void display(ostream &, int, int)const;friend ostream & operator <<(ostream & os, const Picture & p);friend Picture frame(const Picture & p);friend Picture operator & (const Picture & p, const Picture & q);friend Picture operator | (const Picture & p, const Picture & q);
};
class String_Pic :public P_Node
{friend class Picture;String_Pic(const char* const * arr, int n);~String_Pic();char** data;int size;int height()const;int width()const;void display(ostream &, int, int)const;
};class Frame_Pic :public P_Node
{friend Picture frame(const Picture &);int height()const;int width()const;void display(ostream &, int, int)const;Frame_Pic(const Picture &);Picture p;
};class Vcat_Pic :public P_Node
{friend Picture operator &(const Picture & n, const Picture & m);Vcat_Pic(const Picture & n, const Picture & m);int height()const;int width()const;void display(ostream &, int, int)const;Picture top, bottom;
};class Hcat_Pic :public P_Node
{friend Picture operator |(const Picture & n, const Picture & m);Hcat_Pic(const Picture & n, const Picture & m);int height()const;int width()const;void display(ostream &, int, int)const;Picture left,right;
};Picture::Picture(const Picture & m) :p(m.p)
{m.p->use++;
}
Picture::Picture(P_Node * m) : p(m){}
Picture::~Picture()
{if (--p->use == 0)delete p;
}
Picture& Picture::operator=(const Picture & q)
{q.p->use++;if (--p->use == 0)delete p;p = q.p;return *this;
}
int Picture::height()const{ return p->height(); }
int Picture::width()const { return p->width(); }
void Picture::display(ostream & os, int n, int m)const
{p->display(os, n, m);
}
Picture::Picture(const char* const * arr, int n) :p(new String_Pic(arr, n)){}
P_Node::P_Node() :use(1){}String_Pic::String_Pic(const char * const * arr, int n)
: data(new char*[n]), size(n)
{for (int i = 0; i < n; ++i){data[i] = new char[strlen(arr[i]) + 1];strcpy_s(data[i],strlen(arr[i])+1,arr[i]);}
}
String_Pic::~String_Pic()
{for (int i = 0; i < size; ++i)delete[]data[i];delete[]data;}
int String_Pic::height()const{ return size; }
int String_Pic::width()const
{int n = 0;for (int i = 0; i < size; ++i)n = max(n, strlen(data[i]));return n;
}void String_Pic::display(ostream & os, int row, int width)const
{int start = 0;if (row >= 0 && row < height()){os << data[row];start = strlen(data[row]);}pad(os, start, width);
}
int Frame_Pic::height()const{ return p.height() + 2; }
int Frame_Pic::width()const{ return p.width() + 2; }
void Frame_Pic::display(ostream& os, int row, int wd)const
{if (row < 0 || row >= height()){pad(os, 0, wd);}else{if ( 0 == row  || row == height() - 1){os << "+";int i = p.width();while (--i >= 0)os << "-";os << "+";}else{os << "|";p.display(os, row - 1, p.width());os << "|";}pad(os, width(), wd);}
}
Frame_Pic::Frame_Pic(const Picture & m) :p(m){}
Picture frame(const Picture & m)
{return new Frame_Pic(m);
}
Vcat_Pic::Vcat_Pic(const Picture & t, const Picture & b) : top(t), bottom(b){}
Hcat_Pic::Hcat_Pic(const Picture & l, const Picture & r) : left(l),right(r){}
Picture operator &(const Picture & n, const Picture & m)
{return new Vcat_Pic(n, m);
}
Picture operator |(const Picture & n, const Picture & m)
{return new Hcat_Pic(n, m);
}
int Vcat_Pic::height()const{ return top.height() + bottom.height(); }
int Vcat_Pic::width()const{ return max(top.width(), bottom.width()); }
int Hcat_Pic::height()const{ return max(left.height(), right.height()); }
int Hcat_Pic::width()const{ return left.width()+ right.width(); }
void Vcat_Pic::display(ostream& os, int row, int wd)const
{if (row >= 0 && row < top.height())top.display(os, row, wd);else{if (row < top.height() + bottom.height())bottom.display(os, row - top.height(), wd);elsepad(os, 0, wd);}
}
void Hcat_Pic::display(ostream & os, int row, int wd)const
{left.display(os, row, left.width());right.display(os, row, right.width());pad(os, width(), wd);
}
void P_Node::pad(ostream & os, int x, int y)const
{for (int i = x; i < y; ++i)os << " ";
}ostream & operator <<(ostream & os, const Picture & p)
{int ht = p.height();for (int i = 0; i < ht; ++i){	p.display(os, i, 0); os << endl;}return os;
}
#endif
#include"NewPicture.h"
#include<iostream>
using namespace std;
int main()
{char * init[] = { "Summer", "love", "Xieweizhong" };Picture p(init, 3);cout << p << endl;cout << frame((p | frame(p)) | (p | frame(p))) << endl;cout << frame((p & frame(p)) | (p | frame(p))) << endl;cout << frame((p | frame(p)) | (p & frame(p))) << endl;cout << frame((p & frame(p)) | (p & frame(p))) << endl;cout << frame((p | frame(p)) & (p | frame(p))) << endl;cout << frame((p & frame(p)) & (p | frame(p))) << endl;cout << frame((p | frame(p)) & (p & frame(p))) << endl;cout << frame((p & frame(p)) & (p & frame(p))) << endl;return 0;
}


这篇关于c++沉思录第十章的例子的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

C++统计函数执行时间的最佳实践

《C++统计函数执行时间的最佳实践》在软件开发过程中,性能分析是优化程序的重要环节,了解函数的执行时间分布对于识别性能瓶颈至关重要,本文将分享一个C++函数执行时间统计工具,希望对大家有所帮助... 目录前言工具特性核心设计1. 数据结构设计2. 单例模式管理器3. RAII自动计时使用方法基本用法高级用法

深入解析C++ 中std::map内存管理

《深入解析C++中std::map内存管理》文章详解C++std::map内存管理,指出clear()仅删除元素可能不释放底层内存,建议用swap()与空map交换以彻底释放,针对指针类型需手动de... 目录1️、基本清空std::map2️、使用 swap 彻底释放内存3️、map 中存储指针类型的对象

C++ STL-string类底层实现过程

《C++STL-string类底层实现过程》本文实现了一个简易的string类,涵盖动态数组存储、深拷贝机制、迭代器支持、容量调整、字符串修改、运算符重载等功能,模拟标准string核心特性,重点强... 目录实现框架一、默认成员函数1.默认构造函数2.构造函数3.拷贝构造函数(重点)4.赋值运算符重载函数

C++ vector越界问题的完整解决方案

《C++vector越界问题的完整解决方案》在C++开发中,std::vector作为最常用的动态数组容器,其便捷性与性能优势使其成为处理可变长度数据的首选,然而,数组越界访问始终是威胁程序稳定性的... 目录引言一、vector越界的底层原理与危害1.1 越界访问的本质原因1.2 越界访问的实际危害二、基

python中update()函数的用法和一些例子

《python中update()函数的用法和一些例子》update()方法是字典对象的方法,用于将一个字典中的键值对更新到另一个字典中,:本文主要介绍python中update()函数的用法和一些... 目录前言用法注意事项示例示例 1: 使用另一个字典来更新示例 2: 使用可迭代对象来更新示例 3: 使用

python连接sqlite3简单用法完整例子

《python连接sqlite3简单用法完整例子》SQLite3是一个内置的Python模块,可以通过Python的标准库轻松地使用,无需进行额外安装和配置,:本文主要介绍python连接sqli... 目录1. 连接到数据库2. 创建游标对象3. 创建表4. 插入数据5. 查询数据6. 更新数据7. 删除

c++日志库log4cplus快速入门小结

《c++日志库log4cplus快速入门小结》文章浏览阅读1.1w次,点赞9次,收藏44次。本文介绍Log4cplus,一种适用于C++的线程安全日志记录API,提供灵活的日志管理和配置控制。文章涵盖... 目录简介日志等级配置文件使用关于初始化使用示例总结参考资料简介log4j 用于Java,log4c

C++归并排序代码实现示例代码

《C++归并排序代码实现示例代码》归并排序将待排序数组分成两个子数组,分别对这两个子数组进行排序,然后将排序好的子数组合并,得到排序后的数组,:本文主要介绍C++归并排序代码实现的相关资料,需要的... 目录1 算法核心思想2 代码实现3 算法时间复杂度1 算法核心思想归并排序是一种高效的排序方式,需要用

C++11范围for初始化列表auto decltype详解

《C++11范围for初始化列表autodecltype详解》C++11引入auto类型推导、decltype类型推断、统一列表初始化、范围for循环及智能指针,提升代码简洁性、类型安全与资源管理效... 目录C++11新特性1. 自动类型推导auto1.1 基本语法2. decltype3. 列表初始化3

C++11右值引用与Lambda表达式的使用

《C++11右值引用与Lambda表达式的使用》C++11引入右值引用,实现移动语义提升性能,支持资源转移与完美转发;同时引入Lambda表达式,简化匿名函数定义,通过捕获列表和参数列表灵活处理变量... 目录C++11新特性右值引用和移动语义左值 / 右值常见的左值和右值移动语义移动构造函数移动复制运算符