c++ bug 记录(merge函数调用时错误地传入了vector对象而非迭代器。)

bug代码:

cpp 复制代码
/*
	函数方法定义实现
*/

void test11() {
	vector<int> v1 = { 1,2,5,6 };
	vector<int> v2 = { 3,4,7,9 };
	vector<int> vt;//目标向量
	vt.resize(v1.size() + v2.size());
	merge(v1.begin(), v1.end(), v2.begin(), v2.end(), vt);

	for_each(vt.begin(), vt.end(), print01);

}
void print01(int val) {
	cout << val << " ";
}

bug原因分析:

一、先看报错信息

plaintext

复制代码
错误 C2100 无法取消引用类型为"_OutIt"的操作数
错误 C2675 一元"++":"_OutIt"不定义该运算符或到预定义运算符可接收类型的转换
with
[
    _OutIt=std::vector<int,std::allocator<int>>
]
  • _OutItmerge 模板的输出迭代器类型。
  • 这里编译器把 _OutIt 推断成了 std::vector<int>(整个容器),而不是迭代器。
  • merge 内部会对输出迭代器做两件事:
    1. *result = value;(解引用赋值)
    2. ++result;(移动到下一个位置)
  • vector 本身是容器,不是迭代器,不能 *vector 也不能 ++vector,所以报错。

二、问题出在哪一行?

cpp

运行

复制代码
merge(v1.begin(), v1.end(), v2.begin(), v2.end(), vt);

merge 的前四个参数是输入范围的迭代器,第五个参数要求是 输出迭代器 (指向存放结果的位置)。你传的 vtvector<int> 对象,而不是迭代器,所以类型错了。


三、正确写法

应该传 输出迭代器 ,而不是容器本身。因为你已经 resizevt,有足够空间,可以直接用 vt.begin() 作为输出位置:

cpp

运行

复制代码
merge(v1.begin(), v1.end(),
      v2.begin(), v2.end(),
      vt.begin()); // ✅ 传迭代器

四、完整可运行代码

cpp

运行

复制代码
#include <iostream>
#include <vector>
#include <algorithm>
using namespace std;

void print01(int val) {
    cout << val << " ";
}

void test11() {
    vector<int> v1 = { 1,2,5,6 };
    vector<int> v2 = { 3,4,7,9 };

    vector<int> vt;
    vt.resize(v1.size() + v2.size()); // 提前分配空间

    // 正确写法:传输出迭代器 vt.begin()
    merge(v1.begin(), v1.end(),
          v2.begin(), v2.end(),
          vt.begin());

    for_each(vt.begin(), vt.end(), print01);
}

int main() {
    test11();
    return 0;
}

输出:

plaintext

复制代码
1 2 3 4 5 6 7 9

五、补充:如果你不想手动 resize

可以用 back_inserter(定义在 <iterator>)让 merge 自动 push_back

cpp

运行

复制代码
#include <iterator> // back_inserter 头文件

vector<int> vt; // 不用提前 resize
merge(v1.begin(), v1.end(),
      v2.begin(), v2.end(),
      back_inserter(vt)); // 自动插入到 vt 末尾

这样就不需要手动分配空间,更安全。


六、总结 bug 原因

  • 直接传了 vector 对象给 merge 的输出参数 ,而 merge 需要的是迭代器;
  • 容器不是迭代器,不能解引用和递增,导致编译报错;
  • 修复方法
    1. 如果容器已分配好空间,用 vt.begin()
    2. 如果容器未分配空间,用 back_inserter(vt) 自动插入。
相关推荐
身如柳絮随风扬36 分钟前
Java中的CAS机制详解
java·开发语言
-dzk-2 小时前
【代码随想录】LC 59.螺旋矩阵 II
c++·线性代数·算法·矩阵·模拟
风筝在晴天搁浅2 小时前
hot100 78.子集
java·算法
m0_706653233 小时前
C++编译期数组操作
开发语言·c++·算法
故事和你913 小时前
sdut-Java面向对象-06 继承和多态、抽象类和接口(函数题:10-18题)
java·开发语言·算法·面向对象·基础语法·继承和多态·抽象类和接口
qq_423233903 小时前
C++与Python混合编程实战
开发语言·c++·算法
m0_715575343 小时前
分布式任务调度系统
开发语言·c++·算法
Configure-Handler3 小时前
buildroot System configuration
java·服务器·数据库
CSDN_RTKLIB4 小时前
简化版unique_ptr说明其本质
c++
naruto_lnq4 小时前
泛型编程与STL设计思想
开发语言·c++·算法