Mikrokontroléry RP2350A a RP2350B jsou již volně v prodeji. Představeny byly v srpnu loňského roku společně s Raspberry Pi Pico 2.
GIMP 3.0 byl oficiálně vydán (Mastodon, 𝕏). Přehled novinek v poznámkách k vydání.
Od 6. do 19. dubna proběhne volba vedoucího projektu Debian (DPL, Wikipedie) na další funkční období. Kandidují Gianfranco Costamagna, Julian Andres Klode, Andreas Tille a Sruthi Chandran.
Korespondenční seminář z programování (KSP) pražského Matfyzu pořádá i letos jarní soustředění pro začátečníky. Zváni jsou všichni středoškoláci a starší základoškoláci, kteří se chtějí naučit programovat, lépe uvažovat o informatických úlohách a poznat nové podobně smýšlející kamarády. Úplným začátečníkům bude určen kurz základů programování a kurz základních algoritmických dovedností, pokročilejším nabídneme různorodé
… více »Joe Brockmeier z Linux Weekly News vyzkoušel různé forky webového prohlížeče Mozilla Firefox: především GNU IceCat, Floorp, LibreWolf a Zen. V článku shrnuje, v čem se liší od výchozí konfigurace Firefoxu, co mají za vlastní funkcionalitu, jak a kým jsou udržované atd.
Byl vydán Debian 12.10, tj. desátá opravná verze Debianu 12 s kódovým názvem Bookworm. Řešeny jsou především bezpečnostní problémy, ale také několik vážných chyb. Instalační média Debianu 12 lze samozřejmě nadále k instalaci používat. Po instalaci stačí systém aktualizovat.
Byla vydána nová verze 4.5 svobodného notačního programu MuseScore (Wikipedie). Představení novinek v oznámení v diskusním fóru a také na YouTube.
Byla vydána nová verze 8.6.0 správce sbírky fotografií digiKam (Wikipedie). Přehled novinek i s náhledy v oficiálním oznámení (NEWS). Nejnovější digiKam je ke stažení také jako balíček ve formátu AppImage. Stačí jej stáhnout, nastavit právo ke spuštění a spustit.
O víkendu probíhá v Praze na Karlově náměstí 13 konference Installfest 2025. Na programu je celá řada zajímavých přednášek a workshopů. Vstup je zdarma. Přednášky lze sledovat i online na YouTube.
Byla vydána nová verze 2.49.0 distribuovaného systému správy verzí Git. Přispělo 89 vývojářů, z toho 24 nových. Přehled novinek v příspěvku na blogu GitHubu a v poznámkách k vydání.
/proc/net/dev
, ale to není podstatný, protože tam mám spíš nějakou chybu, jenže nevím jakou... Ukazuje mi nesmysl:
dl 18014261070691488 kB/s up 0 kB/sNení na tohle třeba nějaká knihovna? Pokud ne, co tam mám špatně? Díky...
cat /proc/net/dev | grep eth0 | awk '{print $1}'(za predpokladu ze si zmenis eth0 :)
awk '/eth0/ {print $1}' /proc/net/dev
$ time for ((i=0; i<999; i++)) do awk '/eth0/ {print $1}' /proc/net/dev done > /dev/null real 0m2.008s user 0m0.908s sys 0m1.092s $ time for ((i=0; i<999; i++)) do cat /proc/net/dev | grep eth0 | awk '{print $1}' done > /dev/null real 0m5.584s user 0m2.261s sys 0m3.295s
S využitím standardní C++ knihovny by se to dalo napsat mnohem elegantněji.Věřím. Zatím nemám peníze na Mistrovství v C++, takže to asi nevymyslím
/proc
pracuje, abych viděl jak to z nich dolují return
vyhodil exception, takže by zjistil, co se děje… :-)
ifstream f("/proc/net/dev"); string s; while(getline(f, s)) if (s.find("eth0") != -1) cout << s << endl;Tohle vypíše řádek obsahující "eth0", jenže jak z toho dostat ty dvě hodnoty (počet přijatých a odeslaných bajtů) aby to bylo mnohem elegantnější?
Např. takhle:
class Netload { public: typedef unsigned long long count_t; std::string name; count_t d; count_t u; Netload(count_t id = 0, count_t iu = 0) { d = id; u = iu; } ~Netload() {} const Netload operator - (const Netload& x); }; inline const Netload Netload::operator - (const Netload& x) { return Netload(d - x.d, u - x.u); } std::istream& operator >> (std::istream& s, Netload& x) { std::string buff; getline(s, buff, ':'); if (!s) return s; s >> x.d; Netload::count_t tmp; for (int i=0; i<7; i++) s >> x; s >> x.u; s.ignore(std::numeric_limits<std::streamsize>::max(), '\n'); return s; } bool GetStat(const std::string& ifname, Netload& stat) { std::ifstream s("/proc/net/dev"); if (!s) throw std::runtime_error("cannot open /proc/net/dev"); s.ignore(std::numeric_limits<std::streamsize>::max(), '\n'); s.ignore(std::numeric_limits<std::streamsize>::max(), '\n'); while (s >> stat) { if (stat.name == ifname) return true; } return false; }
int main(int argc, char** argv) { if (argc != 2) { cout << "Usage: " << argv[0] << " eth0\n"; return 1; } Netload before, now, diff; GetStat(argv[1], before); sleep(1); GetStat(argv[1], now); diff.d = now.d - before.d; diff.u = now.u - before.u; cout << "dl " << diff.d / 1024 << " kB/s\nup " << diff.u / 1024 << " kB/s\n"; }
To bude tím, že jsem to nezkoušel. :-) Jinak by tento jednoúčelový prográmek šel samozřejmě napsat jednodušeji, ale předpokládám, že s těmi hodnotami budete chtít pracovat nějak soustavněji, takže spíš než na jednoduchost implementace té třídy jsem se zaměřil na jednoduchost použití. Zrovna tak místo konstanty 'std::numeric_limits<std::streamsize>::max()
' jsem mohl napsat třeba 256, ale IMHO je lepší si na podobné bulharské konstanty nezvykat a psát všude to, co tam logicky patří. Takže druhý pokus:
#include <iostream> #include <fstream> #include <stdexcept> #include <unistd.h> // sleep class Netload { public: typedef unsigned long long count_t; std::string name; count_t d; count_t u; Netload() { d = u = 0; } Netload(std::string& iname, count_t id = 0, count_t iu = 0) : name(iname) { d = id; u = iu; } ~Netload() {} const Netload operator - (const Netload& x); }; inline const Netload Netload::operator - (const Netload& x) { return Netload(name, d - x.d, u - x.u); } inline void trimleft(std::string& s) { unsigned i = 0; unsigned L = s.length(); while (i<L && s[i]==' ') i++; s.erase(0, i); } std::istream& operator >> (std::istream& s, Netload& x) { getline(s, x.name, ':'); if (!s) return s; trimleft(x.name); s >> x.d; Netload::count_t tmp; for (int i=0; i<7; i++) s >> tmp; s >> x.u; s.ignore(std::numeric_limits<std::streamsize>::max(), '\n'); return s; } std::ostream& operator << (std::ostream& s, const Netload& x) { s << x.name << ": dn " << x.d/1024 << " KB, up " << x.u/1024 << " KB\n"; return s; } void GetStat(const std::string& ifname, Netload& stat) { std::ifstream s("/proc/net/dev"); if (!s) throw std::runtime_error("cannot open /proc/net/dev"); s.ignore(std::numeric_limits<std::streamsize>::max(), '\n'); s.ignore(std::numeric_limits<std::streamsize>::max(), '\n'); while (s >> stat) { if (stat.name == ifname) return; } throw std::runtime_error("cannot read statistics for selected interface"); } int main(int argc, char** argv) { try { if (argc != 2) throw std::runtime_error("Usage: transfer <ifname>"); Netload before, now; GetStat(argv[1], before); sleep(1); GetStat(argv[1], now); std::cout << (now - before); return 0; } catch(std::exception& e) { std::cerr << "transfer: " << e.what() << std::endl; return 1; } }
Tou elegancí jsem myslel hlavně to, jak se vám zpřehlední právě main()
a zejména zpracování chyb. Díky použití nástrojů jazyka C++ můžete totiž oddělit reakci na chybu od její detekce.
$ mrtg-ip-acct eth0 236054352 240845652 4:05pm up 199 days, 12:11, 1 user, load average: 0.00, 0.02, 0.00 localhost
Tiskni
Sdílej: