Při úklidu na Utažské univerzitě se ve skladovacích prostorách náhodou podařilo nalézt magnetickou pásku s kopií Unixu V4. Páska byla zaslána do počítačového muzea, kde se z pásky úspěšně podařilo extrahovat data a Unix spustit. Je to patrně jediný známý dochovaný exemplář tohoto 52 let starého Unixu, prvního vůbec programovaného v jazyce C.
FFmpeg nechal kvůli porušení autorských práv odstranit z GitHubu jeden z repozitářů patřících čínské technologické firmě Rockchip. Důvodem bylo porušení LGPL ze strany Rockchipu. Rockchip byl FFmpegem na porušování LGPL upozorněn již téměř před dvěma roky.
K dispozici je nový CLI nástroj witr sloužící k analýze běžících procesů. Název je zkratkou slov why-is-this-running, 'proč tohle běží'. Klade si za cíl v 'jediném, lidsky čitelném, výstupu vysvětlit odkud daný spuštěný proces pochází, jak byl spuštěn a jaký řetězec systémů je zodpovědný za to, že tento proces právě teď běží'. Witr je napsán v jazyce Go.
Yazi je správce souborů běžící v terminálu. Napsán je v programovacím jazyce Rust. Podporuje asynchronní I/O operace. Vydán byl v nové verzi 25.12.29. Instalovat jej lze také ze Snapcraftu.
Od soboty do úterý probíhá v Hamburku konference 39C3 (Chaos Communication Congress) věnovaná také počítačové bezpečnosti nebo hardwaru. Program (jiná verze) slibuje řadu zajímavých přednášek. Streamy a záznamy budou k dispozici na media.ccc.de.
Byl představen nový Xserver Phoenix, kompletně od nuly vyvíjený v programovacím jazyce Zig. Projekt Phoenix si klade za cíl být moderní alternativou k X.Org serveru.
XLibre Xserver byl 21. prosince vydán ve verzi 25.1.0, 'winter solstice release'. Od založení tohoto forku X.Org serveru se jedná o vůbec první novou minor verzi (inkrementovalo se to druhé číslo v číselném kódu verze).
Wayback byl vydán ve verzi 0.3. Wayback je "tak akorát Waylandu, aby fungoval Xwayland". Jedná se o kompatibilní vrstvu umožňující běh plnohodnotných X11 desktopových prostředí s využitím komponent z Waylandu. Cílem je nakonec nahradit klasický server X.Org, a tím snížit zátěž údržby aplikací X11.
Byla vydána verze 4.0.0 programovacího jazyka Ruby (Wikipedie). S Ruby Box a ZJIT. Ruby lze vyzkoušet na webové stránce TryRuby. U příležitosti 30. narozenin, první veřejná verze Ruby 0.95 byla oznámena 21. prosince 1995, proběhl redesign webových stránek.
Všem čtenářkám a čtenářům AbcLinuxu krásné Vánoce.
Řešení dotazu:
wc -l pouštět /usr/bin/wc -l ?
file a pak count (pole) a mame pocet radku. Protoze nacteni do pole celeho souboru se dela tak ze kazdy prvek pole obsahuje jeden radek.
Priklad:
$pole_soubor=file ($jm_file);
$pocet_radku=count($pole_soubor);
echo $pocet_radku;
PS: kdyby nekdo nekdy tady neco hledal tak at najde komplet odpoved na toto vlakno
$lines = 0;
$f = fopen("soubor", "r");
if ($f) {
while (fgets($f) != false) {
line++;
}
fclose($f);
}
wc
wc nemusí být všude dostupné. (Typicky na hostingu se zapnutým safe_mode.)
wc, teda kvazi optimalne (oproti horeuvedenym navrhom).
inak z orig. wc kodu:
/*
* Line counting is split out because it's a lot faster to get
* lines than to get words, since the word count requires some
* logic.
*/
if (doline) {
while ((len = read(fd, buf, MAXBSIZE))) {
wc ... 16.763 s wc -l ... 0.176 s PHP file() ... Allowed memory size of 134217728 bytes exhausted PHP po řádcích ... 2.183 s PHP po znacích ... 167.147 sNejsme v libc ani v kernelu, ale v PHP, víme?
Fajn, a co takhle 58MB soubor o jednom řádku? :-)
Obecně nejefektivnější bude načítat soubor pomocí fread() po blocích, řekněme 4 KB, počítat LF a pak případně přičíst jedničku za poslední neukončený řádek.
Tentýž soubor, nahradil jsem konce řádků tečkou:Fajn, a co takhle 58MB soubor o jednom řádku? :-)
wc ... 17.088 s wc -l ... 0.137 s PHP file() ... 0.361 s PHP po řádcích ... 0.250 s PHP po znacích ... 165.240 s
Opět: Netuším, jak to bude vObecně nejefektivnější bude načítat soubor pomocí
fread()po blocích, řekněme 4 KB, počítat LF a pak případně přičíst jedničku za poslední neukončený řádek.
C, testy jsem dělal pouze v programech wc a PHP.
To je docela zvláštní, že jednou se vám ten soubor do paměti nevešel a podruhé stejně velký ano…
Opět: Netuším, jak to bude v C, testy jsem dělal pouze v programech wc a PHP.
Ale já přece nemluvil o C, i PHP má funkci fread().
Nic zvláštního. Paměťový limit mám v PHP 128 MB. Pole s jedním 58MB řetězcem zabere méně místa, než pole s 1202011 řetězci o úhrnné délce 58MB.To je docela zvláštní, že jednou se vám ten soubor do paměti nevešel a podruhé stejně velký ano…
Psát se mi to už nechce, ale vím, že to bude trvat dlouho. Dvojitý (příp. vícenásobný) cyklus ve skriptovacích jazycích celkem spolehlivě zabíjí výkon aplikace.Ale já přece nemluvil o C, i PHP má funkci
fread().
Psát se mi to už nechce, ale vím, že to bude trvat dlouho. Dvojitý (příp. vícenásobný) cyklus ve skriptovacích jazycích celkem spolehlivě zabíjí výkon aplikace.Myslíte, že když ten cyklus nevidíte (je schovaný v nějaké knihovní funkci), bude to s výkonem lepší?
Ještě mi docvaklo, že to půjde sAle já přece nemluvil o C, i PHP má funkci
fread().
fread() i jinak, než vnořeným cyklem a to s funkcí substr_count(). Výsledek 0.207 s pro jednořádkový 58MB soubor a 0.251 s pro původní soubor jsou velmi příznivé, vlastně u PHP nejlepší. Zároveň to bude bezpečně fungovat i pro velmi dlouhé soubory a velmi dlouhé řádky.
A protože je to vítěz, zde je zdroják:
define('LF',chr(10));
$handle = fopen("soubor.txt","rb");
$lines = 0;
while (!feof($handle)) {
$lines+=substr_count(fread($handle, 8192),LF);
}
fclose($handle);
Ovšem pro krátké soubory bych použil raději fgets(), výsledky budou přesné i v případě chybějícího LF na konci.

fgetc(): 14.769s (po znacích/bytech)
fread() 2×cyklus 4KiB: 9.326s
fread() 2×cyklus 32KiB: 9.248s (v C by toto bylo asi nejrychlejší)
file_get_contents(): 9.209s (načtení celého souboru a smyčka)
wc : 2.375s
file() count(): 0.222s (načtení do pole řádků)
fgets(): 0.127s (čtení po řádcích)
fread() substr_count() 8KiB: 0.060s
fread() substr_count() 32KiB: 0.051s
wc -l : 0.024s
Tiskni
Sdílej: