Why is adding SuspendLayout and ResumeLayout reducing performance?

做~自己de王妃 提交于 2019-12-09 09:21:49

问题


I need to add a lot of controls to a parent control.

But I find if I add ParentControl.SuspendLayout and ParentControl.ResumeLayout before and after I add those controls to the parent, I use stopwatch to measure the ticks: If I remove the code ParentControl.SuspendLayout and ParentControl.ResumeLayout, it will be faster. Why does it happen?

So SuspendLayout and ResumeLayout are not supposed to reduce the time to add sub controls, right? So what's the benefit to use SuspendLayout and ResumeLayout or in other words, if I don't use SuspendLayout and ResumeLayout but add the sub controls directly to parents, what's the bad?


回答1:


This is for the usual reason, removing code usually makes your program run faster.

Suspend/ResumeLayout() is pretty universally misunderstood. It will only have an affect when you have controls that have a non-default AutoSize, Dock or Anchor property. It prevents layout accidents when controls have layout properties that affect each other.

If you have a form with hundreds of controls then it is very unlikely that you use these properties at all. Such a massive window does not easily lend itself to automatic layout. So you are calling methods that don't actually do anything, they take time to iterate the layout but for no benefit.




回答2:


You probably want to use .ResumeLayout(false) instead. Calling mySubPanel.ResumeLayout() equals to .ResumeLayout(true), which means it should re-layout this control (and everything child-control that is not suspended at that point) immediately.

MSDN quote: "Calling the ResumeLayout method [without parameters] forces an immediate layout if there are any pending layout requests." [1]

If you are like adding 100 controls to a panel, you want to use an approach like this:

  1. mainPanel.SuspendLayout()
  2. create child control
  3. call child.SuspendLayout()
  4. change the child control properties
  5. add the child control to the mainPanel
  6. call child.ResumeLayout(false) - this means: next layout run, relayout this control, but not immediately
  7. repeat (2-6) for every child-control
  8. call mainPanel.ResumeLayout(true) - this means: relayout my mainPanel and every child-control now!

Note: without SuspendLayout(), every property change for a control would invoke the layout-routine -- even changing the .BackColor makes your control re-layout itself.

[1] http://msdn.microsoft.com/en-us/library/y53zat12.aspx



来源:https://stackoverflow.com/questions/13122994/why-is-adding-suspendlayout-and-resumelayout-reducing-performance

易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!