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 438577
In Process

The Archive Base Latest Questions

Editorial Team
  • 0
Editorial Team
Asked: May 12, 20262026-05-12T20:41:32+00:00 2026-05-12T20:41:32+00:00

Normally (ie. not concurrently), putAll() cannot be more efficient than using lot’s of calls

  • 0

Normally (ie. not concurrently), putAll() cannot be more efficient than using lot’s of calls to put(), even assuming that you exclude the cost of building the other Map that you pass to putAll(). That’s because putAll() will need to iterate the passed Map’s elements, as well as running through the algorithm for adding each key value pair to the Map that put() executes.

But for a ConcurrentHashMap, does it make sense to construct a regular Map and then use putAll() to update it? Or should I just do 10 (or 100, or 1000) calls to put()?

Does the answer change for multiple calls to putIfAbsent()?

Thanks!

  • 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. Editorial Team
    Editorial Team
    2026-05-12T20:41:32+00:00Added an answer on May 12, 2026 at 8:41 pm

    The first (mostly) threadsafe Map in Java Collections was the synchronized HashMap using Collections.synchronizedMap(). It worked by only allowing one operation at a time. Java 5 added the ConcurrentHashMap, which works differently. Basically the Map is divided into slices. A put() operation will only lock the relevant slice. It also added the threadsafe primitives like putIfAbsent().

    The reason I explain this is that putAll() might be more or less efficient depending on how it’s implemented. It may work by locking the whole map, which may actually be more efficient than trying to obtain individual locks on every put(). Or it may work by doing a bunch of put() calls anyway, in which case there’s not much difference.

    So if it makes sense for your code and you’re doing a lot of updates at once, I would use putAll() unless it’s putIfAbsent() that you’re after.

    Edit: I just checked, the Java 6 ConcurrentHashMap implements putAll() as a loop of put() operations so it’s no better or worse than doing this yourself.

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

Sidebar

Related Questions

I think I found more bugs in my web application. Normally, I do not
I normally do most of this work in Excel 2007, but I do not
OK, so my websites been working normally up until now, I'm not really sure
I know this is not normally recommended but I really need to access the
I have a long-running process that must run every five minutes, but more than
Here is the folder layout. /outside is not normally accessible anywhere on example.com /public_html
I'm aware that it's normally not a good idea to return with std::move ,
I know that normally there are no problems using Git from different OSs to
We're using JBoss 4.22 with portlets. When the listener tag is not in the
Everything was going well. Nightly builds ran for more than a month with no

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.