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 02:22 | Zajímavý software

    Hru The Legend of Zelda: Twilight Princess od společnosti Nintendo si lze nově díky projektu Dusklight (původně Dusk) a reverznímu inženýrství zahrát i na počítačích a mobilních zařízeních. Vyžadována je kopie původní hry (textury, modely, hudba, zvukové efekty, …). Ukázka na YouTube. Projekt byl zahájen v srpnu 2020.

    Ladislav Hagara | Komentářů: 0
    dnes 01:11 | Nová verze

    Byla vydána nová major verze 29.0 programovacího jazyka Erlang (Wikipedie) a související platformy OTP (Open Telecom Platform, Wikipedie). Detailní přehled novinek na GitHubu.

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

    Po zranitelnostech Copy Fail a Dirty Frag přichází zranitelnost Fragnesia. Další lokální eskalace práv na Linuxu. Zatím v upstreamu neopravena. Přiřazeno ji bylo CVE-2026-46300.

    Ladislav Hagara | Komentářů: 0
    včera 14:00 | Komunita

    Sovereign Tech Agency (Wikipedie) prostřednictvím svého fondu Sovereign Tech Fund podpoří KDE částkou 1 285 200 eur.

    Ladislav Hagara | Komentářů: 4
    včera 12:55 | IT novinky

    Google na včerejší akci The Android Show | I/O Edition 2026 (YouTube) představil celou řadu novinek: Gemini Intelligence, notebooky Googlebook, novou generaci Android Auto, …

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

    Evropská komise by do léta mohla předložit návrh normy omezující používání sociálních sítí dětmi v zájmu jejich bezpečí na internetu. Prohlásila to včera předsedkyně EK Ursula von der Leyenová, podle níž řada zemí Evropské unie volá po zavedení věkové hranice pro sociální sítě. EU částečně řeší bezpečnost dětí v digitálním prostředí v již platném nařízení o digitálních službách (DSA), podle německé političky to však není dostatečné a

    … více »
    Ladislav Hagara | Komentářů: 32
    včera 04:11 | Nová verze

    Multiplatformní open source aplikace scrcpy (Wikipedie) pro zrcadlení připojeného zařízení se systémem Android na desktopu a umožňující ovládání tohoto zařízení z desktopu, byla vydána v nové verzi 4.0.

    Ladislav Hagara | Komentářů: 0
    12.5. 23:22 | Pozvánky

    Chybí vám někdo, s kým byste si popovídali o bastlení, technice, počítačích a vědě? Nechcete riskovat debatu o sportu u piva v hospodě? Pak doražte na virtuální pokec u virtuálního piva v rámci Virtuální Bastlírny organizované strahovským MacGyverem již tento čtvrtek. Možná se ptáte, co se tak může probírat? Dají se probrat slavná výročí - kromě 55 let obvodu 555 (což je mimochodem prý andělské číslo) a vzpomínky na firmu Signetics -

    … více »
    bkralik | Komentářů: 2
    12.5. 23:11 | Zajímavý software

    GTK2-NG je komunitní fork GTK 2.24 (aktuální verze je 4.22). Oznámení a diskuse v diskusním fóru Devuanu, forku Debianu bez systemd. Není to jediný fork GTK 2. Ardour je například postaven na vlastním forku GTK 2 s názvem YTK.

    Ladislav Hagara | Komentářů: 0
    12.5. 17:33 | Pozvánky

    V neděli 17. května 2026 proběhne v Českých Budějovicích první MobileLinux Hackday zaměřený na Linux v mobilech, embedded platformy a open source hardware. Po sedmi úspěšných měsíčních setkáních v Praze se akce přesouvá také do jižních Čech, aby se komunita mobilního Linuxu mohla potkat i mimo hlavní město. Akce se uskuteční v konferenčním sále Vajgar v Clarion Congress Hotelu (Pražská tř. 2306/14) se zahájením mezi 14:00 až 15:00 a … více »

    lkocman | Komentářů: 0
    Které desktopové prostředí na Linuxu používáte?
     (13%)
     (8%)
     (2%)
     (14%)
     (31%)
     (4%)
     (6%)
     (3%)
     (16%)
     (25%)
    Celkem 1601 hlasů
     Komentářů: 30, poslední 3.4. 20:20
    Rozcestník

    Dotaz: Fungování "find ... -exec"

    13.5.2016 15:22 lertimir | skóre: 64 | blog: Par_slov
    Fungování "find ... -exec"
    Přečteno: 530×
    Jak funguje find? Myslím tím jestli:
    1. při spuštění nejdříve projde strom adreářů (celý), a vytvoří seznam objektů splňujících podmínku a následně na ně spustí akci -exec
    2. nebo jestli najde první objekt, spustí na ni akci -exec a následně, jak program doběhne najde next objekt v adresáři (stromu) atd.
    Ptám se proto, co se stane, jestli se v průběhu běhu programu vyvoleného z find, změní seznam objektů, které find najde. V první případě skončím na chybových stavech, protože ve chvíli, kdy budu volat exec, tak už pro něj nemusí existovat soubor, v druhém případě se nestane nic podstatného, protože ve chvíli, kdy find soubor najde, tak spustí exec.

    Řešení dotazu:


    Odpovědi

    13.5.2016 15:51 MP
    Rozbalit Rozbalit vše Re: Fungování "find ... -exec"
    Bod 1] by default.
    13.5.2016 16:04 Lyco | skóre: 14 | blog: Lyco
    Rozbalit Rozbalit vše Re: Fungování "find ... -exec"
    Špatná otázka. V obou případech tam bude souběh - mezi nalezením souboru a spuštěním příkazu vždycky uběhne nějaký čas. Pokud potřebuješ správný výsledek, musíš tenhle problém nějak ošetřit (typicky zámkem).

    Abych odpověděl na otázku: vypadá to že to není specifikované - v SUS2 ani v manuálových stránkách jsem to nenašel. Nespoléhal bych ani na jedno chování, možná že závisí na ostatních přepínačích.

    Moje verze findu, aspoň v jednoduchých případech, dělá č. 2: $ touch a b c $ find . -exec rm * {} \; rm: nelze odstranit '.': je adresářem $

    Kdyby dělal č. 1, tak by tam byly hlášky že neexistuje "b" a "c".
    Příspěvek se rázem stává až o 37,5 % pravdivější, je-li pod ním napsáno reálné jméno.
    13.5.2016 17:30 lertimir | skóre: 64 | blog: Par_slov
    Rozbalit Rozbalit vše Re: Fungování "find ... -exec"
    No obecně si představit takto zámek moc neumím. Samozřejmě ten exec je na script, který v prvním kroku soubor zabezpečí proti jiné akci. Ale časový rozdíl při bodu 2 mezi findem a vlastním execem neošetříš jinak, než bys zamknul celý strom, protože v této chvili ještě nevíš, který soubor potřebuješ zamknout. A to je nežádoucí z jiných důvodů. Navíc to není produkční a výkonová otázka.

    Otázka směřovala směrem: Program spouštěný execem beží na souboru minuty (desítky minut), po akci původní soubor, který byl vyhledán execem, bude smazán. Filový systém je na NFS sdíleném disku a je ve struktuře, která (řekněme) má poadresáře A, B, C. Find byl spuštěn v rodiči A,B,C a daném okamžiku je v adresáři A a bude tam ještě několik (dost) hodin. Otázka byla: Mohu mezi tím než doběhne původní find adresář A, moutnout stejné NFS z jiného stroje a spustit obdobný find pouze na adresáři B (nebo C) s tím, že vím, že doběhne dříve než původní find opustí A (a urychlit tak zpracování celého stromu). Takže v prvním případě funcionality find, tento vstoupí do B a zařve, že tam nemá, co očekával, v druhém případě otevře B a zjistí, že nic nenajde, co by podmínce vyhovovalo a jede dál.
    13.5.2016 19:43 lertimir | skóre: 64 | blog: Par_slov
    Rozbalit Rozbalit vše Re: Fungování "find ... -exec"
    Tak jsem provedl experiment. Uvidím, co find, až vyjede z adresáře A.
    Jendа avatar 13.5.2016 18:27 Jendа | skóre: 78 | blog: Jenda | JO70FB
    Rozbalit Rozbalit vše Re: Fungování "find ... -exec"
    Když dáš
    find . -exec rm * {} \;
    tak bash ve skutečnosti udělá
    execve("/usr/bin/find", ["find", ".", "-exec", "rm", "a", "b", "c", "{}", ";"], [/* 43 vars */]) = 0
    (tj. expanduje hvězdičku), přičemž find udělá clone() a
    execve("/bin/rm", ["rm", "a", "b", "c", "."], [/* 43 vars */]) = 0
    což vyhodí tu hlášku
    rm: cannot remove '.': Is a directory
    a smaže všechny tři soubory. Pak find skončí.

    Kdyby to nabufferoval a spouštěl to rm s každým souborem, tak by to vypsalo, že neexistuje a, b, c, a, a, b, c, b, a, b, c, c.
    13.5.2016 16:27 ttt
    Rozbalit Rozbalit vše Re: Fungování "find ... -exec"
    find umí oba dva módy, výcuc z manuálových stránek:
    -exec command ; All following arguments to find are taken to be arguments to the command until an argument consisting of `;' is encountered. The specified command is run once for each matched file.

    -exec command {} + This variant of the -exec action runs the specified command on the selected files, but the command line is built by appending each selected file name at the end; the total number of invocations of the command will be executed much less than the number of matched files. The command line is built in much the same way that xargs* builds its command lines. If find encounters an error, this can sometimes cause an immediate exit, so some pending commands may not be run at all.

    * The command line for command is built up until it reaches a system-defined limit
    13.5.2016 17:06 Filip Jirsák | skóre: 67 | blog: Fa & Bi
    Rozbalit Rozbalit vše Re: Fungování "find ... -exec"
    Tohle je něco jiného – ta druhá varianta zajistí, že se příkaz za -exec nebude volat pro každý nalezený soubor, ale bude se volat méně často a jako parametry se mu předá více souborů. Rozdíl je tedy v tom, že v prvním případě se volá
    rm a
    rm b
    rm c 
    rm d
    rm e
    rm f
    
    V druhém případě se zavolá třeba
    rm a b c 
    rm d e f
    
    14.5.2016 16:00 RM
    Rozbalit Rozbalit vše Re: Fungování "find ... -exec"
    Možná pomůže informace v man xargs (BUGS na konci), kde je zmíněno find -execdir . Neověřoval jsem to!
    29.7.2016 11:16 lertimir | skóre: 64 | blog: Par_slov
    Rozbalit Rozbalit vše Re: Fungování "find ... -exec"
    Tak mám výsledek pro ty které by to zajímalo. Je zajímavé že výsledek je "napůl". find projde adresář a vytvoří si seznam souborů, které podmínce vyhovují a seznam všech adresářů. Seznam je v přirozeném pořadí, tedy v jakém pořadí jsou objekty umístěny v adresáři, žádné třídění. Na tyto objekty postupně provádí -exec. V případě, že objekt je adresář, zastaví provádění, odloží seznam do zásobníku, a provede výběr v podadresáři a pokračuje podle předchozího.

    To znamená, že pokud mám strukturu
    W
     w
    a
    b
    X
     x
    c
    Y
     y
    Z
     z
    d
    
    (malá písmena jsou soubory, velká adresáře a odsazení znamená příslušnost do adresáře, pořadí je jak jsou v adresáři) Tak find si udělá seznam a,b,c,d z hlavního adresáře skočí do W a udělá tam seznam a začne spracovávat w. Než jej zpracuje (a následně a, b) je možné s objekty x,y,z libovolně pracovat bez toho že find bude hásit chybu. operace na d způsobí, že find bude hlásit, že nenašel soubor.

    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.