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 01:00 | Nová verze

Známý šifrovaný komunikátor Signal od verze 3.30.0 již nevyžaduje Google Play Services. Autoři tak po letech vyslyšeli volání komunity, která dala vzniknout Google-free forku LibreSignal (dnes již neudržovaný). Oficiální binárky jsou stále distribuované pouze přes Google Play, ale lze použít neoficiální F-Droid repozitář fdroid.eutopia.cz s nezávislými buildy Signalu nebo oficiální binárku stáhnout z Google Play i bez Google účtu

… více »
xm | Komentářů: 1
včera 23:14 | Nová verze

Po třech týdnech od vydání první RC verze byla vydána první stabilní verze 17.01.0 linuxové distribuce pro routery a vestavěné systémy LEDE (Linux Embedded Development Environment), forku linuxové distribuce OpenWrt. Přehled novinek v poznámkách k vydání. Dotazy v diskusním fóru.

Ladislav Hagara | Komentářů: 4
včera 17:28 | Bezpečnostní upozornění

Byly zveřejněny informace o bezpečnostní chybě CVE-2017-6074 v Linuxu zneužitelné k lokální eskalaci práv. Jde o chybu v podpoře DCCP (Datagram Congestion Control Protocol). Do linuxového jádra se dostala v říjnu 2005. V upstreamu byla opravena 17. února (commit). Bezpečnostní chyba byla nalezena pomocí nástroje syzkaller [Hacker News].

Ladislav Hagara | Komentářů: 4
včera 15:00 | Zajímavý software

Společnost Valve vydala novou beta verzi SteamVR. Z novinek lze zdůraznit oficiální podporu Linuxu. Další informace o podpoře této platformy pro vývoj virtuální reality v Linuxu v diskusním fóru. Hlášení chyb na GitHubu.

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

Po necelém roce od vydání verze 0.67 byla vydána verze 0.68 populárního telnet a ssh klienta PuTTY. Podrobnosti v přehledu změn. Řešeny jsou také bezpečnostní chyby.

Ladislav Hagara | Komentářů: 0
21.2. 21:32 | Nasazení Linuxu

Canonical představuje nejnovější verzi chytré helmy DAQRI s Ubuntu pro rozšířenou realitu. K vidění bude příští týden v Barceloně na veletrhu Mobile World Congress 2017.

Ladislav Hagara | Komentářů: 0
21.2. 21:31 | Pozvánky

Pro zájemce o hlubší znalosti fungování operačních systémů připravila MFF UK nový předmět Pokročilé operační systémy, v rámci něhož se vystřídají přednášející nejen z řad pracovníků fakulty, ale dorazí také odborníci ze společností AVAST, Oracle, Red Hat a SUSE. Tento předmět volně navazuje na kurz Operační systémy ze zimního semestru, ale pokud máte praktické zkušenosti odjinud (například z přispívání do jádra Linuxu) a chcete si

… více »
Martin Děcký | Komentářů: 6
21.2. 21:30 | Pozvánky

Czech JBoss User Group Vás srdečně zve na setkání JBUG v Brně, které se koná ve středu 1. března 2017 v prostorách Fakulty Informatiky Masarykovy Univerzity v místnosti A318 od 18:00. Přednáší Tomáš Remeš a Matěj Novotný na téma CDI 2.0 - New and Noteworthy. Více informací na Facebooku a na Twitteru #jbugcz.

mjedlick | Komentářů: 0
20.2. 23:45 | Zajímavý software

Na blogu Qt bylo představeno Qt 3D Studio. Jedná se o produkt dosud známý pod názvem NVIDIA DRIVE™ Design Studio. NVIDIA jej věnovala Qt. Jedná se o několik set tisíc řádků zdrojového kódu. Qt 3D Studio bude stejně jako Qt k dispozici jak pod open source, tak pod komerční licencí. Ukázka práce s Qt 3D Studiem na YouTube.

Ladislav Hagara | Komentářů: 10
20.2. 17:50 | Komunita

Nadace The Document Foundation (TDF) zastřešující vývoj svobodného kancelářského balíku LibreOffice slaví 5 let od svého oficiálního vzniku. Nadace byla představena 28. září 2010. Formálně byla založena ale až 17. února 2012.

Ladislav Hagara | Komentářů: 0
Jak se stavíte k trendu ztenčování přenosných zařízení (smartphony, notebooky)?
 (13%)
 (2%)
 (71%)
 (3%)
 (10%)
Celkem 689 hlasů
 Komentářů: 66, poslední včera 18:57
    Rozcestník

    Dotaz: C - přístup ke jednotlivým znakům řetězce

    11.11.2009 11:19 Afill
    C - přístup ke jednotlivým znakům řetězce
    Přečteno: 898×

    Dobrý den, řeším jedem problém, který mi docela láme hlavu. Řekněme, že mám nějaký řetězec a chci jej předat jako parametr funkci, která vrátí stejně dlouhý řetězec s přeházenými písmeny. Jak na to? Když zkusím třeba:

    char *Fce(char *str)

    {

    char *newStr = str;

    newStr[1] = newStr[6]; // Zde je již chyba!

    printf("%c\n", newStr[1]);

    return newStr;

    }

    Jde o to, že jsem zkoušel všemožné kombinace, ale zkrátka jsem nepřišel na to, jak prohodit znaky u jiného řetězce než s předem definovanou délkou (např: "char str[10];").

    Byl by někdo tak laskav a napsal mi takovou funkci která přehodí některé znaky a vrátí upravený řetězec? Děkuji


    Řešení dotazu:


    Odpovědi

    11.11.2009 11:41 Atom321 | skóre: 20
    Rozbalit Rozbalit vše Základy
    Pane kolego, tudy cesta nevede. Pokud to má být pokus ofixlovat nějakou práci do školy, požádejte zkušenějšího kamaráda. Chcete-li opravdu programovat, musíte se to nejprve naučit.

    Dobrým začátkem s C je "Učebnice jazyka C" od P. Herouta. Ovšem vám by se ještě předtím hodila spíš nějaká středoškolská skripta o programování jako takovém.
    11.11.2009 11:54 Afill
    Rozbalit Rozbalit vše Re: Základy
    Děkuji za konstruktivní návrh, ale bohužel k řešení to nevede. Jsem zvyklý na jiné programovací jazyky, které mají práci s řetězci "jednodušší" a jsem si vědom, že mi některé základy z jazyka C unikají. Nicméně C příliš často nepoužívám. Samozřejmě jsem před položením dotazu hledal kde se dalo. Bohužel marně.

    Mimochodem nevím jak vy, ale pod pojmem "ofixlovat" si představuji něco opsat, ne něco pochopit.
    11.11.2009 14:55 Atom321 | skóre: 20
    Rozbalit Rozbalit vše Re: Základy
    Děkuji za konstruktivní návrh, ale bohužel k řešení to nevede.
    Ale vede. Jen delší cestou, než jste ochoten akceptovat.
    Samozřejmě jsem před položením dotazu hledal kde se dalo. Bohužel marně.
    To jste zřejmně minul tento článek: http://www.linuxsoft.cz/article.php?id_article=842
    Mimochodem nevím jak vy, ale pod pojmem "ofixlovat" si představuji něco opsat, ne něco pochopit.
    Ano, přesně tak. Pokud chcete pochopit, hotové řešení jedné konkrétní funkce vám stačit nebude.
    11.11.2009 12:15 Afill
    Rozbalit Rozbalit vše Re: C - přístup ke jednotlivým znakům řetězce
    Už jsem na to přišel. Vytvořil jsem nový řetězec a alokoval pro něj paměť novy = (char *) malloc(strlen(stary));

    Ještě se mi to někde ztrácí v paměti, ale na to snad už přijdu.
    11.11.2009 14:21 Atom321 | skóre: 20
    Rozbalit Rozbalit vše Re: C - přístup ke jednotlivým znakům řetězce
    Chyba. Řetězce v C jsou ukončeny nulou (znakem s kódem 0), který se do celkové délky nepočítá.

    Správně je tedy:
    novy = (char*) malloc(strlen(stary)+1); /* alokace stringu stejne velikosti */
    if (novy == NULL)
    {
       /* nahlasit chyby alokace */
    }
    strcpy(novy,stary);  /* zkopirovani puvodniho stringu do nove alokovane pameti */
    /* ... pouziti ... */
    
    free(novy); /* dealokace (uvolneni pameti) */
    
    Místo malloc a strcpy lze také použít strdup:
    novy = strdup(stary); /* alokace noveho stringu stejne velikosti a zkopirovani obsahu ze stareho */
    if (novy == NULL)
    {
       /* nahlasit chyby alokace */
    }
    
    /* ... pouziti ... */
    
    free(novy); /* dealokace (uvolneni pameti) */
    
    Funkce strdup() není součástí ANSI C, tedy nemusí být přenositelná na jiné systémy.
    11.11.2009 12:26 Marble | skóre: 27 | blog: marble | Švédsko
    Rozbalit Rozbalit vše Re: C - přístup ke jednotlivým znakům řetězce
    Ta funkce je IMO v pořádku. Teda záleží na tom, co přesně od ní čekáš. Pokud ji budeš volat s parametrem, který je odkazem do paměti na alokovaný string, tak fajn. Pokud ji ale budeš volat s konstantou (Fce("ABCDEFGHIJ");), tak skončí na tom, že se snaží měnit právě přímo svůj parametr.

    Přiřazení lokální proměnní na začátku totiž jen přiřadí ten pointer, tudíž je vlastně zbytečné. Předpokládám, že cheš ve funkci vytvořit kopii stringu a tu upravit. V tom případě se v čistém C nevyhneš mallocu nové paměti, do které ten string zkopíruješ (strcpy) a pak teprv budeš upravovat.

    Jo a ten, kdo tu funkci volal si pak samozřejmě musí alokovanou pamět uklidit. Funkce sama to z principu udělat nemůže.

    Druhým přiblížením, použitým v některých C knihovnách, je místo alokace paměti použít nějakou globální proměnnou deklarovanou v knihovně, ve které je i ona Fce (tahle proměnná nemusí být viditelná ven z knihovny). Fce si pak string zkopíruje do této proměnné. Výhodou je, že volající nemusí uklízet pamět, nevýhodou je, že po opětovném volání Fce je pamět přepsána a tudíž pointer vrácený dřívějším voláním bude odkazovat na "špatný" string. (Každé volání prostě vrátí stejný pointer.)

    11.11.2009 12:38 moira | skóre: 30 | blog: nesmysly
    Rozbalit Rozbalit vše Re: C - přístup ke jednotlivým znakům řetězce
    Je důvod proč nepoužít strrev?
    Překladač ti nikdy neřekne: "budeme kamarádi"
    20.11.2009 17:12 bajo | skóre: 3
    Rozbalit Rozbalit vše Re: C - přístup ke jednotlivým znakům řetězce
    jedine co tu potrebujes je troska pochopit ukazovatele. Vidiet za im nerozumies.
    20.11.2009 18:39 ext3fs
    Rozbalit Rozbalit vše Re: C - přístup ke jednotlivým znakům řetězce
    Pokud jde jen o prehozeni tak neco takoveho by mohlo fungovat:
    char *prehod(const char *str)
    {
    char *buff;
    int n, i = 0;
    
        if ((buff = (char *)malloc((strlen(str) + 1) * sizeof(char))) == NULL)
        {
            fprintf(stdout, "Chyba alokace.\n");
            exit (1);
        }
    
        for(n = strlen(str) - 1; n >= 0; n--)
            buff[i++] = str[n];
    
        buff[i] = '\0';
    
        return (buff);
    }
    
    int main(void)
    {
    char str[5];
    
        strcpy(str, "ahoj");
    
        fprintf(stdout, "%s\n", prehod(str));
    
        return (0);
    }
    
    

    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.