No, non puoi sovraccaricare la lambda!
Le lambda sono funzioni anonime (ovvero oggetti funzione senza nome) e non semplici funzioni. Pertanto, non è possibile sovraccaricare quegli oggetti. Quello che sostanzialmente stai cercando di fare è quasi
struct <some_name>
{
int operator()(int idx) const
{
return {}; // some int
}
}translate; // >>> variable name
struct <some_name>
{
int operator()(char idx) const
{
return {}; // some int
}
}translate; // >>> variable name
Ciò non è possibile, poiché lo stesso nome di variabile non può essere riutilizzato in C ++.
Tuttavia, in c ++ 17 abbiamo per if constexpr
mezzo del quale si può istanziare l'unico ramo che è vero al momento della compilazione.
Ciò significa che le possibili soluzioni sono:
- Un unico modello lambda variabe . o
- Un lambda generico e trova il tipo di parametro usando
decltype
per il if constexpr
controllo. (Credits @NathanOliver )
Usando il modello variabe puoi fare qualcosa di simile. ( Guarda una demo live online )
#include <type_traits> // std::is_same_v
template<typename T>
constexpr auto translate = [](T idx)
{
if constexpr (std::is_same_v<T, int>)
{
constexpr static int table[8]{ 7,6,5,4,3,2,1,0 };
return table[idx];
}
else if constexpr (std::is_same_v<T, char>)
{
std::map<char, int> table{ {'a', 0}, {'b', 1}, {'c', 2}, {'d', 3}, {'e', 4}, {'f', 5}, {'g', 6}, {'h', 7} };
return table[idx];
}
};
e chiamalo come
int r = translate<int>(line[0]);
int c = translate<char>(line[1]);
Usando lambda generico (dal c ++ 14 ), quanto sopra sarà: ( Guarda una demo live online )
#include <type_traits> // std::is_same_v
constexpr auto translate = [](auto idx)
{
if constexpr (std::is_same_v<decltype(idx), int>)
{
constexpr static int table[8]{ 7,6,5,4,3,2,1,0 };
return table[idx];
}
else if constexpr (std::is_same_v<decltype(idx), char>)
{
std::map<char, int> table{ {'a', 0}, {'b', 1}, {'c', 2}, {'d', 3}, {'e', 4}, {'f', 5}, {'g', 6}, {'h', 7} };
return table[idx];
}
};
e chiama il lambda come fai ora:
int r = translate(static_cast<int>(line[0]));
int c = translate(static_cast<char>(line[1]));
translate
sono solo variabili locali che non possono riutilizzare lo stesso nome.