Wayback Machinekoobas.hobune.stream
May JUN Jul
Previous capture 13 Next capture
2021 2022 2023
1 capture
13 Jun 22 - 13 Jun 22
sparklines
Close Help
  • Products
  • Solutions
  • Made with Unity
  • Learning
  • Support & Services
  • Community
  • Asset Store
  • Get Unity

UNITY ACCOUNT

You need a Unity Account to shop in the Online and Asset Stores, participate in the Unity Community and manage your license portfolio. Login Create account
  • Blog
  • Forums
  • Answers
  • Evangelists
  • User Groups
  • Beta Program
  • Advisory Panel

Navigation

  • Home
  • Products
  • Solutions
  • Made with Unity
  • Learning
  • Support & Services
  • Community
    • Blog
    • Forums
    • Answers
    • Evangelists
    • User Groups
    • Beta Program
    • Advisory Panel

Unity account

You need a Unity Account to shop in the Online and Asset Stores, participate in the Unity Community and manage your license portfolio. Login Create account

Language

  • Chinese
  • Spanish
  • Japanese
  • Korean
  • Portuguese
  • Ask a question
  • Spaces
    • Default
    • Help Room
    • META
    • Moderators
    • Topics
    • Questions
    • Users
    • Badges
  • Home /
avatar image
0
Question by TK Han · Nov 04, 2013 at 06:54 AM · loopfreezenested

Nested for-loop freezing Unity

 for (int i = 0; i < Chunk.Width; i++)
 {
     for (int j = 0; j < Chunk.Height; j++)
     {
         for (int k = 0; k < Chunk.Length; k++)
         {
             //Debug.Log(new Vector3(i, j, k));
             //if (random.Next(2) == 1)
             //{
             //    Debug.Log("Adding block");
             //    chunk.Set(i, j, k, testBlock);
             //}
         }
     }
 }

Above code works well. However, the editor freezes on play when I uncomment ANY of the lines within the innermost for-loop.

It's weird that Unity has no problem running the loop when there is nothing in it, but freezes just by adding a Debug.Log line.

I can't seem to figure out what is the problem, so I would be grateful if anyone can tell me what's wrong with the code and how I can fix it.

Comment
Add comment
10 |3000 characters needed characters left characters exceeded
▼
  • Viewable by all users
  • Viewable by moderators
  • Viewable by moderators and the original poster
  • Advanced visibility
Viewable by all users

1 Reply

· Add your reply
  • Sort: 
avatar image
2
Best Answer

Answer by Tomer-Barkan · Nov 04, 2013 at 06:58 AM

It's very likely that it simply takes very very long for the for loop to run. It take Chunk.Width Chunk.Height Chunk.Length iterations to run the loop, now if those numbers are large, it could cause unity to seem frozen while it's running those iterations. Now, Debug.Log is an IO operation which is relatively expensive, so running it 500 x 500 x 500 times will take a long time. And if you do this every frame, then that makes it even worse...

The reason that this doesn't happen when you have no commands inside the for is simple. The compiler recognizes that nothing whatsoever happens in the for, so it optimizes it by removing the code completely.

If I'm right, first thing you'd want to do is remove the logs because they are a heavy operation. If it still feels stuck, then your design has a performance flaw. Either make the loops smaller, or do them only once in the Start() method, and simply wait for them to finish.

Comment
Add comment · Show 9 · Share
10 |3000 characters needed characters left characters exceeded
▼
  • Viewable by all users
  • Viewable by moderators
  • Viewable by moderators and the original poster
  • Advanced visibility
Viewable by all users
avatar image TK Han · Nov 04, 2013 at 07:02 AM 0
Share

First of all, thank you for explaining about the optimization.

Another question though: The values for the three dimensions are 32 each and this is only done once in Start() function; is it still too intensive task to completely freeze Unity?

avatar image Hoeloe · Nov 04, 2013 at 07:08 AM 1
Share

Think of it this way. Debug.Log takes a fairly long time. If each of the dimensions is 32, then with those two log statements, in the worst case you're doing 32*32*32*2 (for both log statements), which is 65536 log statements. That's a lot. If you're printing more than a few hundred at once, you'll have some problems. Take the log statements out, then give it a try.

avatar image Tomer-Barkan · Nov 04, 2013 at 07:12 AM 0
Share

Like @Hoeloe said, although 32*32*32 = 32$$anonymous$$ is not that bad a thing to do in the Start() method when needed, Debug.Log() is expensive, so remove them first.

BTW, if you have the script attached to more than one object, than that also multiplies the number of times the for loop runs.

avatar image TK Han · Nov 04, 2013 at 07:14 AM 0
Share

Actually, the original code didn't log. I added later on in the futile tries to figure out what's wrong. I just tested again without the log but with no avail.

On the other hand, I did test after decreasing the size of the dimensions to 1 and 4. And its working so number of iteration being the issue is confirmed, but I don't see why it can't do the following 32 x 32 x 32 times:

 public void Set(int x, int y, int z, Block block)
 {
     blockArray[x, y, z] = block;
     Dirty = true;
 }

PS. I'm working with one single game object holding the script.

avatar image Tomer-Barkan · Nov 04, 2013 at 07:24 AM 0
Share

What is Block? Is it efficient?

If you want to test something out without the compiler optimizing, do something like this (note I changed the random to use Random.Range which is the one I'm familiar with, try that too...):

 int aaa = 0;
 for (int i = 0; i < Chunk.Width; i++)
 {
     for (int j = 0; j < Chunk.Height; j++)
     {
        for (int k = 0; k < Chunk.Length; k++)
        {
          if (Random.Range(0, 3) == 1)
          {
              aaa++;
          }
        }
     }
 }
Show more comments

Your answer

Hint: You can notify a user about this post by typing @username

Up to 2 attachments (including images) can be used with a maximum of 524.3 kB each and 1.0 MB total.

Follow this Question

Answers Answers and Comments

17 People are following this question.

avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image

Related Questions

Nested for-loop freezing Unity 0 Answers

Game random freeze / hang up / stuck 0 Answers

while loops infinitely, I can't tell why. 1 Answer

Determining groups in a 2D array by checking neighbours (and their neighbours etc) 2 Answers

Help! Unsaved work stuck in frozen unity, believed to be from infinite loop. What can i do? 2 Answers


Enterprise
Social Q&A

Social
Subscribe on YouTube social-youtube Follow on LinkedIn social-linkedin Follow on Twitter social-twitter Follow on Facebook social-facebook Follow on Instagram social-instagram

Footer

  • Purchase
    • Products
    • Subscription
    • Asset Store
    • Unity Gear
    • Resellers
  • Education
    • Students
    • Educators
    • Certification
    • Learn
    • Center of Excellence
  • Download
    • Unity
    • Beta Program
  • Unity Labs
    • Labs
    • Publications
  • Resources
    • Learn platform
    • Community
    • Documentation
    • Unity QA
    • FAQ
    • Services Status
    • Connect
  • About Unity
    • About Us
    • Blog
    • Events
    • Careers
    • Contact
    • Press
    • Partners
    • Affiliates
    • Security
Copyright © 2020 Unity Technologies
  • Legal
  • Privacy Policy
  • Cookies
  • Do Not Sell My Personal Information
  • Cookies Settings
"Unity", Unity logos, and other Unity trademarks are trademarks or registered trademarks of Unity Technologies or its affiliates in the U.S. and elsewhere (more info here). Other names or brands are trademarks of their respective owners.
  • Anonymous
  • Sign in
  • Create
  • Ask a question
  • Spaces
  • Default
  • Help Room
  • META
  • Moderators
  • Explore
  • Topics
  • Questions
  • Users
  • Badges