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 17:22 | IT novinky

    Josef Průša oznámil zveřejnění kompletních CAD souborů rámů tiskáren Prusa CORE One a CORE One L. Nejsou vydány pod obecnou veřejnou licenci GNU ani Creative Commons ale pod novou licencí OCL neboli Open Community License. Ta nepovoluje prodávat kompletní tiskárny či remixy založené na těchto zdrojích.

    Ladislav Hagara | Komentářů: 2
    dnes 17:00 | Komunita

    Nový CEO Mozilla Corporation Anthony Enzor-DeMeo tento týden prohlásil, že by se Firefox měl vyvinout v moderní AI prohlížeč. Po bouřlivých diskusích na redditu ujistil, že v nastavení Firefoxu bude existovat volba pro zakázání všech AI funkcí.

    Ladislav Hagara | Komentářů: 0
    dnes 10:11 | IT novinky

    V pořadí šestou knihou autora Martina Malého, která vychází v Edici CZ.NIC, správce české národní domény, je titul Kity, bity, neurony. Kniha s podtitulem Moderní technologie pro hobby elektroniku přináší ucelený pohled na svět současných technologií a jejich praktické využití v domácích elektronických projektech. Tento knižní průvodce je ideální pro každého, kdo se chce podívat na současné trendy v oblasti hobby elektroniky, od

    … více »
    Ladislav Hagara | Komentářů: 1
    dnes 03:11 | Komunita

    Linux Foundation zveřejnila Výroční zprávu za rok 2025 (pdf). Příjmy Linux Foundation byly 311 miliónů dolarů. Výdaje 285 miliónů dolarů. Na podporu linuxového jádra (Linux Kernel Project) šlo 8,4 miliónu dolarů. Linux Foundation podporuje téměř 1 500 open source projektů.

    Ladislav Hagara | Komentářů: 0
    dnes 02:11 | Zajímavý článek

    Jean-Baptiste Mardelle se v příspěvku na blogu rozepsal o novinkám v nejnovější verzi 25.12.0 editoru videa Kdenlive (Wikipedie). Ke stažení také na Flathubu.

    Ladislav Hagara | Komentářů: 0
    dnes 02:00 | Nová verze

    OpenZFS (Wikipedie), tj. implementace souborového systému ZFS pro Linux a FreeBSD, byl vydán ve verzi 2.4.0.

    Ladislav Hagara | Komentářů: 0
    dnes 01:00 | IT novinky

    Kriminalisté z NCTEKK společně s českými i zahraničními kolegy objasnili mimořádně rozsáhlou trestnou činnost z oblasti kybernetické kriminality. V rámci operací OCTOPUS a CONNECT ukončili činnost čtyř call center na Ukrajině. V prvním případě se jednalo o podvodné investice, v případě druhém o podvodné telefonáty, při kterých se zločinci vydávali za policisty a pod legendou napadeného bankovního účtu okrádali své oběti o vysoké finanční částky.

    Ladislav Hagara | Komentářů: 4
    včera 14:44 | IT novinky

    Na lepší pokrytí mobilním signálem a dostupnější mobilní internet se mohou těšit cestující v Pendolinech, railjetech a InterPanterech Českých drah. Konsorcium firem ČD - Telematika a.s. a Kontron Transportation s.r.o. dokončilo instalaci 5G opakovačů mobilního signálu do jednotek Pendolino a InterPanter. Tento krok navazuje na zavedení této technologie v jednotkách Railjet z letošního jara.

    Ladislav Hagara | Komentářů: 6
    včera 12:22 | Bezpečnostní upozornění

    Rozšíření webového prohlížeče Urban VPN Proxy a další rozšíření od stejného vydavatele (např. 1ClickVPN Proxy, Urban Browser Guard či Urban Ad Blocker) od července 2025 skrytě zachytávají a odesílají celé konverzace uživatelů s AI nástroji (včetně ChatGPT, Claude, Gemini, Copilot aj.), a to nezávisle na tom, zda je VPN aktivní. Sběr probíhá bez možnosti jej uživatelsky vypnout a zahrnuje plný obsah dotazů a odpovědí, metadata relací i

    … více »
    Ladislav Hagara | Komentářů: 5
    včera 05:22 | Zajímavý software

    QStudio, tj. nástroj pro práci s SQL podporující více než 30 databází (MySQL, PostgreSQL, DuckDB, QuestDB, kdb+, …), se stal s vydáním verze 5.0 open source. Zdrojové kódy jsou k dispozici na GitHubu pod licencí Apache 2.0.

    Ladislav Hagara | Komentářů: 6
    Kdo vám letos nadělí dárek?
     (8%)
     (0%)
     (0%)
     (0%)
     (8%)
     (8%)
     (23%)
     (31%)
     (23%)
    Celkem 13 hlasů
     Komentářů: 10, poslední dnes 12:54
    Rozcestník

    Dotaz: Řazení pointerů

    15.12.2016 19:20 Franta
    Řazení pointerů
    Přečteno: 547×
    Vytvářím RB strom v C a chci položky porovnávat podle ukazatele (jedná se o "internované" řetězce, takže mi stačí porovnat ukazatel a né obsah). V C++ můžu použít std::less k porovnání takových ukazatelů (total ordering). Je nějaké makro či něco v C, co má stejnou garanci? Operátor < nelze k porovnání pointerů na různé objekty použít.

    Odpovědi

    15.12.2016 23:30 Michal Kubeček | skóre: 71 | Luštěnice
    Rozbalit Rozbalit vše Re: Řazení pointerů
    Striktně podle normy ne, prakticky to můžete přetypovat na long unsigned (chcete-li být korektní, tak třeba uintptr_t a porovnávat ta čísla. Ale v každém případě je to hraní si s ohněm a moc bych to nedoporučoval.
    17.12.2016 02:27 Andrej | skóre: 51 | blog: Republic of Mordor
    Rozbalit Rozbalit vše Re: Řazení pointerů
    Striktně podle normy ne,…
    Dokonce je to undefined, což je ale podle mě spíš relikt z děsivých dob far/near pointerů než dnešní problém. (Far/near pointery nejsou v C standardu, ale jsou příkladem oné hypotetické situace, kdy porovnání pointerů nemusí dávat smysl.) Například clang přeloží tohle s -Weverything bez keců, což sice neříká absolutně nic o souladu s normou, ale možná to aspoň vzdáleně naznačuje, že porovnatelnost bude na této konkrétní platformě fungovat předvídatelně. (V klasickém lineárním virtuálním adresním prostoru se nic překvapivého vymyslet nedá.)
    …prakticky to můžete přetypovat na long unsigned (chcete-li být korektní, tak třeba uintptr_t a porovnávat ta čísla. Ale v každém případě je to hraní si s ohněm a moc bych to nedoporučoval.

    Já bych to castnul na const void*, což přímo v kódu dokumentuje, že se jedná o pointery a porovnání pointerů, a zakazuje (případnou) pointerovou aritmetiku.

    16.12.2016 23:30 Ondřej Novák
    Rozbalit Rozbalit vše Re: Řazení pointerů
    Můžete to zkusit všechno přetypovat na (char *) nebo radši (const char *) a pak to jde porovnávat.

    Osobně bych doporučoval, když už ten RB strom píšete, aby to umělo definovat porovnávací callback (když v tom C nejsou šablony), aby ten strom se dal využit ještě k něčemu jinému :)
    17.12.2016 01:57 Andrej | skóre: 51 | blog: Republic of Mordor
    Rozbalit Rozbalit vše Re: Řazení pointerů

    Úplně klidně to může být void*.

    #include <stdio.h>
    #include <stdlib.h>
    
    struct blah { int zee[80]; };
    
    int main() {
      struct blah *const sth = (struct blah *)malloc(sizeof(struct blah));
      if (!sth) return EXIT_FAILURE;
      struct blah *const oops = (struct blah *)malloc(sizeof(struct blah));
      if (!oops) { free(sth); return EXIT_FAILURE; }
    
      const void *const nonsense = (const void *)sth;
      const void *const bullcrap = (const void *)sth;
      const void *const bullshit = (const void *)oops;
    
      printf("%d %d\n", nonsense < bullcrap, nonsense < bullshit);
      printf("%d %d\n", nonsense == bullcrap, nonsense == bullshit);
    
      free(oops);
      free(sth);
    
      return EXIT_SUCCESS;
    }
    
    17.12.2016 02:30 Andrej | skóre: 51 | blog: Republic of Mordor
    Rozbalit Rozbalit vše Re: Řazení pointerů

    Aha, správně bych tam měl mít víc datových typů než jeden, aby o opravdu dokumentovalo ten příklad z dotazu. No, co už. :-P

    17.12.2016 14:45 Jardík
    Rozbalit Rozbalit vše Re: Řazení pointerů
    Pokud tam dá callback, tak aby označil všechny funkce inline a modlil se, že mu to kompilátor inlinuje a zoptimalizuje. Výkonově na tom bude lépe, pokud to nechá parametrizovat nějakými makry.
    20.12.2016 13:02 Ondřej Novák
    Rozbalit Rozbalit vše Re: Řazení pointerů
    Zlatý C++ :) (trolling)
    Bedňa avatar 24.12.2016 00:12 Bedňa | skóre: 34 | blog: Žumpa | Horňany
    Rozbalit Rozbalit vše Re: Řazení pointerů
    Asi by som pozrel Google a použil nejakú hotovú knižnicu.
    KERNEL ULTRAS video channel >>>

    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.