Po roce vývoje od vydání verze 1.24.0 byla vydána nová stabilní verze 1.26.0 webového serveru a reverzní proxy nginx (Wikipedie). Nová verze přináší řadu novinek. Podrobný přehled v souboru CHANGES-1.26.
Byla vydána nová verze 6.2 živé linuxové distribuce Tails (The Amnesic Incognito Live System), jež klade důraz na ochranu soukromí uživatelů a anonymitu. Přehled změn v příslušném seznamu. Tor Browser byl povýšen na verzi 13.0.14.
Byla vydána nová verze 30.0.0 frameworku pro vývoj multiplatformních desktopových aplikací pomocí JavaScriptu, HTML a CSS Electron (Wikipedie, GitHub). Chromium bylo aktualizováno na verzi 124.0.6367.49, V8 na verzi 12.4 a Node.js na verzi 20.11.1. Electron byl původně vyvíjen pro editor Atom pod názvem Atom Shell. Dnes je na Electronu postavena celá řada dalších aplikací.
Byla vydána nová verze 9.0.0 otevřeného emulátoru procesorů a virtualizačního nástroje QEMU (Wikipedie). Přispělo 220 vývojářů. Provedeno bylo více než 2 700 commitů. Přehled úprav a nových vlastností v seznamu změn.
Evropský parlament dnes přijal směrnici týkající se tzv. práva spotřebitele na opravu. Poslanci ji podpořili 584 hlasy (3 bylo proti a 14 se zdrželo hlasování). Směrnice ujasňuje povinnosti výrobců opravovat zboží a motivovat spotřebitele k tomu, aby si výrobky nechávali opravit a prodloužili tak jejich životnost.
Bylo oznámeno (cs) vydání Fedora Linuxu 40. Přehled novinek ve Fedora Workstation 40 a Fedora KDE 40 na stránkách Fedora Magazinu. Současně byl oznámen notebook Slimbook Fedora 2.
ČTK (Česká tisková kancelář) upozorňuje (X), že na jejím zpravodajském webu České noviny byly dnes dopoledne neznámým útočníkem umístěny dva smyšlené texty, které nepocházejí z její produkce. Jde o text s titulkem „BIS zabránila pokusu o atentát na nově zvoleného slovenského prezidenta Petra Pelligriniho“ a o údajné mimořádné prohlášení ministra Lipavského k témuž. Tyto dezinformace byly útočníky zveřejněny i s příslušnými notifikacemi v mobilní aplikaci Českých novin. ČTK ve svém zpravodajském servisu žádnou informaci v tomto znění nevydala.
Byla založena nadace Open Home Foundation zastřešující více než 240 projektů, standardů, ovladačů a knihoven (Home Assistant, ESPHome, Zigpy, Piper, Improv Wi-Fi, Wyoming, …) pro otevřenou chytrou domácnost s důrazem na soukromí, možnost výběru a udržitelnost.
Společnost Meta otevírá svůj operační systém Meta Horizon OS pro headsety pro virtuální a rozšířenou realitu. Vedle Meta Quest se bude používat i v připravovaných headsetech od Asusu a Lenova.
Společnost Espressif (ESP8266, ESP32, …) získala většinový podíl ve společnosti M5Stack, čímž posiluje ekosystém AIoT.
public class Program { public static void main(String[] args) { int age=18; if(age>0){ if(age>17){ System.out.println("Jsi vitan"); }else{ System.out.println("Moc mlady"); }else{ System.out.println("chyba"); } } } }Děkuji za radu.
Když si to správně naformátuješ/odsadíš, tak na to přijdeš asi i sám :-)
public class Program { public static void main(String[] args) { int age = 18; if (age > 0) { if (age > 17) { System.out.println("Jsi vitan"); } else { System.out.println("Moc mlady"); } } else { System.out.println("chyba"); } } }
Měl jsi tam jednu } závorku o pár řádků níž, než měla být.
public class Program { public static void main(String[] args) { int age = 18; if (age > 0) { if(age > 17) { System.out.println("Jsi vítán"); } else { System.out.println("Moc mladý"); } } else { System.out.println("chyba"); } } }
Dvě poznámky:
Tak to už bych úplně nedoporučoval.
Mít identifikátory i komentáře anglicky je celkem klíčové kvůli pozdějšímu případnému sdílení kódu. Cokoliv tam bude "neanglicky", to bude představovat obrovský technologický dluh.
Proto má Java od začátku Unicode
Což ale neplatí pro zdrojový kód, kde se předpokládá „na platformě závislé kódování“.
Platí to i pro zdrojový kód, pokud jde o řetězcové literály — pro Stringy s hláškami pro lokalizaci neexistuje jiný rozumný způsob, jak je správně uložit přímo ve zdrojáku, než UTF-8. Escape-sekvence nepovažuji za rozumný způsob; údržba takové lokalizace je jeden velký horor. Teoreticky by bylo možné mít je v oddělených textových souborech, které nebudou zdrojáky — a v některých jazycích je tohle opravdu nutné —, ale … proč takové věci dělat v Javě, když javac
má volbu -encoding
? Dokonce i bez -encoding
se použije kódování implicitní na dané platformě, což u rozumných systémů bude UTF-8. (Ale samozřejmě je lepší vždy -encoding
specifikovat, kvůli některým notoricky nestandardním platformám a tak celkově pro jistotu.)
Samozřejmě tady nemluvím o identifikátorech — ty nepotřebují diakritiku, protože mají být anglicky, stejně jako komentáře, kvůli možnosti sdílet kód, najmout lidi odkudkoliv atd.
3.1. Unicode Programs are written using the Unicode character set.Nižšie v tom istom paragrafe je síce upresnenie:
Except for comments (§3.7), identifiers, and the contents of character and string literals (§3.10.4, §3.10.5), all input elements (§3.5) in a program are formed only from ASCII characters (or Unicode escapes (§3.3) which result in ASCII characters).Inak povedané, vo všetkých častiach programu, ktorých lexikálnu podobu si do nejakej miery volí používateľ, je možné napísať akýkoľvek Unicode junk. A skutočne sme mali v komentári nášho zdrojového kódu nejaký notový zápis. Ani argumentácia, že je to tak len teraz, neobstojí:
Versions of the Java programming language prior to JDK 1.1 used Unicode 1.1.5. Upgrades to newer versions of the Unicode Standard occurred in JDK 1.1 (to Unicode 2.0), JDK 1.1.7 (to Unicode 2.1), Java SE 1.4 (to Unicode 3.0), Java SE 5.0 (to Unicode 4.0), Java SE 7 (to Unicode 6.0), Java SE 8 (to Unicode 6.2), Java SE 9 (to Unicode 8.0), and Java SE 11 (to Unicode 10.0).Nota bene, javovský zdroják je a vždy bol Unicode by definition.
Hnidopišsky lze podotknout, že Unicode character set nic nepraví o kódování.
A teď trochu praxe z manuálové stránky javac:
-encoding encoding Sets the source file encoding name, such as EUC-JP and UTF-8. If the -encoding option is not specified, then the platform default converter is used.
A jednoduchý pokus:
$ cat test.java public class test { public static void main(String[] args) { System.out.println("Vařila myšička kašičku."); } } $ file test.java test.java: C source, UTF-8 Unicode text $ javac test.java test.java:3: error: unmappable character for encoding ASCII System.out.println("Va??ila my??i??ka ka??i??ku."); ^ test.java:3: error: unmappable character for encoding ASCII System.out.println("Va??ila my??i??ka ka??i??ku."); ^ test.java:3: error: unmappable character for encoding ASCII System.out.println("Va??ila my??i??ka ka??i??ku."); ^ test.java:3: error: unmappable character for encoding ASCII System.out.println("Va??ila my??i??ka ka??i??ku."); ^ test.java:3: error: unmappable character for encoding ASCII System.out.println("Va??ila my??i??ka ka??i??ku."); ^ test.java:3: error: unmappable character for encoding ASCII System.out.println("Va??ila my??i??ka ka??i??ku."); ^ test.java:3: error: unmappable character for encoding ASCII System.out.println("Va??ila my??i??ka ka??i??ku."); ^ test.java:3: error: unmappable character for encoding ASCII System.out.println("Va??ila my??i??ka ka??i??ku."); ^ test.java:3: error: unmappable character for encoding ASCII System.out.println("Va??ila my??i??ka ka??i??ku."); ^ test.java:3: error: unmappable character for encoding ASCII System.out.println("Va??ila my??i??ka ka??i??ku."); ^ 10 errors
Důvod je prostý – závisí na platformě, například na locale.
$ LC_ALL=cs_CZ.UTF-8 javac test.java
projde, protože kódování zdrojového kódu a platformy se náhodou shoduje.
Až tak přesně se shodovat nemusí; UTF-8 projde bez ohledu na zvolený jazyk. A pokud systém nemá UTF-8 jako implicitní kódování, je někde zásadní chyba (nejspíš mezi židlí a klávesnicí), kterou Java beztak nevyřeší.
Tiskni Sdílej: