The introduction
I wanted to write this article for a long time. This article will not cover any knowledge of performance optimization, but simply discuss what performance optimization is and why terminal performance is so powerful now.
Is there any need to optimize the performance of powerful terminal hardware, such as 10 – or 20-core cpus, fast memory, and SOLID-state drive storage? I often often hear a lot of front-end programmers say, write code, let the device to run, change card that is not the device? Or who cares about performance optimization these days, when tens of milliseconds are so obvious?
Today we objectively discuss these problems, in the end there is no need.
What is performance
In simple terms, performance can be understood as a multi-dimensional reference index.
The first one is CPU performance. When we break down the dimensions, the typical CPU takes into account our clock cycle, number of cores, number of threads, level 3 cache capacity, and scheduling efficiency.
Then there is memory, the index of memory is nothing more than the bandwidth and throughput of transmitting data per unit time. In fact, there are many indicators of memory reference, which will not be introduced for the sake of space.
GPU, generally is the graphics card, also can call coprocessor, mainly carry on some simple calculation, auxiliary CPU with some graphics rendering, the biggest advantage is can concurrent processing data, and CPU linear approach is very different, can be more efficient processing graphics information, so as to improve the effect of the frame rate and display.
For users, in terms of interaction, the most intuitive performance is whether there is obvious frame lag or operation delay. If the lag is particularly noticeable, or if the first screen loads for more than three seconds, it can result in a 90% loss of users, which can be fatal.
Does the high performance terminal still need to be optimized?
Ok, to begin today’s topic, let’s take an example of this problem:
Suppose we have a 128KB memory and need to read all the data in memory. Let’s assume that the CPU needs 0.1ms for each 1KB of memory.
const Memory = new Array(128);
for(let i = 0; i < Memory.length; i++) {
/** requires 12.8ms **/
}
Copy the code
This linear loop operation is the most common for us, and it takes 12.8ms, which in big O notation can be denoted as O(n), so far it doesn’t seem to be a big problem. So let’s write it another way:
const Memory = new Array(128);
for(let i = 0; i < Memory.length; i++) {
for(let j = 0; j < Memory.length; j++) {
/** requires 1638.4ms **/}}Copy the code
The result of this double loop (bubble sort, for example) may be a bit obvious. The big O notation O(n ^ 2) is 128 times larger, reaching 1638.4ms. In fact, on a 60Hz screen, each frame takes only 16.7ms. It’s already stuck (not for that long, just assuming). What about the three-tier cycle? It will reach O(n ^ 3), and the time will reach 209715.2ms;
The result can be imagined, if our computer memory 8GB, in this way to process, without some optimization, it is unimaginable, even if not processing 1KB time is 0.01ms efficiency, there will be no significant change, right? Because CPU development so far, the performance has always been linear growth, but we have a bad code, the performance problems will be exponential growth, far more than our current hardware technology development;
conclusion
Actually today want to say question very short answer, performance optimization in any time is necessary, such as front end the present new out some of the API, alive any open source framework and application of the iteration, is not forget constantly optimize the performance, optimize performance actually is also a promotion of their technology, hope both front-end and back-end friend, I want to be aware that writing a bad piece of code can take only an hour, and writing a good piece of code can take 10 times 20 times as long to polish.