C++ 【vector模拟实现】

本文详细探讨了C++中vector的实现,包括注意事项、基本模拟实现、拷贝构造的深拷贝、赋值运算符等内容。重点讲解了迭代器在insert和erase操作后的失效问题及其解决方法,强调在操作迭代器时需要先更新其位置。
摘要由CSDN通过智能技术生成

目录

1.vector注意事项

2.vector基本模拟实现

insert迭代器失效

erase迭代器失效场景

erase正确写法

总结:insert/erase不要直接访问pos,必须先更新pos位置再访问,不然就会出现迭代器失效

3.拷贝构造:深拷贝

3.2 内置类型升级

3.3 非法的间接寻址

4.赋值运算符


1.vector注意事项

vector构造函数

default(1):不仅仅允许在模板参数中自己定义空间配置器allocator,还允许在构造函数时自定义传递

fill(2):n个val初始vector,size_type(==size_t)和value_type(第一个模板模板参数)是vector tpyedef的成员类型

range(3):迭代器区间构造

copy(4):拷贝构造


遍历:[]

[]不同于at,at越界抛异常,[]越界assert

返回pos位置数据的引用

vector迭代器类模板不能用类名 ,得用模板类型

void testvector1()
	{
		vector<int> v1;
		vector<int> v2(10, 1);
		vector<int> v3(v2);

		for (size_t i = 0; i < v2.size(); ++i)
		{
			cout << ++v2[i] << " ";//[]返回的数据是对应数据的引用
		}
		cout << endl;


		vector<int>::iterator it = v2.begin();
		while (it != v2.end())
		{
			cout << --(*it) << " ";//迭代器可以修改和遍历,但是注意优先级
			++it;
		}
		cout << endl;


		for (auto ch : v2)
		{
			cout<<--ch<<" ";
		}
	}


push_back && pop_back

vector只提供了尾插尾删

const value_type& val == const T& val(T可以是任意类型)

void testvector4()
	{
		vector<string> s;
		s.push_back("zhangsan");//隐式类型转换
		string str1("lisi");
		s.push_back(str1);
		s.push_back(string("wangwu"));//匿名结构+隐式类型转换
		
		for (auto& e : s)//避免深拷贝
		{
			cout << e << " ";
		}
	}


insert

 vector给的不再是下标位置,而是迭代器

 erase

void testvector2()
	{
		vector<int> v1(10,2);
		vector<int>::iterator pos = find(v1.begin(), v1.end(),2);
		if (pos != v1.end())//没找到返回end
		{
			v1.insert(pos, 3);
		}

		for (auto ch : v1)
		{
			cout << ch << " ";
		}

		cout << endl;

		pos = find(v1.begin(), v1.end(), 3);
		if (pos != v1.end())//没找到返回end
		{
			v1.erase(pos);
		}

		for (auto ch : v1)
		{
			cout << ch << " ";
		}
	}


sort快排(包含在algorithm头文件中)

传迭代器区间即可排序,默认升序

逆序包头文件<functional>,其中greater是仿函数(大堆降序)

void testvector3()
	{
		vector<int> v1;
		v1.push_back(53);
		v1.push_back(41);
		v1.push_back(32);
		v1.push_back(512);
		greater<int> gt;
        less<int> ls;//小堆升序
		sort(v1.begin(), v1.end(), gt);
        //sort(v1.begin(), v1.end(),greater<int>());//匿名对象
		for (auto e : v1)
		
引用和提供了关于实现vector的两种方法。其中,引用展示了一个使用reserve和push_back方法的示例,而引用展示了一个使用new和memcpy函数的示例。这两种方法都是常见的实现vector的方式。 在第一种方法中,通过reserve函数可以预留足够的内存空间,然后使用push_back函数逐个将元素添加到vector中。这种方法的好处是可以避免不必要的内存重分配,提高了效率。 而第二种方法使用new操作符在堆上分配内存空间,并使用memcpy函数将已有的vector对象的数据复制到新的内存空间中。通过这种方式,可以实现深拷贝,即两个vector对象拥有独立的内存空间。这种方法的好处是可以在不修改原始vector对象的情况下创建一个新的vector对象。 除了以上两种方法,还可以使用其他方式实现vector类。例如,可以使用动态数组来实现vector的底层数据结构,然后通过成员函数实现vector的各种操作,如增加、删除、查找等。 总结来说,c语言模拟实现vector的关键是动态内存管理和对元素的增删改查操作。可以使用预留空间和逐个添加元素的方式,也可以使用动态数组和复制数据的方式来实现vector类。具体的实现方式可以根据需求和实际情况选择。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* *3* [C++——vector模拟实现](https://blog.csdn.net/weixin_49449676/article/details/126813526)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 100%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

北方留意尘

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值