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

  • SEARCH
  • Home
  • 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 83287
In Process

The Archive Base Latest Questions

Editorial Team
  • 0
Editorial Team
Asked: May 10, 20262026-05-10T21:45:00+00:00 2026-05-10T21:45:00+00:00

I have a huge dictionary of blank values in a variable called current like

  • 0

I have a huge dictionary of blank values in a variable called current like so:

struct movieuser {blah blah blah} Dictionary<movieuser, float> questions = new Dictionary<movieuser, float>(); 

So I am looping through this dictionary and need to fill in the ‘answers’, like so:

for(var k = questions.Keys.GetEnumerator();k.MoveNext(); ) {     questions[k.Current] = retrieveGuess(k.Current.userID, k.Current.movieID); } 

Now, this doesn’t work, because I get an InvalidOperationException from trying to modify the dictionary I am looping through. However, you can see that the code should work fine – since I am not adding or deleting any values, just modifying the value. I understand, however, why it is afraid of my attempting this.

What is the preferred way of doing this? I can’t figure out a way to loop through a dictionary WITHOUT using iterators.

I don’t really want to create a copy of the whole array, since it is a lot of data and will eat up my ram like its still Thanksgiving.

Thanks, Dave

  • 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-10T21:45:00+00:00Added an answer on May 10, 2026 at 9:45 pm

    Matt’s answer, getting the keys first, separately is the right way to go. Yes, there’ll be some redundancy – but it will work. I’d take a working program which is easy to debug and maintain over an efficient program which either won’t work or is hard to maintain any day.

    Don’t forget that if you make MovieUser a reference type, the array will only be the size of as many references as you’ve got users – that’s pretty small. A million users will only take up 4MB or 8MB on x64. How many users have you really got?

    Your code should therefore be something like:

    IEnumerable<MovieUser> users = RetrieveUsers();  IDictionary<MovieUser, float> questions = new Dictionary<MovieUser, float>(); foreach (MovieUser user in users) {     questions[user] = RetrieveGuess(user); } 

    If you’re using .NET 3.5 (and can therefore use LINQ), it’s even easier:

    IDictionary<MovieUser, float> questions =      RetrieveUsers.ToDictionary(user => user, user => RetrieveGuess(user)); 

    Note that if RetrieveUsers() can stream the list of users from its source (e.g. a file) then it will be efficient anyway, as you never need to know about more than one of them at a time while you’re populating the dictionary.

    A few comments on the rest of your code:

    • Code conventions matter. Capitalise the names of your types and methods to fit in with other .NET code.
    • You’re not calling Dispose on the IEnumerator<T> produced by the call to GetEnumerator. If you just use foreach your code will be simpler and safer.
    • MovieUser should almost certainly be a class. Do you have a genuinely good reason for making it a struct?
    • 0
    • Reply
    • Share
      Share
      • Share on Facebook
      • Share on Twitter
      • Share on LinkedIn
      • Share on WhatsApp
      • Report

Sidebar

Related Questions

I have a python module that makes use of a huge dictionary global variable,
I have huge 3D arrays of numbers in my .NET application. I need to
I have huge number of Word files I need to merge (join) into one
I have a huge web app that is having issues with memory leak in
I have a huge file, where I have to insert certain characters at a
I have a huge database with 100's of tables and stored procedures. Using SQL
I have a huge database with some 100 tables and some 250 stored procedures.
I have a huge text file (~1GB) and sadly the text editor I use
I have a huge file that I must parse line by line. Speed is

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.