模板函数中未解析的外部符号

Unresolved external symbol in template function

提问人:Simo Pelle 提问时间:2/6/2020 最后编辑:1201ProgramAlarmSimo Pelle 更新时间:2/6/2020 访问量:296

问:

我在 Visual Studio 2019 中创建了这个静态库,但出现以下错误:

unresolved external symbol "unsigned short __cdecl method2<unsigned short>(class std::basic_string<char,struct std::char_traits<char>,class std::allocator<char>> const &,unsigned short)"
??$method2@G@@YAGABV?$basic_string@DU?$char_traits@D@std@@V?$allocator@D@2@@std@@G@Z)
//Lib.h

#pragma once
#include "Enter.h"
#include <iostream>
#include <string>

template <typename T>
T method1(const std::string& = "", T = -1);

template <typename T>
T method2(const std::string& = "", T = -1);

//Lib.cpp

#include "pch.h"
#include "Lib.h"
using namespace std;

unsigned short method1(const string& text, unsigned short max)
{
    string ins;
    unsigned short val;

    while (true)
    {
        cout << text;
        getline(cin, ins);

        try
        {
            if (cin.fail()) cin.clear();
            val = stoi(ins);
            if (val > max) throw val;
        }
        catch (...)
        {
            cerr << "Risposta non valida!";
            Enter(2);
            continue;
        }

        break;
    }

    return val;
}
unsigned method1(const string& text, unsigned max)
{
    string ins;
    unsigned val;

    while (true)
    {
        cout << text;
        getline(cin, ins);

        try
        {
            if (cin.fail()) cin.clear();
            val = stoi(ins);
            if (val > max) throw val;
        }
        catch (...)
        {
            cerr << "Risposta non valida!";
            Enter(2);
            continue;
        }

        break;
    }

    return val;
}
unsigned long method1(const string& text, unsigned long max)
{
    string ins;
    unsigned long val;

    while (true)
    {
        cout << text;
        getline(cin, ins);

        try
        {
            if (cin.fail()) cin.clear();
            val = stoi(ins);
            if (val > max) throw val;
        }
        catch (...)
        {
            cerr << "Risposta non valida!";
            Enter(2);
            continue;
        }

        break;
    }

    return val;
}
unsigned long long method1(const string& text, unsigned long long max)
{
    string ins;
    unsigned long long val;

    while (true)
    {
        cout << text;
        getline(cin, ins);

        try
        {
            if (cin.fail()) cin.clear();
            val = stoi(ins);
            if (val > max) throw val;
        }
        catch (...)
        {
            cerr << "Risposta non valida!";
            Enter(2);
            continue;
        }

        break;
    }

    return val;
}

unsigned short method2(const string& text, unsigned short max)
{
    unsigned short val;

    while (true)
    {
        cout << text;
        if (cin >> val && val <= max) break;

        cin.clear();
        cin.ignore(numeric_limits<streamsize>::max(), '\n');

        cerr << "Risposta non valida!";
        Enter(2);
    }
    cin.ignore(numeric_limits<streamsize>::max(), '\n');

    return val;
}
unsigned method2(const string& text, unsigned max)
{
    unsigned val;

    while (true)
    {
        cout << text;
        if (cin >> val && val <= max) break;

        cin.clear();
        cin.ignore(numeric_limits<streamsize>::max(), '\n');

        cerr << "Risposta non valida!";
        Enter(2);
    }
    cin.ignore(numeric_limits<streamsize>::max(), '\n');

    return val;
}
unsigned long method2(const string& text, unsigned long max)
{
    unsigned long val;

    while (true)
    {
        cout << text;
        if (cin >> val && val <= max) break;

        cin.clear();
        cin.ignore(numeric_limits<streamsize>::max(), '\n');

        cerr << "Risposta non valida!";
        Enter(2);
    }
    cin.ignore(numeric_limits<streamsize>::max(), '\n');

    return val;
}
unsigned long long method2(const string& text, unsigned long long max)
{
    unsigned long long val;

    while (true)
    {
        cout << text;
        if (cin >> val && val <= max) break;

        cin.clear();
        cin.ignore(numeric_limits<streamsize>::max(), '\n');

        cerr << "Risposta non valida!";
        Enter(2);
    }
    cin.ignore(numeric_limits<streamsize>::max(), '\n');

    return val;
}

//main.cpp

#include <vector>
struct Client
{
    std::string name;
    unsigned short age;
};

int main()
{
    std::vector<Client> mylist;
    mylist.push_back({ temp, method2<unsigned short>("Insert age: ", 120) });
}

我在 Lib.h 中还收到两个警告:

未找到“方法 1”的函数定义。 未找到“方法 2”的函数定义。

我做错了什么?我已经遵循了这些说明(替代解决方案)。

“内联”定义对我来说不是正确的方式,因为我需要只有这些类型才能被调用......

C++ 函数 模板 unresolved-external

评论

0赞 n314159 2/6/2020
您似乎想对模板函数进行完全专业化。为此,您需要在定义之前添加 a。template<>
0赞 Simo Pelle 2/6/2020
@n314159即使我不使用它?对于每个定义还是仅针对一个定义?
0赞 walnut 2/6/2020
'内联'定义对我来说不是正确的方式,因为我需要只有这些类型才能被调用......”到底是什么意思?您可以使用 SFINAE/ 使模板有选择地可用于某些类型。std::enable_if
0赞 n314159 2/6/2020
@stacking 是的,你需要告诉编译器你想专门化这个函数,而不是以其他方式覆盖它。
0赞 Simo Pelle 2/6/2020
@n314159谢谢,它奏效了!

答: 暂无答案