Мини-тест ("опечатка" + стилистика кода + "известный механизм" языка)
Опять небольшой тест на знание (механизмов) языка. Понравился пример из одной темы в news-группе.
Допустим, есть такая проверка (пример абстрактный): if (!x) { x = 1; } Какого типа ошибка будет при следующей опечатке в ключевом слове? iff (!x) { x = 1; } Важно ответить самому без запуска кода, проверок; пояснить, почему именно так. |
Переменная iff не инициализованна. А происходит так, потому что iff (/*smthng*/) трактуется JS'ом как вызов ф-ии.
/* Все честно: сначала написал, потом проверил. */ |
B@rmaley.e><e, угу, спасибо. Ответ ясен, подождём ещё.
Также, интересуют причины (приведённое Вами - это следствие) и методика недопущения ошибок подобного рода. |
Цитата:
Цитата:
|
Kolyaj, угу, спасибо, ещё подождём. Ответы пока неполные.
Цитата:
P.S.: всем: пишите, не стесняйтесь. Не бойтесь ошибиться в предположениях, так можно наиболее точно понять, что и почему происходит. |
Цитата:
|
Цитата:
Цитата:
|
Цитата:
Цитата:
|
Цитата:
Можно ли недопустить ошибку подобного плана без редактора с подстветкой? Будет ли вообще ошибка? Если да, при каких условиях? |
iff (!x) /* заканчивается \r\n — запускаем функцию iff — ошибка, если такой нет */ { /* начинаем объявление объекта */ x = 1; /* ошибка синтаксиса, что-то типа «недопустимое имя свойства»? */ } Как-то так? |
Цитата:
Это самый главный момент - это именно RuntimeError, не ParseError (SyntaxError). Соответственно, если ещё и функция iff существует, то в этом месте ошибки вообще не будет (а вот такие ошибки уже являются ошибками логики программы - программа полностью рабочая и нерабочая одновременно). Причина и следствие ясны. Возможно ли как-то избавиться от RuntimeError (именно это я имел в виду, когда спрашивал про избавление от подобного типа ошибки), но не допустить ошибки в логике программы? Т.е. можно, конечно, объявить функцию iff, и RuntimeError-a не будет, но это ещё больше усугубит дело, т.к. ошибка не будет отловлена. Цитата:
|
Цитата:
|
Цитата:
Меня как раз интересует, можно ли сделать так, чтобы был SyntaxError на стадии парсинга? Чтобы мы отловили ошибку с iff ещё до запуска и не допустили случая логической ошибки, если будет существовать функция iff. В сущности, все подсказки были даны в заголовке темы (две из них уже разобраны). |
ну остается только механизм. это обьявление функции при которой ключевое слово funcion отсутсвует.
|
Цитата:
Также, задействовали "опечатку". Осталась "стилистика кода". Отмечу, что я обычно использую стилистику не ту, что была приведена в примере, хотя в текущем проекте у нас принята именно стилистика из примера. |
пока пришла в голову только использовать обязательно конечный else, таким образом вызывая именно ошибку парсинга
непонятно что делать с другими стандартными структырами типа циклов do,do-while, и условий |
Если не будет точки с запятой внутри фигурных скобок -
Цитата:
iff (!x) { x = 1; } |
Цитата:
хотя не факт ибо, такой подход все еще не решает проблему do-while x=false; doq=123; i=0; doq { alert(i);//в опере данный код показывает один alert, после чего процессор начинает показывать 100% нагруженность, без каких-либо изменений на странице скрипта //мозилла показывает ошибку missing ; before statement "doq {\n" i++; if(i==3) x = true; }while(!x); alert('end'); |
Цитата:
|
Цитата:
то есть в зависимости от контекста, фигурные скобочки будут использоваться так или иначе <script type="text/javascript"> var qwe={alert(1)};//missing : after property id, ибо объект </script> <script type="text/javascript"> {alert(1)};//выведет alert, ибо это блок кода </script> Цитата:
Цитата:
|
Dmitry A. Soshnikov, ну ты мозг, конечно...
Цитата:
Цитата:
|
Цитата:
|
Цитата:
Только насчёт "как принято" тут утверждать категорично нельзя, поскольку официального style-guide (который я бы хотел видеть даже от ECMA, либо от B.Eich-a) - нет. Более-менее "полуофициальным" можно считать style-guide от Mozilla - https://developer.mozilla.org/en/JavaScript_style_guide (поскольку создатель JS хоть как-то связан с Mozilla, а именно - работает там ;)); данная стилистика похожа на стиль Java. К примеру у Python-a заведён специальный документ на эту тему, на официальном сайте. По поводу приоритетов, я уже писал: http://javascript.ru/forum/offtopic/...html#post33740 (1) - локальный в компании, (2) - официальный технологии, (3) - локальная привычка. В идеале, (1) должно быть === (2). В профессиональном коде на международном уровне, (3) вообще не должно рассматриваться. Цитата:
Цитата:
var dof = 10; dof { } while(false); Вот этот код должен завершится так: var dof = 10; dof; // разрешение идентификатора { // пустой блок }; while(false); // пустой while Но не этот: var dof = 10; dof { } while(false); Так что, Опера, не права, получается. Цитата:
Вообще, существенным является именно наличие определённой единой стилистики кода в команде - это на данный момент имеется. Впрочем, если бы речь шла о выборе стилистики в самом начале проекта, я бы отдал предпочтение стилистике Mozilla. Хотя, стилистика текущего проекта также хорошо структурирована и оформлена (для меня вопрос "Где ставить скобку - в той же строке или с новой?" - давно уже перешёл в разряд несущественных, я могу подстраиваться под стилистику, главное, чтобы она была единой, логически структурированной и обоснованной). Хотя, если "завтра" B.Eich или ECMA выпустят официальный style guide, в этом вопросе будет поставлена окончательная точка - и тогда да, возможно предложить смену стилистики, поскольку код на международном уровне должен быть оформлен по официальному стилю технологии (хотя, локальная стилистика компании всё ещё будет иметь приоритет выше; в своих локальных проектах - должна быть только официальная стилистика, не касаемо каких-то своих локальных привычек). Kolyaj, возвращаясь по твоим вопросам (ответам), Цитата:
CallExpression : MemberExpression Arguments Arguments: ( ) ( ArgumentList ) Т.е. MemberExpression со скобками вызова - это выражение вызова (функции). А MemberExpression, в частности, распадается на Idenfier. Т.е. с ключевым словом бы это прокатило, а вот с идентификатором - уже нет, это по-любому трактуется, как вызов функции. Ну и, плюс, механизм автоматической вставки точки с запятой делает своё дело. Цитата:
Цитата:
return // undefined { x: 10 }; return { x: 10 }; // object Цитата:
iff (!x) { // SyntaxError x = 1; } subzey, Цитата:
Ниже - синтаксически правильная ECMAScript-программа, состоящая из блока и пустой инструкции: { ; } P.S.: ещё (классические) примеры: a = b + c ({x: 10}).x Здесь наоборот, точка с запятой не будет поставлена в конце первой строки, поскольку "c(... )" - это вызов функции с аргументом "{x: 10}". Или: var foo = function () { alert(arguments[0]); } (function () {return 'x';}()) Так же, точка с запятой не ставится; это вызов первой анонимной функции, в которую параметром передаётся результат вызова второй анонимной функции. var foo = function () { alert(arguments[0]); }; (function () {return 'x';})(); А так - верно: описание первой анонимной функции (которая сохраняется в foo); далее описание и вызов второй анонимной функции. |
Вобщем, у меня вывод такой:
выбирать стиль кодирования (для себя, команды, стандарта) необходимо в первую очередь исходя из: Цитата:
Это поможет избежать ошибок в логике программы и понимания кода другими людьми. Как показывает предыдущий пост, таких ситуаций может быть немало. Цитата:
PS: спасибо за примеры, отличный мануал;) |
Часовой пояс GMT +3, время: 16:58. |