C
C#3y ago
Matt

Count updating before it's supposed to

public void CheckCounts()
{
ReadCounts();

Console.WriteLine($"Current TE Count = {CollectibleCounts[0]}\nPrevious TE Count = {PreviousCollectibleCounts[0]}");
if (!Enumerable.SequenceEqual(PreviousCollectibleCounts, CollectibleCounts))
{
PreviousCollectibleCounts = CollectibleCounts;
UpdateServerData(HeroHandler.CurrentLevelId, LevelData[HeroHandler.CurrentLevelId], "Collectible");
}
}
public void CheckCounts()
{
ReadCounts();

Console.WriteLine($"Current TE Count = {CollectibleCounts[0]}\nPrevious TE Count = {PreviousCollectibleCounts[0]}");
if (!Enumerable.SequenceEqual(PreviousCollectibleCounts, CollectibleCounts))
{
PreviousCollectibleCounts = CollectibleCounts;
UpdateServerData(HeroHandler.CurrentLevelId, LevelData[HeroHandler.CurrentLevelId], "Collectible");
}
}
This function is called in an infinite loop. When run, the code writes to the console with the previous and current collectible counts. For example, let's say I have 2 collectibles. The code writes: "Current TE Count = 2" "Previous TE Count = 2" Every time the loop executes. When I then collect a collectible, since there is literally nowhere else in the code assigning anything to the previous count other than what I've posted, I would expect to see: "Current TE Count = 3" "Previous TE Count = 2" Then the if statement would be called, updating the previous count and only then should I see: "Current TE Count = 3" "Previous TE Count = 3" In reality, I never see a console write where the current and previous counts are different. Any idea why? I'm aware this is difficult to answer without any other code but believe me when I say I have checked to see if previous count is being updated somewhere else many times.
4 Replies
troy236
troy2363y ago
If you want to monitor changes to a collection you should use ObservableCollection<T>
Matt
MattOP3y ago
I'm not sure that's what I want the issue is that I am constantly updating the data in the collection. I need to only recognize when a value changes. It seems like an observable collection can't tell the difference between an assignment of the same value and an assignment of a different value but I'll happily be wrong this also seems like a case where that implementation is far more complex than what is required. And it still doesn't answer the question of why is the code not executing in the correct order I'm not using any async implementation anywhere. Multithreading yes but there's only one thread ever working on this section of code
Matt
MattOP3y ago
for reference
Matt
MattOP3y ago
solved
PreviousCollectibleCounts = CollectibleCounts;
PreviousCollectibleCounts = CollectibleCounts;
is a bad idea. it sets the arrays to be equal and for some reason... always equal. I wasn't aware this is how arrays work but sure why not

Did you find this page helpful?