Еще один пример «Variable is out of scope»
Как я уже неоднократно видел подобные вопросы, может быть, еще один пример того, что является незаконным, даже если он может чувствовать в порядке.
Рассмотрим этот код:
if(somethingIsTrue()) {
String message = "Everything is fine";
} else {
String message = "We have an error";
}
System.out.println(message);
Это неверный код. Поскольку ни одна из переменных с именем message
не видна за пределами их соответствующей области действия - в данном случае это будут окружающие скобки {}
.
Вы могли бы сказать: «Но переменная с именем отображается в любом виде, поэтому сообщение указано , определенное после if
».
Но вы ошибаетесь.
У Java нет операторов free()
или delete
, поэтому он должен полагаться на область отслеживания переменных, чтобы узнать, когда переменные больше не используются (вместе со ссылками на эти переменные причины).
Это особенно плохо, если вы считаете, что сделали что-то хорошее. Я видел такую ошибку после «оптимизации» кода следующим образом:
if(somethingIsTrue()) {
String message = "Everything is fine";
System.out.println(message);
} else {
String message = "We have an error";
System.out.println(message);
}
«О, есть дублированный код, давайте вытащить эту общую строку» -> и вот оно.
. Наиболее распространенным способом борьбы с этим видом проблемы является предварительная привязка значений else к именам переменных во внешней области, а затем переназначение, если:
String message = "We have an error";
if(somethingIsTrue()) {
message = "Everything is fine";
}
System.out.println(message);
У вас будет больше удачи, я полагаю, если вы переключите clipPath на использование блоков ограничивающих блоков:
<clipPath clipPathUnits="objectBoundingBox" ... >
Затем все ваши координаты пути клипа должны быть определены в диапазоне 0..1.
http://www.w3.org/TR/SVG/masking.html#EstablishingANewClippingPath
clipPathUnits="objectBoundingBox"
. Я не знал, что вам нужно использовать значения от 0 до 1 (я использовал 0-100), спасибо! – undefined 1 March 2015 в 03:43