Aşağıdaki kodu bakınız nesneleri (o here canlı bakınız):Karışıklık
#include <iostream>
#include <tuple>
#include <type_traits>
#include <utility>
struct S {
int&& v;
};
int main() {
std::tuple<int&&> t(1);
std::cout << std::is_same<int, decltype(std::get<0>(t))>{} << std::endl;
std::cout << std::is_same<int&, decltype(std::get<0>(t))>{} << std::endl;
std::cout << std::is_same<int&&, decltype(std::get<0>(t))>{} << std::endl;
S s{1};
std::cout << std::is_same<int&&, decltype(s.v)>{} << std::endl;
}
Ben çıktı 0 0 1 1
görmeyi bekliyorum, ancak GCC ve çınlama hem çıktı 0 1 0 1
yerine verir. Gerçekten kafam karıştı. Birisi bana bir açıklama verebilir mi? std::get
imzasıyla birlikte
std :: tuple_element <0, std :: tuple> :: type & 'döndüren herhangi bir fikir' int & 'int &' + '&' int &? –
James
@Phantom: bak [kısa-açıklama-of-referans-çökmesi-kural] (http://stackoverflow.com/questions/13725747/concise-explanation-of-reference-collapsing-rules-requested-1-aa- 2) – Jarod42
Teşekkür ederim. Tam olarak aradığım şey bu. – James