Tidak, Anda tidak bisa membebani lambda!
Lambda adalah functor anonim (yaitu objek fungsi yang tidak disebutkan namanya), dan bukan fungsi sederhana. Karenanya, membebani benda-benda itu tidak mungkin dilakukan Apa yang pada dasarnya Anda coba lakukan hampir
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
Yang tidak mungkin, karena nama variabel yang sama tidak dapat digunakan kembali dalam C ++.
Namun, dalam c ++ 17 kita memiliki if constexpr
satu yang dapat instantiate satu-satunya cabang yang benar pada waktu kompilasi.
Berarti solusi yang mungkin adalah:
Menggunakan templat variabe Anda bisa melakukan sesuatu seperti. ( Lihat demo langsung 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];
}
};
dan menyebutnya seperti
int r = translate<int>(line[0]);
int c = translate<char>(line[1]);
Menggunakan lambda generik (sejak c ++ 14 ), yang di atas adalah: ( Lihat demo online secara langsung )
#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];
}
};
dan panggil lambda seperti yang Anda lakukan sekarang:
int r = translate(static_cast<int>(line[0]));
int c = translate(static_cast<char>(line[1]));
translate
hanya variabel lokal yang tidak dapat menggunakan kembali nama yang sama.