Last post Dec 09, 2010 03:44 PM by nathon
Aug 16, 2007 10:37 AM|olanorm|LINK
I have a Page where I have placed a User Control. The User Control is responsible for dynamically showing a menu based on values in a database. The code for adding the menu looks like this:
private void AddMenuContent(Control container, Menu menu, List<Tab> tabs, BasePageAdmin myPage)
Version currentSystemVersion = SessionUtils.SessionContainer.CurrentDepartment.Version;
List currentUserRoles = SessionUtils.SessionContainer.User.Roles;
foreach (Tab t in tabs)
// Only add tab to this menu if it is supposed
// to be shown here, is in the current version and this user has access to it.
if (t.Menu != null && menu.Id == t.Menu.Id && !t.IsExcluded(currentSystemVersion) && t.IsAuthorized(currentUserRoles))
// Mark as isActiveTab if this Tab is the currently displayed tab.
bool isActiveTab = false;
if (t.Id == myPage.ActiveTab.Id)
isActiveTab = true;
// Decide what kind of menu to display
this.AddImageElement(t, container, isActiveTab);
this.AddTextElement(t, container, isActiveTab);
this.AddTextElement(t, container, isActiveTab);
// Decide if we should display the menu as vertical or horizontal
if (_orientation == Orientations.Vertical)
MenuContent.Controls.Add(new LiteralControl("<br />"));
} // End foreach
This method is called from Page_Load of the User Control. Some times, this method throws this exception:
Can anyone explain why this exception is being thrown? And why is it not thrown on every request?
Aug 16, 2007 11:49 AM|d4dennis@inspir3|LINK
If you wish to add/edit/delete item from <list> best to use following to prevent modified enumeration collection.
For ( int i = 0; i < tabs.Count; i++ )
Hope it helps!
Aug 16, 2007 12:04 PM|olanorm|LINK
But I'm not adding/editing/deleting any of the items in the tabs collection inside the foreach loop? I'm only adding to the Control called container that I'm passing as a parameter. Or is it maybe that one that is causing the problem?
Aug 16, 2007 12:10 PM|d4dennis@inspir3|LINK
What are you doing in this function ?
this.AddTextElement(t, container, isActiveTab); // i doubt you are adding something to your tab ? if yes, is this editing?
In addition of that, if you put the Foreach inside try and catch
// do nothing
The operation will still complete and catches the error.
Aug 16, 2007 12:12 PM|valenumr|LINK
You can't add or remove items for a collection in a foreach loop. Try converting the collection to an array (use Collection.ToArray()), and iterate over the array. Then you can add items to the collection, since you are iterating over the array, not the
Aug 16, 2007 12:17 PM|olanorm|LINK
Here is the code of the functions being called inside the foreach loop
private void AddImageElement(Tab t, Control c, bool isActiveTab)
Theme currTheme = SessionUtils.SessionContainer.Theme;
string themePath = "~/Themes/" + currTheme.Path + "/images/menu/";
string languageExtension = "en";
if (_currentSystemLanguage != null)
languageExtension = _currentSystemLanguage.Culture;
string linkimage = "";
linkimage += @"<img src=";
linkimage += Page.ResolveUrl(themePath + t.TabAlias + ".3." + languageExtension + ".gif");
linkimage += Page.ResolveUrl(themePath + t.TabAlias + ".1." + languageExtension + ".gif");
linkimage += " alt=\"" + TabBLL.GetLocalizedTabTooltip(t) + "\"";
linkimage += " border=\"0\">";
c.Controls.Add(new LiteralControl("<a href=\"DesktopDefault.aspx?tabalias=" + t.TabAlias + "\">" + linkimage + "</a>"));
private void AddTextElement(Tab t, Control c, bool isActiveTab)
c.Controls.Add(new LiteralControl("<a href=\"DesktopDefault.aspx?tabalias=" + t.TabAlias + "\">" + TabBLL.GetLocalizedTabName(t) + "</a>"));
As far as I can see, it is only the Control collection c that is being modified when new controls are added to it. But that's perfectly ok isn't it?
Yes I can catch the exception, but I don't think that is very nice. I would rather know why it's telling me that the collection is being modified.
Aug 16, 2007 12:34 PM|valenumr|LINK
that does certainly seem to be the case (that you are only modifying Controls). So either there is some wierd reference foo (did you add the Tabs objects to the Control's collection?), or you are somehow modifying a tab indirectly. I *think* that most collections
have a "dirty" property for their items, and if that flag is set during an iteration, it freaks out.... anyhow, try the array thing I mentioned... it should work?
May 29, 2009 08:07 AM|sirajulhasan|LINK
Dec 09, 2010 03:44 PM|nathon|LINK
I was having this problem as well with the same exception you were getting. I saw the part about modifying the List object inside a foreach loop, but mine wasn't even inside a foreach loop.
It turns out that the problem came from a null item I was adding to the list. I wanted 1 item in the list, but didn't want it to contain any data. It didn't throw an exception when adding it. However, later when I tried to access the list it would give this
System.InvalidOperationException - "Collection was modified; enumeration operation may not execute."
When I changed the code from this...
MyList.Add(new MyListItem(param1, param2, ...));
It worked just fine; no more exception! I don't know if this applies to other people's instances of getting this exception, but I hope it helps.