Typeof против голого, если в производительности JavaScript

У меня есть два выражения, и я хотел бы знать, какое из них лучше с точки зрения производительности.

1 if (typeof a !== "undefined") {}

2 if (a) {}

(Я не уверен, как называется второе выражение, поэтому я называю его голый, если в заголовке вопроса, не стесняйтесь поправлять меня, если вы знаете правильный термин для этого)

Я понимаю, что два выражения приведут к тому, что true будет находиться в совершенно разных условиях. Меня это не интересует, меня интересует только производительность.

Также я понимаю, что разница в производительности может кому-то показаться незначительной. Но все равно мне это интересно.

С моей точки зрения они оба хорошо читаются. Для моего случая они оба применимы. Теперь мне нужно дать оценку производительности одному из двух вариантов. Точка решит, какой подход я буду всегда использовать в будущем, если оба они подходят.

Спасибо.

Существенной разницы в производительности нет, но есть большая разница в семантике; другими словами, они делают существенно разные вещи. Для вашего приложения это может иметь значение, а может и не иметь.

Pointy 14.03.2019 17:37

@ Пойнти, спасибо. Я обновил свой вопрос.

manymanymore 14.03.2019 17:39

Как часто это происходит, если его казнят? Один раз, 10 раз, 1 миллион раз? Даже если один из них в десять раз медленнее другого, имеет ли это значение?

Jonas Wilms 14.03.2019 17:39

И вы не можете (особенно в JS) утверждать производительность одного оператора без его окружения

Jonas Wilms 14.03.2019 17:40

@JonasWilms, вы имеете в виду, что производительность двух опций зависит от кода, который был выполнен до и который будет выполняться после? Спасибо.

manymanymore 14.03.2019 17:44

@ Бармар, я уверен, что мое желание, чтобы мой выбор из двух вариантов был объяснен и оказался хорошим выбором, не является корнем зла. Спасибо.

manymanymore 14.03.2019 17:48

@Barmar, самое главное здесь не оптимизировать. Мое намерение состоит в том, чтобы принять правильное решение, и я хочу сделать это с помощью оптимизации. Так что тут оптимизация не результат, а инструмент. Спасибо.

manymanymore 14.03.2019 17:49

Это неправильная идея. Пишите код максимально понятным образом, не слишком беспокойтесь о производительности. Если вы обнаружите, что ваше решение работает слишком медленно, вы оптимизируете его. Разница в этом случае будет незначительна в 99% приложений.

Barmar 14.03.2019 17:52

@ Бармар, как я уже упоминал в своем вопросе From my pov they both are readable well.. Спасибо.

manymanymore 15.03.2019 09:01

Затем вам следует подумать о том, какой из них лучше всего представляет логику, на благо других читателей.

Barmar 15.03.2019 15:03

@ Бармар, это хороший момент. Спасибо. Но мне все равно интересно узнать ответ на свой вопрос.

manymanymore 15.03.2019 16:13

Используйте № 2, он менее подробный.

Barmar 15.03.2019 22:34
Поведение ключевого слова "this" в стрелочной функции в сравнении с нормальной функцией
Поведение ключевого слова "this" в стрелочной функции в сравнении с нормальной функцией
В JavaScript одним из самых запутанных понятий является поведение ключевого слова "this" в стрелочной и обычной функциях.
Концепция локализации и ее применение в приложениях React ⚡️
Концепция локализации и ее применение в приложениях React ⚡️
Локализация - это процесс адаптации приложения к различным языкам и культурным требованиям. Это позволяет пользователям получить опыт, соответствующий...
Улучшение производительности загрузки с помощью Google Tag Manager и атрибута Defer
Улучшение производительности загрузки с помощью Google Tag Manager и атрибута Defer
В настоящее время производительность загрузки веб-сайта имеет решающее значение не только для удобства пользователей, но и для ранжирования в...
Безумие обратных вызовов в javascript [JS]
Безумие обратных вызовов в javascript [JS]
Здравствуйте! Юный падаван 🚀. Присоединяйся ко мне, чтобы разобраться в одной из самых запутанных концепций, когда вы начинаете изучать мир...
Система управления парковками с использованием HTML, CSS и JavaScript
Система управления парковками с использованием HTML, CSS и JavaScript
Веб-сайт по управлению парковками был создан с использованием HTML, CSS и JavaScript. Это простой сайт, ничего вычурного. Основная цель -...
JavaScript Вопросы с множественным выбором и ответы
JavaScript Вопросы с множественным выбором и ответы
Если вы ищете платформу, которая предоставляет вам бесплатный тест JavaScript MCQ (Multiple Choice Questions With Answers) для оценки ваших знаний,...
0
13
31
0

Другие вопросы по теме