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í
×
    včera 21:55 | Komunita

    Společnost Proxmox Server Solutions stojící za virtualizační platformou Proxmox Virtual Environment věnovala 10 000 eur nadaci The Perl and Raku Foundation (TPRF).

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

    Byla vydána nová verze 2.4.65 svobodného multiplatformního webového serveru Apache (httpd). Řešena je bezpečnostní chyba CVE-2025-54090.

    Ladislav Hagara | Komentářů: 0
    včera 14:22 | IT novinky

    Společnost Proton AG stojící za Proton Mailem a dalšími službami přidala do svého portfolia AI asistenta Lumo.

    Ladislav Hagara | Komentářů: 6
    včera 12:22 | IT novinky

    Amazon koupil společnost Bee zaměřenou na nositelnou osobní AI aktuálně nabízející náramek Pioneer (YouTube) s mikrofony zaznamenávající vše kolem [𝕏, LinkedIn].

    Ladislav Hagara | Komentářů: 6
    včera 04:33 | IT novinky

    Společnost Teufel nedávno představila svůj první open source Bluetooth reproduktor MYND.

    Ladislav Hagara | Komentářů: 9
    22.7. 20:00 | Nová verze

    Byla vydána verze 4.2 multiplatformního integrovaného vývojového prostředí (IDE) pro rychlý vývoj aplikaci (RAD) ve Free Pascalu Lazarus (Wikipedie). Využíván je Free Pascal Compiler (FPC) 3.2.2.

    Ladislav Hagara | Komentářů: 0
    22.7. 19:33 | IT novinky

    Anton Carniaux, právní zástupce Microsoft France, pod přísahou: Microsoft nemůže garantovat, že data z EU nepředá do USA bez EU souhlasu, musí dodržovat americké zákony.

    Ladislav Hagara | Komentářů: 28
    22.7. 15:33 | Nová verze

    Byl vydán Mozilla Firefox 141.0. Přehled novinek v poznámkách k vydání a poznámkách k vydání pro vývojáře. Lokální AI umí uspořádat podobné panely do skupin. Firefox na Linuxu využívá méně paměti. Řešeny jsou rovněž bezpečnostní chyby. Nový Firefox 141 je již k dispozici také na Flathubu a Snapcraftu.

    Ladislav Hagara | Komentářů: 0
    21.7. 22:44 | Bezpečnostní upozornění

    NÚKIB upozorňuje na kritickou zranitelnost v SharePointu. Jedná se o kritickou zranitelnost typu RCE (remote code execution) – CVE-2025-53770, která umožňuje neautentizovaný vzdálený přístup a spuštění kódu, což může vést k úplnému převzetí kontroly nad serverem. Zranitelné verze jsou pouze on-premise verze a to konkrétně SharePoint Server 2016, 2019 a Subscription Edition. SharePoint Online (Microsoft 365) není touto zranitelností ohrožen.

    Ladislav Hagara | Komentářů: 5
    21.7. 21:00 | IT novinky

    Společnost Valve zpřísnila pravidla pro obsah, který je možné distribuovat ve službě Steam. Současně řadu her ze Steamu odstranila. V zásadách a pravidlech přibylo omezení 15: Obsah, který by mohl porušovat pravidla a normy stanovené zpracovateli plateb a souvisejícími sítěmi platebních karet a bankami nebo poskytovateli připojení k internetu. Sem spadají zejména určité druhy obsahu pouze pro dospělé.

    Ladislav Hagara | Komentářů: 0
    Kolik tabů máte standardně otevřeno ve web prohlížeči?
     (27%)
     (24%)
     (4%)
     (6%)
     (5%)
     (2%)
     (3%)
     (29%)
    Celkem 97 hlasů
     Komentářů: 14, poslední včera 23:49
    Rozcestník

    Dotaz: Řazení pointerů

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