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 11:55 | IT novinky

    Společnost Perplexity AI působící v oblasti umělé inteligence (AI) podala nevyžádanou nabídku na převzetí webového prohlížeče Chrome internetové firmy Google za 34,5 miliardy dolarů (zhruba 723 miliard Kč). Informovala o tom včera agentura Reuters. Upozornila, že výše nabídky výrazně převyšuje hodnotu firmy Perplexity. Společnost Google se podle ní k nabídce zatím nevyjádřila.

    Ladislav Hagara | Komentářů: 4
    dnes 04:33 | Bezpečnostní upozornění

    Intel vydal 34 upozornění na bezpečnostní chyby ve svých produktech. Současně vydal verzi 20250812 mikrokódů pro své procesory řešící 6 bezpečnostních chyb.

    Ladislav Hagara | Komentářů: 0
    dnes 04:22 | Nová verze

    Byla vydána nová verze 1.25 programovacího jazyka Go (Wikipedie). Přehled novinek v poznámkách k vydání.

    Ladislav Hagara | Komentářů: 1
    včera 13:44 | Nová verze

    Byla vydána beta verze Linux Mintu 22.2 s kódovým jménem Zara. Podrobnosti v přehledu novinek a poznámkách k vydání. Vypíchnout lze novou XApp aplikaci Fingwit pro autentizaci pomocí otisků prstů nebo vlastní fork knihovny libAdwaita s názvem libAdapta podporující grafická témata. Linux Mint 22.2 bude podporován do roku 2029.

    Ladislav Hagara | Komentářů: 0
    včera 13:00 | IT novinky

    Provozovatel internetové encyklopedie Wikipedie prohrál v Británii soudní spor týkající se některých částí nového zákona o on-line bezpečnosti. Soud ale varoval britského regulátora Ofcom i odpovědné ministerstvo před zaváděním přílišných omezení. Legislativa zpřísňuje požadavky na on-line platformy, ale zároveň čelí kritice za možné omezování svobody slova. Společnost Wikimedia Foundation, která je zodpovědná za fungování

    … více »
    Ladislav Hagara | Komentářů: 2
    včera 12:55 | Nová verze

    Byla vydána verze 2.0.0 nástroje pro synchronizaci dat mezi vícero počítači bez centrálního serveru Syncthing (Wikipedie). Přehled novinek na GitHubu.

    Ladislav Hagara | Komentářů: 2
    včera 12:33 | IT novinky

    Americký prezident Donald Trump se v pondělí osobně setkal s generálním ředitelem firmy na výrobu čipů Intel Lip-Bu Tanem. Šéfa podniku označil za úspěšného, informují agentury. Ještě před týdnem ho přitom ostře kritizoval a požadoval jeho okamžitý odchod. Akcie Intelu v reakci na schůzku po oficiálním uzavření trhu zpevnily asi o tři procenta.

    Ladislav Hagara | Komentářů: 12
    11.8. 04:55 | Nová verze

    Byl vydán Debian GNU/Hurd 2025. Jedná se o port Debianu s jádrem Hurd místo obvyklého Linuxu.

    Ladislav Hagara | Komentářů: 6
    11.8. 02:44 | Komunita

    V sobotu 9. srpna uplynulo přesně 20 let od oznámení projektu openSUSE na konferenci LinuxWorld v San Franciscu. Pokuď máte archivní nebo nějakým způsobem zajímavé fotky s openSUSE, můžete se o ně s námi podělit.

    lkocman | Komentářů: 6
    9.8. 21:11 | Nová verze

    Byl vydán Debian 13 s kódovým názvem Trixie. Přehled novinek v poznámkách k vydání.

    Ladislav Hagara | Komentářů: 8
    Kolik tabů máte standardně otevřeno ve web prohlížeči?
     (50%)
     (19%)
     (4%)
     (5%)
     (3%)
     (1%)
     (1%)
     (17%)
    Celkem 371 hlasů
     Komentářů: 23, poslední 4.8. 13:01
    Rozcestník

    Dotaz: Řazení pointerů

    15.12.2016 19:20 Franta
    Řazení pointerů
    Přečteno: 544×
    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: 72 | 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.