#pragma once #ifndef __Book_H #define __Book_H class Reader; class Book { private: int m_id; char m_title[30]; bool m_state; Reader* m_keeper; public: Book(int id, char title[]); ~Book(); void print_books(); void set_state(bool state); bool get_state(); void set_reader(Reader* reader); int get_id(); }; #endif // !__Book_H,#include "book.h" #include "reader.h" #include <string.h> #include <iostream> using namespace std; Book::Book(int id, char title[]) { m_id = id; strcpy_s(m_title,30, title); m_state = false; m_keeper = NULL; } Book::~Book() { } void Book::print_books() { cout << m_id << " " << m_title << " "; cout << (m_state ? "借出" : "未借出"); if (m_keeper != NULL) cout << m_keeper->get_name(); cout << endl; } void Book::set_state(bool state) { m_state = state; } bool Book::get_state() { return m_state; } void Book::set_reader(Reader* reader) { m_keeper = reader; } int Book::get_id() { return m_id; }如何进行析构
时间: 2024-03-26 22:35:50 浏览: 131
#pragma once用法
在这个 Book 类中,析构函数不需要做太多工作,因为这个类里不包含需要手动释放的资源。因此,你可以简单地把析构函数留空即可,例如:
```c++
Book::~Book()
{
// 空析构函数
}
```
这样就可以了。注意,即使类里不包含需要手动释放的资源,你仍然需要定义析构函数。这是因为在 C++ 中,如果没有显式定义析构函数,编译器会为你生成一个默认析构函数,但这个默认析构函数可能并不符合你的需求,因此最好还是自己定义一个空析构函数。
需要注意的是,如果 Book 类中包含指针类型的成员变量,例如指向 Reader 对象的指针,在析构函数中需要手动释放这些指针所指向的内存。但是在这个例子中,Book 类中并没有这样的成员变量,因此不需要手动释放任何内存。
另外,你需要在类的头文件中声明析构函数:
```c++
class Book {
// ...
public:
Book(int id, char title[]);
~Book(); // 声明析构函数
// ...
};
```
这样,当你销毁 Book 对象时,就会自动调用析构函数了。
阅读全文