Portál AbcLinuxu, 2. května 2025 08:33
Asi na tomto všetky podobné pokusy stroskotali a to je bezpečnosť. Dnešné systémy stavajú na tom, že napríklad spomínaná kamerá má nejaké API ktoré si musím naštudovať, aby som odtiaľ vytiahol nejaký RAW snímok, alebo video prúd. StructuredOS by mi poslal celý objekt aj z metódami. Napr. camera.getPNG() hoci pošle PNG obrázok, ale popri tom spustí nejaký hack.Tohle je imho řešitelné v Selfu například tak, že sice umožníš posílání přímo objektů, ale neumožníš, aby měly sloty s metodami. Veškerou funkcionalitu pak musí odkazovat přes parent sloty. Zajímavě by to řešil třeba Korz, který by tenhle objekt prostě otevřel v dimenzi, kde nejsou žádné prostředky, jak se z ní dostat ven, tzn chybí tam mirrory, funkce pro práci se socketem, diskem a C API.
Příští díl bude obsahovat pár odkazů. V podstatě jde o to, že objekt spustíš v takovém jakémsi sandboxu, ze kterého nemá cestu ven.To je teraz dosť hype. Tak som zvedavý na použiteľnosť.
Stojí za zamyšlení si to srovnat s na třídách založenými jazyky, které zpravidla trpí přesně opačným problémem, kde se snaží pojmenovat úplně všechno.
I v těchto jazycích (např. v Javě) lze vytvářet anonymní třídy (pak mají nějaký automaticky generovaný název) a dokonce je i generovat dynamicky za běhu programu.
instance má jméno proměnné kde existuje.
Skutečně mají jméno? Objekt přece většinou existuje na haldě a neví, jak se jmenuje, ani komu patří.
Jestli na ten objekt ukazuje nějaká reference, to je věc jiná. A těch referencí může být více a nebo taky žádná. A třeba v C++ ti je ani v dlouhodobém horizontu nepožere GC, takže si můžeš vyrobit na haldě spoustu anonymních objeků, a pak se trefovat pomocí ukazatelů na různá místa v paměti a nacházet tam ty objekty (třeba v poli).
Tiskni
Sdílej:
ISSN 1214-1267, (c) 1999-2007 Stickfish s.r.o.