Diskuze: "Range-based for" smyčka
V předchozím kvízu, Online test znalostí C++, jsme si ověřili nabyté zkušenosti z kurzu.
Člen
Zobrazeno 11 zpráv z 11.
//= Settings::TRACKING_CODE_B ?> //= Settings::TRACKING_CODE ?>
V předchozím kvízu, Online test znalostí C++, jsme si ověřili nabyté zkušenosti z kurzu.
Další situace, které nerozumím je to, že výše zmíněný kus kódu, mi ve funkci main funguje tak, jak má. Pokud ale stejný kód použiji v metodě třídy, dostávám error "begin and end was not declared in this scope".
void List::removeAll(int d[]){
for(int& i : d)
removeAll(i);
Pozn: Metoda removeAll je přetížená, takže removeAll(i) je v
pořádku.
Budu vděčný za odezvu.
Respektive, že se do x uloží hodnota uložená na adrese pole my_array a poté se adresa x zvětšuje o 1.
Já tomu rozumím tak, že se v každé iteraci vzniká proměnná i, což je reference na int a postupně se směruje na jednotlivé položky zadaného pole (v jedné iteraci na jednu položku). To je samozřejmě pohled bez optimalizací. Optimalizovaný kód bude vypadat trochu jinak.
error "begin and end was not declared in this scope"
Protože ta funkce neví, jak velké pole jsi ji předal. V C/C++ je pole v zásadě jen ukazatel na jeho první prvek a následující výrazy jsou ekvivalentní:
a[i]
*(a + i)
A jelikož není známá velikost toho pole, for smyčka neví, kdy má skončit.
Aha, ale jak tedy obejít to, že předem nevím, jak velké pole bude vstupovat do funkce jako parametr?
Nebo si velikost pole předávat také jako parametr funkce, pokud se ti nelíbí režie zavedená použitím kontejneru (např ten std::vector<T>). Pak ale samozřejmě nepůjde použít tento fajnový konstrukt for cyklu.
To byla nouzová situace, ale mě se nelíbilo předávat délku pole jako parametr. Vektor mi asi vyhovuje více pro tento účel.
Hmm to vidím poprvé :
int my_array[] = {1, 2, 3, 4, 5};
for(int& x : my_array)
{
cout<<x<<endl;
}
není to jen jednodušší varianta foreach ?
int my_array[] = {1, 2, 3, 4, 5};
for each(int x in my_array)
{
cout<<x<<endl;
}
kde je úplně jedno jak je pole dlouhé
for each
není ve standardu klasického C++ (https://msdn.microsoft.com/…s177202.aspx), ale s
range-based for jde dělat to samé. Bude to fungovat i pro vlastní typy, pokud
pro ně definuješ metody begin
a end
, které vrátí
iterátor.
Zobrazeno 11 zpráv z 11.