abclinuxu.cz AbcLinuxu.cz itbiz.cz ITBiz.cz HDmag.cz HDmag.cz abcprace.cz AbcPráce.cz
AbcLinuxu hledá autory!
Inzerujte na AbcPráce.cz od 950 Kč
Rozšířené hledání
×
    dnes 18:44 | Zajímavý článek

    Nová čísla časopisů od nakladatelství Raspberry Pi zdarma ke čtení: Raspberry Pi Official Magazine 155 (pdf) a Hello World 27 (pdf).

    Ladislav Hagara | Komentářů: 0
    dnes 16:11 | Nová verze

    Hyprland, tj. kompozitor pro Wayland zaměřený na dláždění okny a zároveň grafické efekty, byl vydán ve verzi 0.50.0. Podrobný přehled novinek na GitHubu.

    Ladislav Hagara | Komentářů: 0
    dnes 15:55 | Komunita

    Patrick Volkerding oznámil před dvaatřiceti lety vydání Slackware Linuxu 1.00. Slackware Linux byl tenkrát k dispozici na 3,5 palcových disketách. Základní systém byl na 13 disketách. Kdo chtěl grafiku, potřeboval dalších 11 disket. Slackware Linux 1.00 byl postaven na Linuxu .99pl11 Alpha, libc 4.4.1, g++ 2.4.5 a XFree86 1.3.

    Ladislav Hagara | Komentářů: 2
    včera 21:22 | IT novinky

    Ministerstvo pro místní rozvoj (MMR) jako první orgán státní správy v Česku spustilo takzvaný „bug bounty“ program pro odhalování bezpečnostních rizik a zranitelných míst ve svých informačních systémech. Za nalezení kritické zranitelnosti nabízí veřejnosti odměnu 1000 eur, v případě vysoké závažnosti je to 500 eur. Program se inspiruje přístupy běžnými v komerčním sektoru nebo ve veřejné sféře v zahraničí.

    Ladislav Hagara | Komentářů: 13
    včera 16:22 | IT novinky

    Vláda dne 16. července 2025 schválila návrh nového jednotného vizuálního stylu státní správy. Vytvořilo jej na základě veřejné soutěže studio Najbrt. Náklady na přípravu návrhu a metodiky činily tři miliony korun. Modernizovaný dvouocasý lev vychází z malého státního znaku. Vizuální styl doprovází originální písmo Czechia Sans.

    Ladislav Hagara | Komentářů: 24
    včera 15:33 | Upozornění

    Vyhledávač DuckDuckGo je podle webu DownDetector od 2:15 SELČ nedostupný. Opět fungovat začal na několik minut zhruba v 15:15. Další služby nesouvisející přímo s vyhledáváním, jako mapyAI asistent jsou dostupné. Pro některé dotazy během výpadku stále funguje zobrazování například textu z Wikipedie.

    bindiff | Komentářů: 8
    včera 13:33 | Bezpečnostní upozornění

    Více než 600 aplikací postavených na PHP frameworku Laravel je zranitelných vůči vzdálenému spuštění libovolného kódu. Útočníci mohou zneužít veřejně uniklé konfigurační klíče APP_KEY (např. z GitHubu). Z více než 260 000 APP_KEY získaných z GitHubu bylo ověřeno, že přes 600 aplikací je zranitelných. Zhruba 63 % úniků pochází z .env souborů, které často obsahují i další citlivé údaje (např. přístupové údaje k databázím nebo cloudovým službám).

    Ladislav Hagara | Komentářů: 5
    včera 00:11 | Nová verze

    Open source modální textový editor Helix, inspirovaný editory Vim, Neovim či Kakoune, byl vydán ve verzi 25.07. Přehled novinek se záznamy terminálových sezení v asciinema v oznámení na webu. Detailně v CHANGELOGu na GitHubu.

    Ladislav Hagara | Komentářů: 0
    15.7. 20:44 | IT novinky

    Americký výrobce čipů Nvidia získal od vlády prezidenta Donalda Trumpa souhlas s prodejem svých pokročilých počítačových čipů používaných k vývoji umělé inteligence (AI) H20 do Číny. Prodej těchto čipů speciálně upravených pro čínský trh by tak mohl být brzy obnoven, uvedla firma na svém blogu. Americká vláda zakázala prodej v dubnu, v době eskalace obchodního sporu mezi oběma zeměmi. Tehdy to zdůvodnila obavami, že by čipy mohla využívat čínská armáda.

    Ladislav Hagara | Komentářů: 10
    15.7. 17:22 | Nová verze

    3D software Blender byl vydán ve verzi 4.5 s prodlouženou podporou. Podrobnosti v poznámkách k vydání. Videopředstavení na YouTube.

    Ladislav Hagara | Komentářů: 0
    Jaký je váš oblíbený skriptovací jazyk?
     (59%)
     (27%)
     (7%)
     (3%)
     (0%)
     (1%)
     (4%)
    Celkem 409 hlasů
     Komentářů: 16, poslední 8.6. 21:05
    Rozcestník

    Dotaz: Céčko - načtení proměnné a použití jejího obsahu jako název jiné proměnné

    11.12.2011 23:05 Jan
    Céčko - načtení proměnné a použití jejího obsahu jako název jiné proměnné
    Přečteno: 435×
    Mám vytvořené pole osoba[100] obsahující strukturu s položkama jmeno, prijmeni, adresa, tel, email, a další. Potřeboval bych ve funkci hledej, které jsou předávány paramtery (co, kde) zajistit, pokud je do promenne "kde" vlozen retezec napriklad "adresa", abych se pomocí této proměnné dostal na správné místo struktury ve smyslu - najdi_osobu_ktera_obsahuje_retezec_stejny_jako_co a hledej v osoba[i].(zde_by_se_mel_vyhodnotit_obsah_promenne_"kde"), neboli např. osoba[i].adresa.

    Tento požadavek by se dal obejít prohledáním celé struktury, nebo pro každou položku struktury mít jeden - if (strcmp(kde, "adresa") = 1) {hledej v osoba[i].adresa}, if (strcmp(kde, "jmeno") = 1) {hledej v osoba[i].jmeno}, ale to mně nepřijde příliš správné řešení.

    Prosím kohokoli o sebemenší radu. Děkuji mnohokrát

    Řešení dotazu:


    Odpovědi

    Luboš Doležel (Doli) avatar 11.12.2011 23:06 Luboš Doležel (Doli) | skóre: 98 | blog: Doliho blog | Kladensko
    Rozbalit Rozbalit vše Re: Céčko - načtení proměnné a použití jejího obsahu jako název jiné proměnné
    C/C++ nemá reflexi, takže bez nějakého ručního mapování mezi názvem proměnné a offsetem ve struktuře to nepůjde.
    11.12.2011 23:14 Jan
    Rozbalit Rozbalit vše Re: Céčko - načtení proměnné a použití jejího obsahu jako název jiné proměnné
    Děkuji za reakci. Přiznám se, že si nevím rady, jak takovou cestu namapovat. Využití ukazatelů jsem zavrhl, protože ty problém neřeší. Mohu poprosit o trochu konkrétnější radu? Nechci řešení, jen vědět, jakým směrem se ubírat. V programování jsem začátečník, ale tímto bych se chtěl vyhnout redundantnosti kódu.
    12.12.2011 00:57 l4m4
    Rozbalit Rozbalit vše Re: Céčko - načtení proměnné a použití jejího obsahu jako název jiné proměnné
    Je zapotřebí mít definovánu tabulku asociující ta jména (která nemusí mít reálně nic společného se skutečnými jmény datových členů struktury) s offsety ve struktuře (viz např. definice G_STRUCT_OFFSET a G_STRUCT_MEMBER_P pro přenositelný způsob, jak to realizovat).

    Pak se hledání skládá ze dvou kroků: (a) projití tabulky a nalezení offsetu datového členu, který odpovídá danému typu dotazu identifikovaného nějakým tím stringem (b) vlastní generické hledání, které používá ten zjištěný offset.
    12.12.2011 00:00 ::: | skóre: 14 | blog: e_lama
    Rozbalit Rozbalit vše Re: Céčko - načtení proměnné a použití jejího obsahu jako název jiné proměnné
    tohle v c bez sequence if-u nebo bez nejaky mapovaci struktury nepujde. Jestli ti nevadi c++ tak nejjednoduzsi (ne nejefektivnejsi) by bylo nahradit strukturu s informacemi o osobe za std::map
    #include <iostream>
    #include <string>
    #include <map>
    
    typedef std::map<std::string, std::string> osoba_t;
    
    int main()
    {
            osoba_t osoba;
            
            osoba["adresa"] = "mars colony";
            osoba["jmeno"] = "Douglas Quaid";
            
            std::cout << "jmeno = " << osoba["jmeno"] << ", adresa = " << osoba["adresa"] << "\n";
    }
    
    Josef Kufner avatar 12.12.2011 14:04 Josef Kufner | skóre: 70
    Rozbalit Rozbalit vše Re: Céčko - načtení proměnné a použití jejího obsahu jako název jiné proměnné
    Pro 100 položek nemá smysl vymýšlet nějaké složitosti, tím spíš, když to je jen domácí úkol.

    Projdi to pole jednu položku po druhé a napíš těch 5 ifů. Aby to nebylo až tak úplně pomalé, ukončuj porovnávání ihned jak to půjde, abys v ideálním případě při nulové shodě porovnával jen první znak.

    Pokud bys těch osob měl pár tisíc a chtěl to mít opravdu hezky, asi by stálo za to si udělat index, kde by byla hodnota, v jaké položce je a pointer na osobu do toho pole. Tan index by byl seřazen podle hodnoty a pomocí bsearch bys po tom pobíhal.
    Hello world ! Segmentation fault (core dumped)
    12.12.2011 14:28 ::: | skóre: 14 | blog: e_lama
    Rozbalit Rozbalit vše Re: Céčko - načtení proměnné a použití jejího obsahu jako název jiné proměnné
    Pokud bys těch osob měl pár tisíc a chtěl to mít opravdu hezky, asi by stálo za to si udělat index, kde by byla hodnota, v jaké položce je a pointer na osobu do toho pole. Tan index by byl seřazen podle hodnoty a pomocí bsearch bys po tom pobíhal.
    s binarnim vyhledavanim bych byl opatrnej. Ono ma sice lepsi asymptotickou slozitost, ale pro maly n je pomalejsi. Hlavni duvod je pravdepodobne obtizna predikce skoku.

    Kdysi jsem s tim delal nejaky pokusy a binarni vyhledavani bylo rychlejsi nez sequencni hledani az pri asi n > 30

    Pokud bych chtel max rychlost tak bych to udelal nejak takhle:
    struct osoba_t
    {
            char *jmeno;
            char *adresa;
            ...
    }
    
    char *najdi_pole(osoba_t *o, char *pole)
    {
            if (!strcmp(pole, "jmeno")) { return o->jmeno; }
            else if (!strcmp(pole, "adresa")) { return o->adresa; }
            else { ... }
    }
    
    takhle bude mit vyhledavani v jedny funkci takze tam nebude zadna redundance a pokud v ty strukture nema moc polozek tak to bude i rychly.

    Ty if-y navic muze seradit tak aby ty nejcastejsi byly na zacatku.
    Josef Kufner avatar 12.12.2011 15:27 Josef Kufner | skóre: 70
    Rozbalit Rozbalit vše Re: Céčko - načtení proměnné a použití jejího obsahu jako název jiné proměnné
    Pokud bys těch osob měl pár tisíc a chtěl to mít opravdu hezky...
    Hello world ! Segmentation fault (core dumped)
    12.12.2011 15:52 ::: | skóre: 14 | blog: e_lama
    Rozbalit Rozbalit vše Re: Céčko - načtení proměnné a použití jejího obsahu jako název jiné proměnné
    v tomhle pripade ale n = pocet polozek ve strukture, ne pocet struktur. Takze odhadem kolem 10...

    Pokud s tim teda nemyslel ze by se udelal jeden velkej strom ve kterym by byly vsechny pouzity retezce a u kazdyho nejaky seznam dvojic (osoba, pole). To by pro velkej pocet osob bylo rychlejsi... v podstate ta volba nejlepsiho algoritmu dost zalezi na ocekavanym 'n' :-)
    Josef Kufner avatar 12.12.2011 21:43 Josef Kufner | skóre: 70
    Rozbalit Rozbalit vše Re: Céčko - načtení proměnné a použití jejího obsahu jako název jiné proměnné
    Však tak jsem to napsal.

    Jeden index: hodnota -> (osoba, položka)

    Velikost: indexu = počet osob * počet položek
    Hello world ! Segmentation fault (core dumped)
    Fluttershy, yay! avatar 12.12.2011 15:25 Fluttershy, yay! | skóre: 93 | blog:
    Rozbalit Rozbalit vše Re: Céčko - načtení proměnné a použití jejího obsahu jako název jiné proměnné
    Jak radí výš, hodila by se asociativní tabulka, ale u tohoto úkolu je to kanón na vrabce. Prostě tam prdni něco ifů.
    🇵🇸Touch grass🇺🇦 ✊ ani boha, ani pána

    Založit nové vláknoNahoru

    Tiskni Sdílej: Linkuj Jaggni to Vybrali.sme.sk Google Del.icio.us Facebook

    ISSN 1214-1267   www.czech-server.cz
    © 1999-2015 Nitemedia s. r. o. Všechna práva vyhrazena.