legongju.com
我们一直在努力
2025-01-13 10:17 | 星期一

如何用C++实现自己的容器类

在C++中,你可以通过继承标准库中的容器类(例如std::vectorstd::list等)或者从头开始创建一个新的容器类。这里我将给出一个简单的示例,展示如何从头开始创建一个基本的动态数组(类似于std::vector):

#include
#include // for std::copy
#include  // for std::out_of_range

template
class MyVector {
public:
    MyVector() : data(nullptr), size(0), capacity(0) {}

    ~MyVector() {
        delete[] data;
    }

    // 复制构造函数
    MyVector(const MyVector& other) {
        data = https://www.yisu.com/ask/new T[other.capacity];>= size) {
            throw std::out_of_range("Index out of range");
        }
        return data[index];
    }

    const T& operator[](size_t index) const {
        if (index >= size) {
            throw std::out_of_range("Index out of range");
        }
        return data[index];
    }

    // 添加元素
    void push_back(const T& value) {
        if (size == capacity) {
            reserve(capacity == 0 ? 1 : capacity * 2);
        }
        data[size++] = value;
    }

    // 预分配内存
    void reserve(size_t newCapacity) {
        if (newCapacity > capacity) {
            T* newData = https://www.yisu.com/ask/new T[newCapacity];"hljs">size_t getSize() const {
        return size;
    }

    // 获取当前容量
    size_t getCapacity() const {
        return capacity;
    }

private:
    T* data;
    size_t size;
    size_t capacity;
};

int main() {
    MyVector vec;
    vec.push_back(1);
    vec.push_back(2);
    vec.push_back(3);

    for (size_t i = 0; i < vec.getSize(); ++i) {
        std::cout<< vec[i] << " ";
    }
    std::cout<< std::endl;

    return 0;
}

这个示例展示了一个简单的动态数组类MyVector,它支持添加元素、获取元素、预分配内存等基本操作。你可以根据需要扩展这个类,添加更多的功能和优化性能。

未经允许不得转载 » 本文链接:https://www.legongju.com/article/106243.html

相关推荐

  • 在c++中cbegin适用于哪些场景

    在c++中cbegin适用于哪些场景

    cbegin() 是 C++11 标准库中的一个函数,它返回一个指向容器开始位置的常量迭代器(const_iterator)。这意味着你不能通过这个迭代器修改容器中的元素。cbegin()...

  • c++ cbegin能提高程序性能吗

    c++ cbegin能提高程序性能吗

    cbegin() 是 C++11 标准中引入的一个成员函数,用于返回容器的常量迭代器,指向容器的第一个元素。使用 cbegin() 本身并不会直接提高程序性能,但它可以帮助你编...

  • c++中使用cbegin有哪些注意事项

    c++中使用cbegin有哪些注意事项

    在C++中,cbegin()和cend()是C++11引入的函数,用于获取容器的常量迭代器(const_iterator),这意味着你不能通过这些迭代器修改容器的内容 确保容器支持cbegin(...

  • c++ cbegin与普通迭代器有何区别

    c++ cbegin与普通迭代器有何区别

    cbegin() 和普通迭代器(例如 begin())之间的主要区别在于它们返回的迭代器类型 cbegin():此成员函数返回一个常量迭代器(const_iterator),表示容器的开始位...

  • C++实现高效数据结构的方法

    C++实现高效数据结构的方法

    在C++中,实现高效数据结构的方法有很多。以下是一些建议: 选择合适的数据结构:根据问题的需求选择合适的数据结构。例如,如果需要快速查找、插入和删除操作,...

  • C++ Cookbook里的错误处理技巧

    C++ Cookbook里的错误处理技巧

    在《C++ Cookbook》这本书中,作者提供了一些关于错误处理的技巧和最佳实践。以下是其中一些建议: 使用异常处理:C++提供了一种名为异常处理的机制,可以在程序...

  • 从C++ Cookbook掌握STL容器用法

    从C++ Cookbook掌握STL容器用法

    C++ Cookbook 是一本关于 C++ 编程的实用教程,其中包含了许多关于 STL(Standard Template Library)容器的用法示例 向量(Vector): #include
    #include ...

  • C++ Cookbook中的高级算法讲解

    C++ Cookbook中的高级算法讲解

    《C++ Cookbook》是一本关于C++编程的实用教程,其中包含了许多高级算法的讲解 排序算法: 快速排序(Quick Sort)
    归并排序(Merge Sort)
    堆排序(H...