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 14:00 | Zajímavý článek

    Byl publikován aktuální přehled vývoje renderovacího jádra webového prohlížeče Servo (Wikipedie).

    Ladislav Hagara | Komentářů: 0
    včera 12:00 | Nová verze

    V programovacím jazyce Go naprogramovaná webová aplikace pro spolupráci na zdrojových kódech pomocí gitu Forgejo byla vydána ve verzi 12.0 (Mastodon). Forgejo je fork Gitei.

    Ladislav Hagara | Komentářů: 0
    17.7. 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ářů: 1
    17.7. 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ářů: 2
    17.7. 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ářů: 5
    16.7. 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ářů: 19
    16.7. 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ářů: 26
    16.7. 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
    16.7. 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
    16.7. 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
    Jaký je váš oblíbený skriptovací jazyk?
     (59%)
     (27%)
     (7%)
     (3%)
     (0%)
     (1%)
     (4%)
    Celkem 410 hlasů
     Komentářů: 16, poslední 8.6. 21:05
    Rozcestník

    Dotaz: Sloučení char

    13.8.2012 11:44 kb
    Sloučení char
    Přečteno: 475×
    Zdravím, mám dvě proměnné char a potřeboval bych je sloučit do jednoho char, nevíte někdo jak na to? Zkoušel jsem:
    char a[25]="Dobrý";
    char b[25]=" den";
    char ab[25]= a || b;
    a píše to chybu: neco.cpp:82:36: error: array must be initialized with a brace-enclosed initializer

    Řešení dotazu:


    Odpovědi

    DaBler avatar 13.8.2012 12:35 DaBler | skóre: 17 | blog: dabler | Brno
    Rozbalit Rozbalit vše Re: Sloučení char
    Funkcemi strcpy a strcat.
    Josef Kufner avatar 13.8.2012 13:11 Josef Kufner | skóre: 70
    Rozbalit Rozbalit vše Re: Sloučení char
    Raději strncpy, aby mu nepřetekl buffer.
    Hello world ! Segmentation fault (core dumped)
    15.8.2012 00:34 chrono
    Rozbalit Rozbalit vše Re: Sloučení char
    V takom prípade bude zase riskovať, že sa mu tam nezmestí '\0' (a reťazec bude teda neukončený).
    14.8.2012 23:34 Václav HFechs Švirga | skóre: 26 | blog: HF | Kopřivnice
    Rozbalit Rozbalit vše Re: Sloučení char
    Já mám nejraději funkci sprintf či snprintf, která ten strcat v pohodě nahradí a je univerzálnější. Další využití je třeba převedení čísla na řetězec a různé další formátovací kouzla. Prostě je to printf, co výsledek uloží do proměnné (obšírně to rozepisuji samozřejmě pro autora dotazu). Tady by to vypadalo takto:
    char a[]="Dobrý";
    char b[]=" den";
    char ab[25];
    
    snprintf(ab, 25, "%s%s", a, b);
    A třeba to převedení čísla na řetězec:
    snprintf(buf, 100, "Číslo má hodnotu %i", 1000);
    Baník pyčo!
    Michy avatar 14.8.2012 11:11 Michy | skóre: 11 | Praha
    Rozbalit Rozbalit vše Re: Sloučení char
    Proměnné nejsou typu char, ale char[25]. Pokud se jedná o statickou inicializaci, řešil bych to s použitím maker, asi nějak takhle:
    #define CHAR_A "Dobrý"
    #define CHAR_B " den"
    #define CHAR_AB CHAR_A CHAR_B
    
    char a[25] = CHAR_A;
    char b[25] = CHAR_B;
    char ab[25] = CHAR_AB;
    
    Josef Kufner avatar 14.8.2012 23:00 Josef Kufner | skóre: 70
    Rozbalit Rozbalit vše Re: Sloučení char
    Pochybuju, že by šlo o statickou inicializaci a daleko lepší je napsat:
    char *a = "Dobrý";
    char *b = " den";
    char *c;
    
    c = malloc(strlen(a) + strlen(b) + 1);
    strcpy(c, a);
    strcat(c, b);
    // ...
    free(c);
    Hello world ! Segmentation fault (core dumped)
    14.8.2012 23:41 l4m4
    Rozbalit Rozbalit vše Re: Sloučení char
    const char a[] = "....";
    
    a
    const char *a = "....";
    
    není ekvivalentní, viz např. dsohowto (používání bez const je pak vůbec zajímavé, a byť někdy užitečné, obecně ho nelze doporučit, pokud přesně nevíte proč a jak). Také by pole znaků narozdíl od pointerů umožnily použít sizeof() namísto strlen(), i když optimalizující kompilátor bude schopen vyhodnotit i ten strlen() staticky.

    Především ale proboha použij nějakou knihovnu pro práci s řetezci, která má alespoň něco jako g_strconcat() z GLib (příklad implementace takové funkce je jako concat() i přímo v manuálu glibc). Nebo string v C++ -- těžko řící, v jakém to mělo být jazyce, ale koncovka souboru je .cpp, takže by to snad mohlo být C++.
    14.8.2012 23:55 Václav HFechs Švirga | skóre: 26 | blog: HF | Kopřivnice
    Rozbalit Rozbalit vše Re: Sloučení char
    Tak není špatné se ty základy naučit, s funkcemi sprintf, sscanf, strstr, strcpy, strlen a hlavně pochopením, jak je v C řetězec reprezentován (pole znaků ukončené zarážkou) se dá udělat hodně (a když už žádná funkce nepomůže, pořád máme cyklus a něco na způsob stavového automatu). Ale samozřejmě, když už člověk princip pochopí, nikdo mu v ulehčení si práce knihovnou či std::stringem nebrání :-). Ale zas používat knihovnu a představovat si, jakou magii vykonovává taky není dobré, obzvlášť v C (u skriptovacích jazyků je to jiná - tam interpret přístup mimo paměť a leaky většinou ošetří).
    Baník pyčo!
    15.8.2012 08:52 l4m4
    Rozbalit Rozbalit vše Re: Sloučení char
    Ano, na jedné straně by si někdo, kdo nemá jasno v tom, co to znamená string v C (což je zjevné z dotazu), v tom měl udělat jasno.

    Ale na druhé straně při kreativním lepení hromady strcat() a spol. do nějaké high-level operace udělá vcelku snadno botu i zkušený programátor. U začátečníka je to téměř jisté.

    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.