⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 pr11030.cpp

📁 c++编程宝典源码及Quincy99编译器 是《标准C++编程宝典》电子工业出版社的光盘
💻 CPP
字号:
////////////////////////////////////////
// File Name: pr11030.cpp
////////////////////////////////////////
#include <iostream>
#include <cstring>
#include <cstddef>
#include <new>

const int maxnames = 5;

////////////////////////////////////////
// The Names class.
////////////////////////////////////////
class Names
{
    char name[25];
    static char Names::pool[];
    static short int Names::inuse[maxnames];

public:
    Names(char* s = 0)
    {
        if (s)
            strncpy(name, s, sizeof(name));
    }
    void* operator new[](size_t) throw(std::bad_alloc);
    void operator delete[](void*) throw();
    void display() const
        { std::cout << name << std::endl; }
};

// Simple memory pool to handle fixed number of Names.
char Names::pool[maxnames * sizeof(Names)];
short int Names::inuse[maxnames];

// Overloaded new[] operator for the Names class.
void* Names::operator new[](size_t size) throw(std::bad_alloc)
{
    int elements = size / sizeof(Names);

    // Find the first empty element (if any).
    int p = -1;
    int i = 0;
    while ((i < maxnames) && (p == -1))
    {
        if (!inuse[i])
            p = i;
        ++i;
    }

    // Not enough room.
    if ((p == -1) || ((maxnames - p) < elements))
        throw std::bad_alloc();

    // Mark the elements as used.
    for (int x=0; x<elements; ++x)
        inuse[p+x] = elements;

    // Return pointer to memory.
    return pool+p*sizeof(Names);
}

// Overloaded delete[] operator for the Names class.
void Names::operator delete[](void* b) throw()
{
    if (b != 0)
    {
        int p = ((char*)b - pool) / sizeof(Names);
        int elements = inuse[p];
        for (int i = 0; i < elements; i++)
            inuse[p + i] = 0;
    }
}

////////////////////////////////////////
// The main() function.
////////////////////////////////////////
int main()
{
    Names* np = new Names[maxnames];

    int i;
    for (i = 0; i < maxnames; i++)
    {
        std::cout << std::endl << "Enter name # "
                  << i+1 << ": ";
        char name[25];
        std::cin >> name;
        *(np + i) = name;
    }

    for (i = 0; i < maxnames; i++)
        (np + i)->display();

    delete [] np;

    return 0;
}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -