abclinuxu.cz AbcLinuxu.cz itbiz.cz ITBiz.cz HDmag.cz HDmag.cz abcprace.cz AbcPráce.cz
AbcLinuxu hledá autory!
Inzerujte na AbcPráce.cz od 950 Kč
Rozšířené hledání
×

dnes 14:11 | Komunita

Některým uživatelům Firefoxu se tento týden do Firefoxu nainstalovalo neznámé rozšíření Looking Glass 1.0.3 (png). Ve fórů Mozilly se řešilo, zda se nejedná o malware. Mozilla později informovala, že se jednalo o reklamu na seriál Mr. Robot. Řadě uživatelů Firefoxu se jednání Mozilly vůbec nelíbilo. Mozilla proto automatickou instalaci doplňku ukončila [Hacker News, reddit].

Ladislav Hagara | Komentářů: 2
včera 12:00 | Nová verze

Po cca 3 týdnech od vydání Linux Mintu 18.3 s kódovým jménem Sylvia a prostředími MATE a Cinnamon byla oznámena také vydání s prostředími KDE a Xfce. Podrobnosti v poznámkách k vydání (KDE, Xfce) a v přehledech novinek s náhledy (KDE, Xfce). Linux Mint 18.3 je podporován do roku 2021.

Ladislav Hagara | Komentářů: 6
15.12. 12:55 | Nová verze

Byla vydána verze 17.12.0 KDE Aplikací (KDE Applications). Přehled novinek v kompletním seznamu změn a na stránce s dalšími informacemi. Aplikace, které nebyly dosud portovány na KDE Frameworks 5, byly z KDE Aplikací odstraněny.

Ladislav Hagara | Komentářů: 52
15.12. 03:00 | Komunita

Na Humble Bundle lze získat počítačovou hru Company of Heroes 2 (Wikipedie, YouTube) běžící také v Linuxu zdarma. Speciální akce končí v sobotu v 19:00.

Ladislav Hagara | Komentářů: 0
15.12. 02:00 | Zajímavý software

Christian Kellner představil na svém blogu projekt Bolt řešící bezpečnost rozhraní Thunderbolt 3 na Linuxu. Pomocí příkazu boltctl nebo rozšíření GNOME Shellu lze komunikovat s démonem boltd a například zakázat neznámá zařízení a předejít tak útokům typu Thunderstrike nebo DMA.

Ladislav Hagara | Komentářů: 8
15.12. 01:00 | Nová verze

Po půl roce vývoje od vydání verze 11.0 byla vydána verze 11.1 svobodného softwaru pro vytváření datových úložišť na síti FreeNAS (Wikipedie). Nejnovější FreeNAS je postaven na FreeBSD 11.1. Přehled novinek v příspěvku na blogu. Zdůraznit lze zvýšení výkonu OpenZFS, počáteční podporu Dockeru nebo synchronizaci s cloudovými službami Amazon S3 (Simple Storage Services), Backblaze B2 Cloud, Google Cloud a Microsoft Azure

Ladislav Hagara | Komentářů: 0
14.12. 23:55 | Nová verze

Po dvou měsících vývoje od vydání verze 235 oznámil Lennart Poettering vydání verze 236 správce systému a služeb systemd (GitHub, NEWS).

Ladislav Hagara | Komentářů: 10
14.12. 20:00 | Nová verze Ladislav Hagara | Komentářů: 0
14.12. 19:33 | Pozvánky

Pražská Fedora 27 Release Party, oslava nedávného vydání Fedory 27, se uskuteční 19. prosince od 19:00 v prostorách společnosti Etnetera (Jankovcova 1037/49). Na programu budou přednášky o novinkách, diskuse, neřízený networking atd.

Ladislav Hagara | Komentářů: 0
14.12. 18:11 | Nová verze

Byla vydána verze 2.11.0 QEMU (Wikipedie). Přispělo 165 vývojářů. Provedeno bylo více než 2 000 commitů. Přehled úprav a nových vlastností v seznamu změn.

Ladislav Hagara | Komentářů: 0
Jak se vás potenciálně dotkne trend odstraňování analogového audio konektoru typu 3,5mm jack z „chytrých telefonů“?
 (8%)
 (0%)
 (1%)
 (1%)
 (75%)
 (14%)
Celkem 1007 hlasů
 Komentářů: 45, poslední 1.12. 19:00
    Rozcestník

    Dotaz: Zvětšení pole v Javě

    16.2.2012 10:35 Conpuerus | skóre: 4
    Zvětšení pole v Javě
    Přečteno: 454×
    Zdravím, potřeboval bych poradit s následujícím problémem. Mám takovýto kód (úseky):
    public class RevList<E extends Comparable<E>> implements ReversibleList<E> {
    
    	private E list[] = null;
    	private int size = 1;
    	private int current = 0;
    
    …
    
    	@Override
    	public void add(E e) {
    		if (size == current) {
    
    		}
    	}
    
    a potřebuji dvojnásobně zvětšit pole list (v té podmínce). Kdyby to byl např. normální int, tak nemám problém. Jak to mám ale udělat, když je tam to E? (Potřebuji to do školní úlohy, kde je zadání takové, že máme implementovat vlastní metody komponenty ReversibleList, které jsme dostali jako rozhraní, a nesmíme přitom použít kolekce…)

    Řešení dotazu:


    Odpovědi

    16.2.2012 11:29 juriad | skóre: 7
    Rozbalit Rozbalit vše Re: Zvětšení pole v Javě
    Podívej se na implementaci ArrayListu, pole je pořád typu Object[] a jen v public metodách se provádí šaškárna s přetypováním
    16.2.2012 11:33 juriad | skóre: 7
    Rozbalit Rozbalit vše Re: Zvětšení pole v Javě
    nebo se na pole vykašli a implementuj to jako spoják (neznám zadání, toto řešení by možná nemuselo vyhovovat), viz LinkedList
    16.2.2012 12:00 Conpuerus | skóre: 4
    Rozbalit Rozbalit vše Re: Zvětšení pole v Javě
    LinkedList jsem chtěl použít, ale když jsem při přidávání zjistil, že to je moc jednoduché (ll.add()), tak mi bylo hned jasné, že to není dovoleno (čili - není LinkedList kolekce?).
    16.2.2012 12:08 Conpuerus | skóre: 4
    Rozbalit Rozbalit vše Re: Zvětšení pole v Javě
    Ano, jako spojový seznam to udělat můžeme, ale nějak nevím, jak to použít. Je mi jasné, jak musí vypadat funkčnost (pamatovat si toho před sebou a za sebou, jak vkládat a mazat atd.), ale nevím, z jakých komponent to sestavit (jestli udělat vlastní či jak)…
    16.2.2012 11:51 Filip Jirsák | skóre: 67 | blog: Fa & Bi
    Rozbalit Rozbalit vše Re: Zvětšení pole v Javě
    Potřebuji to do školní úlohy, kde je zadání takové, že máme implementovat vlastní metody komponenty ReversibleList, které jsme dostali jako rozhraní, a nesmíme přitom použít kolekce…
    Ach jo. To by mne zajímalo, jaký je v tom výchovný záměr, naučit to někoho schválně dělat blbě.

    Jinak když použijete java.util.Arrays.copyOf(), nemusíte myslím nic moc řešit. A až ten úkol dokončíte, tak na to celé hlavně rychle zapomeňte – pole a primitivní typy jsou v Javě především z historických důvodů, kdy to byl způsob optimalizace. Pokud k tomu nemáte nějaký pádný důvod (jako třeba hloupé zadání školní úlohy), používejte kolekce, ty jsou mnohem pružnější.
    16.2.2012 12:06 Conpuerus | skóre: 4
    Rozbalit Rozbalit vše Re: Zvětšení pole v Javě
    Já jsem to chtěl udělat takto (bude to pole intů):
    int list[] = new int[1];
    int tmp[] = list.clone();
    list = new int[2*list.length]
    atd

    Jenomže když to pole list není int, ale E, tak nevím, jak udělat to list = new E[2*list.length] (toto je samozřejmně špatně…)

    16.2.2012 12:15 Filip Jirsák | skóre: 67 | blog: Fa & Bi
    Rozbalit Rozbalit vše Re: Zvětšení pole v Javě
    Proč to zbytečné klonování? Nehledě na to, že klonování bych se spíš vyhýbal, protože nikdy nevíte, co to vlastně udělá. Raději než tohle ruční kopírování bych použil tu výše uvedenou metodu – jednak už to tam máte implementováno, jednak ta metoda může být v některých budoucích verzích implementována nativně a v některých případech se třeba obejde bez kopírování.

    Generiky se v konstruktoru pole použít nedají, je to omezení plynoucí z toho, jak jsou generiky v Javě implementovány. Takže byste musel použít konstrukci
    (E[]) new Object[list.length*2]
    
    16.2.2012 12:23 Conpuerus | skóre: 4
    Rozbalit Rozbalit vše Re: Zvětšení pole v Javě
    A jak by se do tedy dalo vyřešit (nejspíš lépe) pomocí spojových seznamů (viz. výše)?
    16.2.2012 12:26 Filip Jirsák | skóre: 67 | blog: Fa & Bi
    Rozbalit Rozbalit vše Re: Zvětšení pole v Javě
    Inspirací ve zdrojáku java.util.LinkedList :-) Nebo si vyhledejte na internetu "spojový seznam", určitě najdete spoustu popisů toho, jaké se používají struktury a jak jsou implementovány jednotlivé operace.
    16.2.2012 12:27 Conpuerus | skóre: 4
    Rozbalit Rozbalit vše Re: Zvětšení pole v Javě
    Ok, díky za pomoc, zkusím to a snad něco dopadne :-)
    Solitary avatar 16.2.2012 13:06 Solitary
    Rozbalit Rozbalit vše Re: Zvětšení pole v Javě
    O jakou skolu jde?
    16.2.2012 17:08 kuka
    Rozbalit Rozbalit vše Re: Zvětšení pole v Javě
    Vychovny zamer pravdepodobne smeruje k pochopeni vztahu generik a poli, ktery je celkem netrivialni. Ze je to v kontextu jednoduche ulohy, ktera by sla jinym zpusobem resit mozna lepe, neni asi nic proti nicemu.
    19.2.2012 09:29 Conpuerus | skóre: 4
    Rozbalit Rozbalit vše Re: Zvětšení pole v Javě
    Jde o ČVUT FEL (2. ročník, kdyby vás někoho zajímal i předmět, tak to je Architektura softwarových systémů) a souhlasím s tím, že je to k pochopení generik a polí.

    Založit nové vláknoNahoru

    Tiskni Sdílej: Linkuj Jaggni to Vybrali.sme.sk Google Del.icio.us Facebook

    ISSN 1214-1267   www.czech-server.cz
    © 1999-2015 Nitemedia s. r. o. Všechna práva vyhrazena.