【求解惑】变参函数模板出现segment fault?

本文探讨了在使用C++变参函数模板时遇到的段错误问题,分析了错误代码的原因,指出编译器可能错误地匹配到变参模板,导致行为不正确。解决方案是调整函数模板的定义,以避免编译器的误匹配。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

在学习变参函数模板的时候,运行如下代码时,出现了段错误:
tem.h

#ifndef TEM_H
#define TEM_H

#include <set>
#include <memory>
#include <iostream>

class Base {};
class Derive1 : public Base {};
class Derive2 : public Base {};
class Derive3 : public Base {};

class Mng {
public:
    static Mng *GetInst()
    {
        static Mng instance;
        return &instance;
    }

    void RegLoad(std::unique_ptr<Base> &&ptr)
    {
        std::cout << "regload" << std::endl;
        mem_.insert(std::move(ptr));
    }

    void RegLoad() {}

    template <typename T, typename... Args>
    void RegLoad(T &&t, Args&&... args)
    {
        RegLoad(std::forward<T>(t));
        RegLoad(std::forward<Args>(args)...);
    }

    uint32_t Size()
    {
        return mem_.size();
    }

private:
    Mng() = default;

    std::set<std::unique_ptr<Base>> mem_;
};

#endif

test.cpp

#include "tem.h"

int main()
{
    Mng::GetInst()->RegLoad(std::make_unique<Derive1>(), std::make_unique<Derive2>(),
         std::make_unique<Derive3>());

    std::cout << Mng::GetInst()->Size() << std::endl;

    return 0;
}

在这里插入图片描述
在这里,实际给mem_赋值的接口也被定义成了RegLoad,编译器可能总是匹配到变参模板函数的RegLoad,而导致行为不符合预期。

修改一下RegLoad的定义即可:

void RegLoad() {}

template <typename T, typename... Args>
void RegLoad(T &&t, Args&&... args)
{
    mem_.insert(std::move(t));
    RegLoad(std::forward<Args>(args)...);
}

在这里插入图片描述
那为什么错误的那版代码会报Segmentation Fault:11错误呢?

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值