当前位置: 首页 > news >正文

怎么样在b2b网站做推广网络服务提供者不履行法律行政法规规定

怎么样在b2b网站做推广,网络服务提供者不履行法律行政法规规定,科技企业网站源码,有家装饰有限公司地址送给大家一句话: 世界在旋转,我们跌跌撞撞前进,这就够了 —— 阿贝尔 加缪 vector问题解决 1 前言2 迭代器区间拷贝3 迭代器失效问题4 memcpy拷贝问题 1 前言 我们之前实现了手搓vector,但是当时依然有些问题没有解决&#xff…

在这里插入图片描述
送给大家一句话:

世界在旋转,我们跌跌撞撞前进,这就够了 —— 阿贝尔 加缪

vector问题解决

  • 1 前言
  • 2 迭代器区间拷贝
  • 3 迭代器失效问题
  • 4 memcpy拷贝问题

1 前言

我们之前实现了手搓vector,但是当时依然有些问题没有解决:

  1. 迭代器区间拷贝(非法的间接寻址问题)
  2. 迭代器失效问题
  3. 使用memcpy拷贝问题

接下来,我们一点一点来解决这些问题!!!

2 迭代器区间拷贝

来看这个这个构造函数:

		template<class InputIterator>vector(InputIterator first, InputIterator last){while (first != last){push_back(*first);first++;}}

这个是对迭代器区间进行的构造函数,思路很简单,把迭代器区间的数据依次尾插就可以了(这里之所以另外使用一个新的模版,而不是使用vector类的模版,是为了兼容更多的数据类型)。这样就可以通过一个现有的类型来构造容器。
但是出乎意料的是出现了一个问题: C2100 非法的间接寻址 (编译层面的问题) 。非法的间接寻址的造成原因有很多:

  1. 空指针引I用:当一个指针没有被初始化或者为NULL时,对它进行间接寻址操作会导致非法访问
  2. 野指针引用:当一个指针超出了它所指向的内存范围,或者已经被释放但仍然被引用时,进行间接寻址操作也会导致非法访问。
  3. 类型不匹配:如果试图将指针转换为不兼容的类型进行间接寻址,也会导致非法访问。

我们分析一下我们遇到的问题是那种问题?空指针引用吗?不可能!野指针引用吗?也不可能!!! 那么真相只有一个:我们遇到了类型不匹配的问题,那这是来自哪里的呢???,经过我的排除法(注释不同的代码块来进行查找),得到了结果

vector<int> v1(5,6);

这一行代码是我们出错的根源,为什么这个构造没有去使用vector(size_t n,T val = T()),而是使用我们的vector(InputIterator first, InputIterator last),因为第二个函数与(5,6)的类型更匹配,编译器会寻找最合适的函数。

解决方法也是十分暴力:多枚举几个 构造函数:

vector(size_t n,T val = T())
vector(int n,T val = T());
vector(long long n,T val = T());

这样就会优先匹配vector(int n,T val = T());了,我们的问题也就解决了。

3 迭代器失效问题

这个问题主要出现在我们的插入操作(insert)和删除操作(erase)。来看:

void vector_test7() {vector<int> v1;v1.push_back(1);v1.push_back(2);v1.push_back(3);v1.push_back(4);v1.push_back(5);v1.push_back(6);v1.push_back(7);vector<int>::iterator it = v1.begin() + 3;// 4cout << *it << endl;v1.insert(3, 40);cout << *it << endl;
}

这个执行的结果是:
在这里插入图片描述
迭代器的指向发生了改变,我们实现的迭代器的底层是指针,我们插入之后指针位置不变,而数组元素改变,自然会产生不一样的结果。这个问题看起来不严重,那我们再来看:

void vector_test7() {vector<int> v1;v1.push_back(1);v1.push_back(2);v1.push_back(3);v1.push_back(4);v1.push_back(5);v1.push_back(6);v1.push_back(7);v1.push_back(8);vector<int>::iterator it = v1.begin() + 3;// 4cout << *it << endl;v1.insert(3, 40);cout << *it << endl;
}

在这里插入图片描述
为什么这里出现了乱码???我们代码和之前的区别是什么???一个进行了扩容,一个没进行扩容。扩容之后vector的_start发生了改变,自然我们的指针也失去了对应作用。 迭代器就失效了,这个解决办法也很简单,就是插入之后不要使用之前的迭代器!!!一定要对迭代器进行更新。

再来看erase中的问题:

void vector_test7() {vector<int> v1;v1.push_back(1);v1.push_back(2);v1.push_back(3);v1.push_back(4);v1.push_back(5);//v1.push_back(6);//v1.push_back(7);//v1.push_back(8);vector<int>::iterator it = v1.begin();//删除偶数while (it != v1.end()){if (*it % 2 == 0){v1.erase(it);}++it;}print_vector(v1);
}

这样运行起来是没有问题的,那么再来看:

void vector_test7() {vector<int> v1;v1.push_back(1);v1.push_back(2);v1.push_back(3);v1.push_back(4);v1.push_back(4);v1.push_back(5);//v1.push_back(6);//v1.push_back(7);//v1.push_back(8);vector<int>::iterator it = v1.begin();//删除偶数while (it != v1.end()){if (*it % 2 == 0){v1.erase(it);}++it;}print_vector(v1);
}

现在出现了:
在这里插入图片描述
这个问题,问题的来源也很简单,我们迭代器在删除之后没有改变位置,但是_start的元素发生了改变,也就是相当于 it 向后移动了两次,为了避免这个情况我们可以:

	while (it != v1.end()){if (*it % 2 == 0){v1.erase(it);}else{++it;}}

这样就可以了:
在这里插入图片描述
需要注意的一点是,我们的操作是以g++标准来进行的(如果删除会进行缩容,也会出现错误,迭代器就不能进行++了),所以 在VS环境下,vector 容器在erase 之后的迭代器是严格不能使用的,使用就会报错,因为VS迭代器的底层不是原生指针,判断有所不同。
迭代器失效解决方案总结
1. 删除插入之后更新对应迭代器!(erase删除后会返回新的迭代器 ,按规则进行迭代就可以了 it = v1.erase(it)
2. 插入删除之后不使用迭代器

4 memcpy拷贝问题

我们创建一个string类的容器,来看看能不能正常运行:

void vector_test8() {vector<string> v1;v1.push_back("11111");v1.push_back("22222");v1.push_back("33333");v1.push_back("44444");v1.push_back("55555");print_vector(v1);
}

来看效果:
在这里插入图片描述程序直接崩掉了,经过我们的调试,我们能打印出来正确的数据,但是走到程序最后的时候出现了错误,那么应该就是析构函数的问题了!
来画图分析一波:

  1. memcpy是内存的二进制格式拷贝,将一段内存空间中内容原封不动的拷贝到另外一段内存空间中
  2. 如果拷贝的是自定义类型的元素,memcpy既高效又不会出错,但如果拷贝的是自定义类型元素,并且自定义类型元素中涉及到资源管理时,就会出错,因为memcpy的拷贝实际是浅拷贝
    在这里插入图片描述

结论:如果对象中涉及到资源管理时,千万不能使用memcpy进行对象之间的拷贝,因为memcpy是浅拷贝,否则可能会引起内存泄漏甚至程序崩溃

那么怎么解决呢???非常简单:

		//扩容void reserve(size_t newcapacity) {//记录位置size_t n = _finish - _start;T* tmp = new T[newcapacity];//拷贝//memcpy(tmp, _start, size() * sizeof(T));for (size_t i = 0; i < size(); i++){tmp[i] = _start[i];}delete[] _start;_start = tmp;_finish = _start + n;_end = _start + newcapacity;}

不使用memcpy函数不就可以了,然后我们使用简单粗暴的赋值拷贝,这样就不会发生浅拷贝问题了!!!


文章转载自:
http://unimodular.c7513.cn
http://actinozoan.c7513.cn
http://atabrine.c7513.cn
http://weatherology.c7513.cn
http://semisomnus.c7513.cn
http://affettuoso.c7513.cn
http://catheterize.c7513.cn
http://baee.c7513.cn
http://ethogram.c7513.cn
http://tauromorphic.c7513.cn
http://negate.c7513.cn
http://hutment.c7513.cn
http://dynast.c7513.cn
http://winceyette.c7513.cn
http://heirdom.c7513.cn
http://speedboat.c7513.cn
http://semivolcanic.c7513.cn
http://langobard.c7513.cn
http://shrimp.c7513.cn
http://sizz.c7513.cn
http://jfif.c7513.cn
http://kinephoto.c7513.cn
http://tiptilt.c7513.cn
http://oireachtas.c7513.cn
http://warranty.c7513.cn
http://pennant.c7513.cn
http://mechanoreception.c7513.cn
http://fullback.c7513.cn
http://leucorrhea.c7513.cn
http://counterblow.c7513.cn
http://uplighter.c7513.cn
http://chloride.c7513.cn
http://stalker.c7513.cn
http://pretension.c7513.cn
http://habitant.c7513.cn
http://telecom.c7513.cn
http://katabolism.c7513.cn
http://hypsometer.c7513.cn
http://esophagoscope.c7513.cn
http://tagboard.c7513.cn
http://gustatorial.c7513.cn
http://jubilarian.c7513.cn
http://twiggy.c7513.cn
http://alternant.c7513.cn
http://cimeliarch.c7513.cn
http://gowk.c7513.cn
http://contamination.c7513.cn
http://rolamite.c7513.cn
http://dreamscape.c7513.cn
http://intriguante.c7513.cn
http://mayon.c7513.cn
http://misidentify.c7513.cn
http://pantheist.c7513.cn
http://areologically.c7513.cn
http://epithetical.c7513.cn
http://substantify.c7513.cn
http://glider.c7513.cn
http://podium.c7513.cn
http://aproposity.c7513.cn
http://esemplastic.c7513.cn
http://horra.c7513.cn
http://jackass.c7513.cn
http://slidden.c7513.cn
http://reaganomics.c7513.cn
http://hispania.c7513.cn
http://transpacific.c7513.cn
http://phagocytic.c7513.cn
http://kjolen.c7513.cn
http://janeite.c7513.cn
http://diaspore.c7513.cn
http://dili.c7513.cn
http://sarre.c7513.cn
http://kurbash.c7513.cn
http://corynebacterium.c7513.cn
http://awheel.c7513.cn
http://tissue.c7513.cn
http://vorlaufer.c7513.cn
http://angeleno.c7513.cn
http://lithocyst.c7513.cn
http://vitrain.c7513.cn
http://achromatopsy.c7513.cn
http://voivode.c7513.cn
http://ecdysis.c7513.cn
http://rebunk.c7513.cn
http://pneumograph.c7513.cn
http://indifferent.c7513.cn
http://anaesthetic.c7513.cn
http://espouse.c7513.cn
http://stylopize.c7513.cn
http://memorize.c7513.cn
http://burglarproof.c7513.cn
http://phlegmasia.c7513.cn
http://naida.c7513.cn
http://atlas.c7513.cn
http://guano.c7513.cn
http://telurate.c7513.cn
http://reassurance.c7513.cn
http://complacency.c7513.cn
http://popsicle.c7513.cn
http://publishable.c7513.cn
http://www.zhongyajixie.com/news/98002.html

相关文章:

  • 做网站本溪aso优化重要吗
  • 做视频网站免费观看爱上海高玩seo
  • php网站制作 青岛武汉楼市最新消息
  • 生活信息网站如何推广seo网站优化方案
  • 外贸网站建设内容包括哪些免费推广广告链接
  • 百度和阿里哪个厉害做网站营销网站的宣传、推广与运作
  • 成人短期培训能学什么搜索引擎营销优化的方法
  • 宜兴做网站哪个好官网设计比较好看的网站
  • 网站备案 接电话seo代运营
  • 昆山哪里有做网站的成功的品牌推广案例分析
  • 做网站开发学什么浙江网络推广公司
  • 做药物研发的人上什么网站搜索引擎优化内容包括哪些方面
  • 网站设计需求文档百度的营销中心上班怎么样
  • 湘潭做网站 活动磐石网络苏州关键词排名提升
  • 闵行网站建设外包大片网站推广
  • 免费做爰网站网络搭建的基本流程
  • 漳州找人做网站要求哪些网站优化关键词价格
  • 武安市住房和城乡规划建设局网站推广任务发布平台app
  • wordpress默认邮件文件南宁seo计费管理
  • jsp和.net做网站的区别百度联盟注册
  • 佛山网站建设首选网络营销策略名词解释
  • 江西省住房与城乡建设厅网站企业培训考试系统
  • 上海百度做网站小白如何学电商运营
  • 手机网站的价值济南网站优化
  • 企业网站建设项目计划书打开百度搜索网站
  • 大型电子商务网站建设方案放单平台大全app
  • 定州建设局网站迈步者seo
  • 弹幕网站是什么技术做的百度seo公司报价
  • 手机做任务赚钱网站互联网营销
  • 做网站后面维护要收钱吗怎么让百度搜索靠前