Přidat otázku mezi oblíbenéZasílat nové odpovědi e-mailemVyřešeno C++, pole konstant, předání parametrů, jak na to?

Ahoj.... mám v tom hokej, přímo NHL...
potřebuju udělat něco takovýho:


const char pole1[] PROGMEM={1,2,3,4,5};
const char pole2[] PROGMEM={6,7,8,9,0};
const char pole3[] PROGMEM={a,s,d,f,g};

void ctipole(int pole) {
  for(byte i=0; i<5; i++) {
    byte hodnota=pgm_read_byte(&pole[i]);
    //nějaké další akce....
  }
}

int main(void) {
  ctipole(*pole1);
  ctipole(*pole2);
  ctipole(*pole3);
}   

kompilátor mě s tím posílá do prdele a já nevím jak to udělat, kde dát *, &, kde dát int nebo byte nebo co vlastně...
Když to napíšu takhle:


....
void ctipole() {
  for(byte i=0; i<5; i++) {
    byte hodnota=pgm_read_byte(&pole1[i]);
    //další akce...
  }
}

tak to chodí. Jenže to bych musel psát tři podprogramy pro jednu a tu samou věc, která se liší jen ukazatelem na pole konstant

Jak 100hoven?

Jsou zobrazeny jen nové odpovědi. Zobrazit všechny
Předmět Autor Datum
ufff... Jediné čeho chci dosáhnout je předat adresu konkrétního pole konstant podprogramu, tak abych…
mia 03.07.2018 13:44
mia
const char pole1[] PROGMEM={ 1, 2, 3, 4, 5}; const char pole2[] PROGMEM={ 6, 7, 8, 9, 0}; const char…
vladah 03.07.2018 13:48
vladah
int main(void) { ctipole(pole1); ctipole(pole2); ctipole(pole3); } sa mi zdá ako zbytočné opakovani…
Mlocik97 03.07.2018 13:52
Mlocik97
Možná se zkus nesoustředit jenom na mě, ale třeba i na tazatele :-) int main(void) { ..... if(podmi…
vladah 03.07.2018 13:56
vladah
Máš to marný, tohle přerostlý děcko chce a musí být středem pozornosti, jakmile ji nemá, začne ti mí…
Killer of amphibians 03.07.2018 14:00
Killer of amphibians
Ty čská nudle choď do piče :-) zasedlej týpek.... čo dislikuje len preto že mám za nickom číslo vätš…
Mlocik97 03.07.2018 14:02
Mlocik97
Nebo co? Hodláš mi vyhrožovat? Jediný se tu chováš jako pablb a jediný porušuješ pravidla fóra, já s… nový
Killer of amphibians 03.07.2018 14:04
Killer of amphibians
tebe fakt dobre jebe.... ;-) ostatne tys porušil pravidlá fóra už toľko krát taky... a nie len to,..… nový
Mlocik97 03.07.2018 14:06
Mlocik97
Oneskorená puberta? poslední
pozorovateľ 03.07.2018 16:45
pozorovateľ
Když som to psal tak tazatel nepísal nič o tom že by nechcel jednotlivé polia použiť naraz. To napsa… nový
Mlocik97 03.07.2018 14:02
Mlocik97
Mel jsem predtim jenom pocit, ze tady celou dobu jenom trollujes, ale ted uz to vim jiste. Nikdo nem… nový
vladah 03.07.2018 14:05
vladah
To som psal k tvojmu kódu nie ku kódu tazatele. Chápeš? Neviem kto je tady tupý. Ostatne pravda, kdy… nový
Mlocik97 03.07.2018 14:09
Mlocik97
Já bych to neudělal, pokud bys nenapsal blbost. Nebo kdybys alespoň odpověděl na otázku. PS: všiml… nový
vladah 03.07.2018 14:27
vladah
Aby si nezačal stěžovat, že ho diskriminuješ prosím tě :D nový
Killer of amphibians 03.07.2018 14:50
Killer of amphibians
ano, tohle funguje, jen ve "void ctipole (int *pole)" nesmí být (int *pole) ale (const char *pole),… nový
mia 03.07.2018 15:33
mia
Takže som správne napsal s tým char* .... vladah napíšeš mi niečo k tomuto? inak som rád že to tazat… nový
Mlocik97 03.07.2018 16:06
Mlocik97

ufff... Jediné čeho chci dosáhnout je předat adresu konkrétního pole konstant podprogramu, tak abych mohl podprogram volat z mainu kdykoliv a v závorce mu předat z čeho má číst. Takže vícerozměrné pole nechci, protože nebudu konstanty číst najednou ale různě, v závislosti např výsledku podmínky...


int main(void) {
.....
  if(podminka) ctipole(pole1);
  if(jinapodminka) ctipole(pole3);
.....
}

v ctipole() v cyklu bych použil for(byte i=0; i<sizeof(pole); i++)

cout neznám, půjde to použít pro vyčtení hodnoty z FLASH paměti? (pole je v PROGMEM)

const char pole1[] PROGMEM={ 1, 2, 3, 4, 5};
const char pole2[] PROGMEM={ 6, 7, 8, 9, 0};
const char pole3[] PROGMEM={ 'a', 's', 'd', 'f', 'g'};

void ctipole(int *pole) {
  for(byte i=0; i<5; i++) {
    byte hodnota=pgm_read_byte(&pole[i]);
    //nějaké další akce....
  }
}

int main(void) {
  ctipole(pole1);
  ctipole(pole2);
  ctipole(pole3);
}

viz. moje prvni odpoved.

int main(void) {
  ctipole(pole1);
  ctipole(pole2);
  ctipole(pole3);
}

sa mi zdá ako zbytočné opakovanie,... čo tak for cyklus a "číslo pola" dosadzovať z indexu cyklu for? (i když ak to budú stále len 3 "čítania" tak pre také množstvo je to ešte ok.

Máš to marný, tohle přerostlý děcko chce a musí být středem pozornosti, jakmile ji nemá, začne ti mínuskovat komentáře :D Prostě poraď tazateli a na Mloka se vykašli, je to šašek co nic neumí a do všech rýpe.

Ty čská nudle choď do piče :-) zasedlej týpek.... čo dislikuje len preto že mám za nickom číslo vätšie než 80.

Nebo co? Hodláš mi vyhrožovat? Jediný se tu chováš jako pablb a jediný porušuješ pravidla fóra, já si jen počkám :) Užívej dne Mloku, karma tě stejně dostane ;) (Btw jsem rád že si už začal nadávat, alespoň se konečně vybarvuješ :)))

tebe fakt dobre jebe.... ;-) ostatne tys porušil pravidlá fóra už toľko krát taky... a nie len to,... hanovenie národnosti ti taky nic nevraví, ešte stále si myslíš že jsem čech? Ty seš už vyfarbil úplne. Čo si zatím poradil ty? celú dobu v tomto vlákne len pičujete. A ty nudle pičuješ v každom vlákne a nič neradíš.

Když som to psal tak tazatel nepísal nič o tom že by nechcel jednotlivé polia použiť naraz. To napsal kedy? už dávno potom. Ostatne po tom čo dodal tazateľ že bude tie poľa čítať nezávysle na sebe tak pak áno súhlasím že 2D tam použiť je nie nemožné ale zbytočne problematické.

To som psal k tvojmu kódu nie ku kódu tazatele. Chápeš? Neviem kto je tady tupý. Ostatne pravda, když som psal ten jeden konkrétny príspevok som ešte nemal prečítaný koment od tazatele. OK uznávam že v prípade toho jedneho komentu som to napsal blbo, i když to je rovnako blbo napsané v tvojom kóde. Za to ovšem nemusíš hneď útočiť. Kdybys nezaútočil na mňa hneď v prvom príspevku celé by toto tu vyzeralo inak :-)

Já bych to neudělal, pokud bys nenapsal blbost. Nebo kdybys alespoň odpověděl na otázku.

PS: všiml jsem si, že kromě dislajkování všech mých komentářů, jsi opravil všechny ty své. To by odpovídalo tomu, že píšeš první blbost co tě napadne. Není divu, že pak vybleješ to, co jsi vyblil nahoře :-)
Nejhorší pak je, že si to za každou cenu pak snažíš obhajovat.

ano, tohle funguje, jen ve "void ctipole (int *pole)" nesmí být (int *pole) ale (const char *pole), jinak mě překladač vyfakuje, že nejde provést konverzi mezi int* a const char*...

DÍKY!!! :-)

Takže som správne napsal s tým char* .... vladah napíšeš mi niečo k tomuto? inak som rád že to tazateľ vyriešil. Ja bych povedal že poľku pravdy som mal ja a polku vladah.

Zpět do poradny Odpovědět na původní otázku Nahoru