eGospodarka.pl
eGospodarka.pl poleca

eGospodarka.plGrupypl.comp.programmingOpowiadanie o GCRe: Opowiadanie o GC
  • Path: news-archive.icm.edu.pl!news.rmf.pl!agh.edu.pl!news.agh.edu.pl!news.onet.pl!not
    -for-mail
    From: Krzysiek Kowaliczek <k...@g...com>
    Newsgroups: pl.comp.programming
    Subject: Re: Opowiadanie o GC
    Date: Mon, 27 Jul 2009 11:50:54 +0200
    Organization: http://onet.pl
    Lines: 39
    Message-ID: <h4jt7t$7s3$1@news.onet.pl>
    References: <2...@w...googlegroups.com>
    NNTP-Posting-Host: krak.alatek.krakow.pl
    Mime-Version: 1.0
    Content-Type: text/plain; charset=ISO-8859-2; format=flowed
    Content-Transfer-Encoding: 8bit
    X-Trace: news.onet.pl 1248688189 8067 217.96.2.229 (27 Jul 2009 09:49:49 GMT)
    X-Complaints-To: n...@o...pl
    NNTP-Posting-Date: Mon, 27 Jul 2009 09:49:49 +0000 (UTC)
    User-Agent: Mozilla/5.0 (Windows; U; Windows NT 5.0; en-US; rv:1.8.1.2pre)
    Gecko/20070111 SeaMonkey/1.1
    In-Reply-To: <2...@w...googlegroups.com>
    Xref: news-archive.icm.edu.pl pl.comp.programming:182804
    [ ukryj nagłówki ]

    Maciej Sobczak wrote:
    [ciach]
    > Piszę *prawie*, bo pomiędzy posprzątaniem obiektów Item (hint: to się
    > dzieje dopiero wtedy, gdy GC jest wystarczająco zestresowany, żeby się
    > w ogóle ruszyć - co następuje akurat wtedy, gdy *zaczyna brakować
    > pamięci*) a skanem mapy jest pewien odstęp czasu, kiedy niepotrzebne
    > już wpisy w mapie *nadal* zajmują pamięć, zmniejszając efektywnie pulę
    > dostępnej pamięci. To powoduje, że przy dalszej pracy programu GC
    > szybciej będzie zestresowany i znowu coś tam posprząta, ale przez nowe
    > wiszące wpisy w mapie i tak zostawi jeszcze mniejszą pulę wolnej
    > pamięci. Ostatecznie program wylatuje na jej braku, chociaż z
    > projektowego punktu widzenia może nigdy nie używać więcej, niż jednego
    > obiektu Item.
    > Oczywiście zmiany okresu skanowania mapy wpływają jedynie na
    > *prawdopodobieństwo* poprawnego działania całego programu i nigdy nie
    > można tej poprawności *zagwarantować*.
    >

    Dlaczego? Watek sprzątający może sam "kopnąć" GC.

    > Ot, taka sobie historyjka. Ale może ktoś znudzony upałami i burzami
    > wpadnie na jakiś pomysł, jak to poprawić.
    >
    > Jedną z możliwości jest dodatnie do klasy Item funkcji close() i
    > uprzejme poproszenie programisty, żeby jej używał. Jest to
    > rozwiązanie, którego poziom abstrakcji i wartość projektowa
    > odpowiadają językowi C.

    To nie jest złe. Dla bezpieczeństwa w finalizatorze można
    dodać asercje o niezwolnionym obiekcie.

    > Są inne?
    >

    Może zobaczyć jak zaimplementowali WeakHashMap ( tam "weak"
    jest klucz a nie wartość ).

    Pozdrawiam
    KK

Podziel się

Poleć ten post znajomemu poleć

Wydrukuj ten post drukuj


Następne wpisy z tego wątku

Najnowsze wątki z tej grupy


Najnowsze wątki

Szukaj w grupach

Eksperci egospodarka.pl

1 1 1

Wpisz nazwę miasta, dla którego chcesz znaleźć jednostkę ZUS.

Wzory dokumentów

Bezpłatne wzory dokumentów i formularzy.
Wyszukaj i pobierz za darmo: