Po 9 týdnech vývoje od vydání Linuxu 7.0 oznámil Linus Torvalds vydání Linuxu 7.1. Přehled novinek a vylepšení na LWN.net: první a druhá polovina začleňovacího okna a časem také na Linux Kernel Newbies.
Cheat Engine (Wikipedie) je s verzí 7.7 k dispozici už také pro Linux. Jedná se o proprietární skener/debugger paměti používaný především k cheatování v počítačových hrách.
Vláda USA nařídila společnosti Anthropic pozastavit přístup k modelům Fable 5 a Mythos 5 pro všechny cizince, včetně zaměstnanců Anthropicu.
Společnost Murena představila (YouTube) novou verzi 4.0 mobilního operačního systému /e/OS (Wikipedie) založeného na Androidu a LineageOS bez aplikací a služeb od Googlu.
V Arch User Repository (AUR) bylo kompromitováno přes 400 opomíjených balíčků (jejich seznam). Útočník do nich začlenil škodlivý npm balíček atomic-lockfile, který krade citlivá data uživatelů. Publikována byla předběžná analýza spouštěného malwaru deps.
Homebrew, správce balíčků nejen pro macOS, byl vydán ve verzi 6.0.0 (seznam změn). Hlavními novinkami jsou bezpečnostní mechanismus tap trust kvůli důvěryhodnosti závislostí, vylepšení sandboxingu na Linuxu, interní JSON API nebo zlepšení výkonu.
Byla nalezena a 9. června opravena kritická zranitelnost ve FreeBSD v Kernel TLS (KTLS). Pojmenována byla Bumsrakete (FreeBSD-SA-26:26.ktls, CVE-2026-45257). Lokální neprivilegovaný uživatel může přepisovat soubory, ke kterým má právo pouze pro čtení. Přepsáním setuid binárky a jejím spuštěním může získat roota. Na všech verzích od verze 13.0 vydané v dubnu 2021.
Vývojáři open source operačního systému ReactOS (Wikipedie), jehož cílem je kompletní binární kompatibilita s aplikacemi a ovladači pro Windows, se na síti 𝕏 pochlubili, že ReactOS zvládne počítačovou hru Half-Life.
Byla vydána nová verze 4.8 multiplatformního integrovaného vývojového prostředí (IDE) pro rychlý vývoj aplikaci (RAD) ve Free Pascalu Lazarus (Wikipedie). Využíván je Free Pascal Compiler (FPC) 3.2.2.
Apple container dospěl do verze 1.0.0. Jedná se o open source nástroj pro spouštění linuxových kontejnerů na macOS postavený nad containerization. Napsaný je v programovacím jazyce Swift a optimalizovaný pro Apple silicon.
Čau
Programuju Java Applet (pomocí JApplet) a nelíbí se mi implicitní ColorChooser tak sem si naprogramoval svůj. Nedělám s Javou moc dlouho.. no třídu svého ColorChooseru (MyColorChooser) jsem dal do speciálního souboru a protože v něm mám programovaných víc svýcho komponent tak sem to zabalil do třídy MyColors:
<code>
MyColors.java:
public class MyColors{
public class MyColorChooser extends javax.swing.JPanel{
private SpectrumSlider Slider;
...
public MyColorChooser(){
...
}
...
}
public class SpectrumSlider extends javax.swing.JLabel {
float hue, saturation, brightness;
int WIDTH, HEIGHT, SIDE, VERTICALBORDER;
SpectrumSlider(){this(15, 180);}
SpectrumSlider(int a, int b){
super();
...
}
...
}
...
}
</code>
Mno... a v souboru s hlavní třídou - MyJApplet.java mám kód
<code>
private MyColors.MyColorChooser ColorChooser
</code>
To funguje bez problémů.. Tohle však háže chybu <code> ColorChooser = new MyColors.MyColorChooser(); </code> C:\...\NetBeansProjects\MyJApplet\src\MyJApplet.java:110: an enclosing instance that contains MyColors.MyColorChooser is required Nevím co s tím, zdalipak se najde laskavá duše co poradí? Dííík..
Ne ze bych nekdy nejaky aplet napsal ... , ale sdruzovani trid se v jave resi pres baliky (ostatne nepouzivas defaultni balik, ze:). Plati co verejna trida, to soubor.
Vnorene tridy viz odpoved vyse. (Nemas k nim primy pristup, potreboval bys (statickou?) instanci vnejsi tridy, ktera by ti poskytla instanci tridy vnitrni -- to je to, co ti ta hlaska rika.)
Takze pokud to fakt nepotrebujes (neznam konkretne aplety), tak to dej do zvlastnich souboru v jednom baliku (cz.moje.utils whatever).
static, můžete vytvářet jejich instance (analogicky k přístupu ke statickým proměnným nebo volání statických metod) nezávisle na tom, zda máte instanci vnější třídy. Samozřejmě pouze pokud k nim máte přístup, platí obvyklý význam slov public, protected, private. Taková vnořená třída pak pochopitelně nemá přístup k instančním členům vnější třídy.
Vnořená třída, která není static, se nazývá vnitřní třída a je součástí instance vnější třídy. Je to užitečné, ale pokud tomu člověk příliš nerozumí, měl by používat pravidlo každá vnořená třída bude static. Zatímco u statických vnořených tříd má veřejný přístup (public) často smysl, u vnitřních tomu tak nebývá, většinou jsou soukromé (private) jenom pro potřeby vnějších tříd. Každopádně pokud je to opravdu potřeba, lze toto:
public class A {
...
public class B {
...
}
}
---
A a = new A();
A.B b = a.new B()
Ovšem úpěnlivě vás prosím: NEDĚLEJTE TO!
Fakt to moc nepomáhá čtení kódu, tahle konstrukce je hodně neobvyklá.
Yep dík moc, stih sem na to přijít ještě včera :D Ale díky moc
Tiskni
Sdílej: