script.js 2.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263
  1. function makeProfileTimer() {
  2. let time1 = performance.now()
  3. let timeInner = () => {
  4. let time2 = performance.now()
  5. return time2 - time1
  6. }
  7. return timeInner;
  8. }
  9. // var timer = makeProfileTimer()
  10. // alert('Замеряем время работы этого alert'); //некий код, время выполнения которого мы хотим измерить с высокой точностью
  11. // alert(timer()); //alert должен вывести время в микросекундах от выполнения makeProfileTimer до момента вызова timer(),
  12. // // т. е. измерить время выполнения alert
  13. function makeSaver(funk) {
  14. let savedResult
  15. let saverInner = () => {
  16. if (savedResult == undefined) {
  17. savedResult = funk()
  18. }
  19. return savedResult
  20. }
  21. return saverInner
  22. }
  23. var saver = makeSaver(Math.random) //создает функцию-хранилище результата переданной в качестве параметра функции (Math.random
  24. // в примере). На этом этапе Math.random НЕ вызывается
  25. var value1 = saver() //saver вызывает переданную в makeSaver функцию, запоминает результат и возвращает его
  26. var value2 = saver() //saver в дальнейшем просто хранит результат функции, и более НЕ вызывает переданную
  27. //в makeSaver функцию;
  28. value1 === value2 // всегда true
  29. var saver2 = makeSaver(() => console.log('saved function called') || [null, undefined, false, '', 0, Math.random()][Math.ceil(Math.random()*6)])
  30. var value3 = saver2()
  31. var value4 = saver2()
  32. value3 === value4 // тоже должно быть true
  33. function starter (number) {
  34. console.log(number)
  35. number = number - 1
  36. starterInner()
  37. function starterInner() {
  38. setTimeout(() => {
  39. if(number > 0){
  40. console.log(number)
  41. number = number-1
  42. return starterInner(number)
  43. } else {
  44. return console.log("done")
  45. }
  46. }, 1000)
  47. }
  48. }
  49. // starter(5)