Как Windows определя колко време е необходимо да извърши действие с файл?

Съдържание:

Как Windows определя колко време е необходимо да извърши действие с файл?
Как Windows определя колко време е необходимо да извърши действие с файл?
Anonim
Определенията за "оставащо време" на Windows са достатъчни, за да карат някого понякога да е луд, но някога сте се чудили как Windows определя тези времена? Днешната публикация "SuperUser Q &A" има някои отговори за любопитен, но разочарован въпрос на читателя.
Определенията за "оставащо време" на Windows са достатъчни, за да карат някого понякога да е луд, но някога сте се чудили как Windows определя тези времена? Днешната публикация "SuperUser Q &A" има някои отговори за любопитен, но разочарован въпрос на читателя.

Днешната сесия за въпроси и отговори ни идва с любезното съдействие на SuperUser - подразделение на Stack Exchange - обединяване на уеб сайтове с въпроси и отговори.

Windows 8.1 снимки трансфер на екрана снимка любезното съдействие на IM наистина famecore.

Въпроса

Четецът на SuperUser "im really famecore" иска да знае как Windows определя колко време ще отнеме, за да извърши операция с файл:

I wanted to know if there is an equation that Windows uses to determine how long it takes to perform an action with a file such as: deleting, copying, erasing, or installing.

Image
Image

For example, when I delete a file and Windows says Time remaining: 18 seconds, how is it calculating this number, and what does it use to calculate it?

Дали Windows използва специално уравнение, за да определи оставащото време за извършване на операция, или просто предвижда "най-добро предположение"?

Отговорът

Служителите на SuperUser Valmiky Arquissandas и Richard имат отговора за нас. Първо, Валмики Арквисандас:

Have you noticed that it usually does not give you any estimates during the first few seconds?

That is because during the first few seconds, it just does the operation it has to do. Then, after a short amount of time, it knows how much it has already copied/deleted/etc, and how long it took. That gives you the average speed of the operation.

Then, divide the remaining bytes by the speed, and you have the time it will take to complete the operation.

This is elementary school math. If you want to travel 360 km, and at the end of the first minute you have traveled 1 km, how long will it take you to reach your destination?

Well, the speed is 1 km/minute, so that is 60 km/hour. 360 km divided by 60 km/hour gives you an estimated time of 6 hours (or 360 km / 1 km/minute = 360 minutes = 6 hours). Since you have already traveled for one minute, then the estimated time left is 5 hours and 59 minutes.

Substitute travel with copy, km with bytes, and that answers your question.

Different systems have different ways of estimating time. You can take the last minute and the estimates may vary wildly. Or you can take the full time, and if the speed actually changes permanently, your estimates may be far removed from reality. What I described is the simplest method.

Следвайки отговора на Ричард:

If you are interested, this question tells you how Windows and OSX formats the time left into the progress bar once it has an idea how long it has remaining.

When shortening time expressions in progress dialogs, should they be rounded up or down?

Raymond Chen, a developer on the Windows team at Microsoft, confirms this algorithm (see Valmiky’s answer above) in a posting on his blog. He also explains why it can be wrong.

Why does the copy dialog give such horrible estimates?

Имате ли нещо, което да добавите към обяснението? Звучи в коментарите. Искате ли да прочетете повече отговори от други потребители на Stack Exchange? Вижте цялата тема на дискусията тук.

Препоръчано: