官术网_书友最值得收藏!

Responsive user interfaces

A user's first contact with any program is always the user interface. A good UI can make or break a program. Leaving the user interface design aside (as I am not qualified to speak about that), I will focus on just one fact.

Users hate user interfaces that are not responsive.

In other words, every good user interface must react quickly to a user's input, be that a keyboard, mouse, touchpad, or anything else.

What are the tasks that can make a user interface unresponsive? Basically, they all fall into one of two categories:

  1. A program is running a slow piece of code. While it is running, the UI is not responding.
  2. Updating the user interface itself takes a long time.

The problems from the first category fall into two subsets—functions that have non-blocking (asynchronous) alternative and functions that don't.

Sometimes we can replace the slow function with another one that runs asynchronously. For example, instead of using a standard function for reading from a file, we can use the Windows Asynchronous File I/O API. File reading will then occur in parallel with our program and we will be notified of successful or unsuccessful reads via some other mechanism. 

Often, however, this is not possible (there is no alternative for the slow function) or the asynchronous version is too complicated to implement. In that case, we can execute the slow code in a thread. This will be covered in chapters 5 to 7. 

An excellent candidate for the multithreaded approach is the file reading example. True, Windows offers an asynchronous API for that, but it is quite complicated and tricky to implement correctly. Pushing a read operation into a thread is simpler and cross-platform compatible, if that is important for your application.

The second category (updating the UI takes a long time) is typically solved with a simple solution: Do less updating! Delphi/Windows controls are typically very fast and they only fail when we want them to do too many operations in a short time. 

We will now focus on that category. I'll show a few examples of overabundant updates and give solutions for faster code.

主站蜘蛛池模板: 福建省| 鸡西市| 全州县| 阿勒泰市| 塔河县| 镶黄旗| 斗六市| 天门市| 丹东市| 定日县| 惠州市| 兴安县| 屯门区| 廉江市| 普兰店市| 屏东县| 宿松县| 黄龙县| 平乐县| 屯门区| 扬中市| 谢通门县| 遂昌县| 永川市| 丰台区| 乐安县| 包头市| 延津县| 诸城市| 南宁市| 博野县| 大石桥市| 沁阳市| 攀枝花市| 格尔木市| 昭苏县| 苗栗县| 高碑店市| 奈曼旗| 贵南县| 日喀则市|