Sign Up

Sign Up to our social questions and Answers Engine to ask questions, answer people’s questions, and connect with other people.

Have an account? Sign In

Have an account? Sign In Now

Sign In

Login to our social questions & Answers Engine to ask questions answer people’s questions & connect with other people.

Sign Up Here

Forgot Password?

Don't have account, Sign Up Here

Forgot Password

Lost your password? Please enter your email address. You will receive a link and will create a new password via email.

Have an account? Sign In Now

You must login to ask a question.

Forgot Password?

Need An Account, Sign Up Here

Please briefly explain why you feel this question should be reported.

Please briefly explain why you feel this answer should be reported.

Please briefly explain why you feel this user should be reported.

Sign InSign Up

The Archive Base

The Archive Base Logo The Archive Base Logo

The Archive Base Navigation

  • Home
  • SEARCH
  • About Us
  • Blog
  • Contact Us
Search
Ask A Question

Mobile menu

Close
Ask a Question
  • Home
  • Add group
  • Groups page
  • Feed
  • User Profile
  • Communities
  • Questions
    • New Questions
    • Trending Questions
    • Must read Questions
    • Hot Questions
  • Polls
  • Tags
  • Badges
  • Buy Points
  • Users
  • Help
  • Buy Theme
  • SEARCH
Home/ Questions/Q 99705
In Process

The Archive Base Latest Questions

Editorial Team
  • 0
Editorial Team
Asked: May 11, 20262026-05-11T00:26:20+00:00 2026-05-11T00:26:20+00:00

In the constructor of my class, I map the current object ( this ),

  • 0

In the constructor of my class, I map the current object (this), along with its key (a string entered as a parameter in the constructor) into a static LinkedHashMap so I can reference the object by the string anywhere I might need it later.

Here’s the code (if it helps):

public class DataEntry {     /** Internal global list of DataEntry objects. */     private static LinkedHashMap _INTERNAL_LIST;      /** The data entry's name. */     private String NAME;      /** The value this data entry represents. */     private Object VALUE;       /** Defines a DataEntry object with a name and a value. */     public DataEntry( String name, Object value )     {         if( _INTERNAL_LIST == null )         {             _INTERNAL_LIST = new LinkedHashMap();         }          _INTERNAL_LIST.put( name, this );          NAME = name;         VALUE = value;     } } 

The problem? Instances of this class won’t get garbage collected when I’m done using them.

I’m just curious if there’s a way to have instances of this class clean themselves up when I’m done using them without having to manually call a Remove() method or something each time (to remove its reference in the internal LinkedHashMap when I’m no longer using them, I mean).

  • 1 1 Answer
  • 0 Views
  • 0 Followers
  • 0
Share
  • Facebook
  • Report

Leave an answer
Cancel reply

You must login to add an answer.

Forgot Password?

Need An Account, Sign Up Here

1 Answer

  • Voted
  • Oldest
  • Recent
  • Random
  1. 2026-05-11T00:26:20+00:00Added an answer on May 11, 2026 at 12:26 am

    Making an object visible to others before its constructor is complete is not thread safe.

    It’s not clear how the map is being used in this case, but suppose there’s a static method like this in the class:

    public static DataEntry getEntry(String name) {   return _INTERNAL_LIST.get(name); } 

    Another thread, running concurrently, can access a DataEntry while it is being created, and start to use an entry with an uninitialized VALUE. Even you reorder the code in the constructor so that adding the new instance to the map is the last thing you do, the JVM is allowed to reorder the instructions so that the object is added to the list first. Or, if the class is extended, the subclass initialization could take place after the object has been published.

    If more than one thread accesses the interacts with the DataEntry class, you could have a concurrency bug that is platform dependent, intermittent, and very tough to diagnose.

    The article, ‘Safe Construction,’ by Brian Goetz has more information on this topic.

    Back to the original question: using WeakReference, as mentioned by others, is a good approach, but rather than iterating over every entry in the map, I’d recommend creating a wrapper for your values that extends WeakReference (it could be your DataEntry itself, or a helper), and queuing each reference in a ReferenceQueue. That way, you can quickly poll the queue for any collected entries, and remove them from the map. This could be done by a background thread (blocking on remove) started in a class initializer, or any stale entries could be cleaned (by polling) each time a new entry is added.

    If your program is multi-threaded, you should abandon LinkedHashMap for a map from java.util.concurrent, or wrap the LinkedHashMap with Collections.synchronizedMap().

    • 0
    • Reply
    • Share
      Share
      • Share on Facebook
      • Share on Twitter
      • Share on LinkedIn
      • Share on WhatsApp
      • Report

Sidebar

Ask A Question

Stats

  • Questions 74k
  • Answers 74k
  • Best Answers 0
  • User 1
  • Popular
  • Answers
  • Editorial Team

    How to approach applying for a job at a company ...

    • 7 Answers
  • Editorial Team

    How to handle personal stress caused by utterly incompetent and ...

    • 5 Answers
  • Editorial Team

    What is a programmer’s life like?

    • 5 Answers
  • added an answer In a lot of scripting and shell languages, there is… May 11, 2026 at 2:29 pm
  • added an answer Kind of from collections import defaultdict fq= defaultdict( int )… May 11, 2026 at 2:29 pm
  • added an answer You're right, you can't and shouldn't cast from base class… May 11, 2026 at 2:29 pm

Related Questions

I have a system that I need to distrubte that works as follows. Servlets
I'm working on an asp.net-mvc application. The linq data context is being passed into
I'm trying to figure out the correct syntax to use the pipe operator |>
I have, for my game, a Packet class, which represents network packet and consists

Trending Tags

analytics british company computer developers django employee employer english facebook french google interview javascript language life php programmer programs salary

Top Members

Explore

  • Home
  • Add group
  • Groups page
  • Communities
  • Questions
    • New Questions
    • Trending Questions
    • Must read Questions
    • Hot Questions
  • Polls
  • Tags
  • Badges
  • Users
  • Help
  • SEARCH

Footer

© 2021 The Archive Base. All Rights Reserved
With Love by The Archive Base

Insert/edit link

Enter the destination URL

Or link to existing content

    No search term specified. Showing recent items. Search or use up and down arrow keys to select an item.