NullPointerException
s - исключения, возникающие при попытке использовать ссылку, которая указывает на отсутствие местоположения в памяти (null), как если бы она ссылалась на объект. Вызов метода по нулевой ссылке или попытка получить доступ к полю нулевой ссылки вызовет функцию NullPointerException
. Они наиболее распространены, но другие способы перечислены на странице NullPointerException
javadoc.
Вероятно, самый быстрый пример кода, который я мог бы придумать для иллюстрации NullPointerException
, be:
public class Example {
public static void main(String[] args) {
Object obj = null;
obj.hashCode();
}
}
В первой строке внутри main
я явно устанавливаю ссылку Object
obj
равной null
. Это означает, что у меня есть ссылка, но она не указывает на какой-либо объект. После этого я пытаюсь обработать ссылку так, как если бы она указывала на объект, вызывая метод на нем. Это приводит к NullPointerException
, потому что нет кода для выполнения в местоположении, на которое указывает ссылка.
(Это техничность, но я думаю, что она упоминает: ссылка, которая указывает на null, равна 't то же, что и указатель C, указывающий на недопустимую ячейку памяти. Нулевой указатель буквально не указывает на в любом месте , который отличается от указаний на местоположение, которое оказывается недопустимым.)
Для отключения предупреждений на основе на файл с помощью Xcode 3 и llvm-gcc-4.2, можно использовать:
#pragma GCC diagnostic ignored "-Wwarning-flag"
, Где предупреждение имени является некоторым gcc предупреждение флага.
Это переопределяет любые флаги предупреждения на командной строке. Это не работает со всеми предупреждениями все же. Добавьте-fdiagnostics-show-option к своему CFLAGS, и Вы видите, какой флаг можно использовать для отключения того предупреждения.
С Objective C много серьезных ошибок только появляются как предупреждения. Не только делают я никогда не отключаю предупреждения, я обычно включаю "Предупреждения обработки как ошибки" (-Werror).
Каждого типа предупреждения в Вашем коде можно избежать путем выполнения вещей правильно (обычно путем кастинга объектов к корректному типу) или путем объявления прототипов при необходимости в них.
Подавление, что конкретное предупреждение не безопасно. Компилятор должен знать, что типы аргументов и возвратов к методу генерируют корректный код.
, Например, если Вы называете метод как это
[нечто doSomethingWithFloat:1.0];
, который берет плавание, и нет никакого видимого прототипа, тогда компилятор предположит, что метод берет двойное, не плавание. Это может вызвать катастрофические отказы и неправильно интерпретируемые значения. В примере выше, на небольшой машине порядка байтов как машины Intel, метод получателя видел бы 0, передал, не 1.
можно читать, почему в эти документы i386 ABI , или можно просто зафиксировать предупреждения.:-)
Чтобы избавиться от предупреждения: попробуйте создать интерфейс категории для рассматриваемого объекта
@interface NSTheClass (MyUndocumentedMethodsForNSTheClass)
-(id)theUndocumentedMethod;
@end
...
@implementation myClass : mySuperclass
-(void) myMethod {
...
[theObject theUndocumentedMethod];
...
}
Кроме того, я настоятельно не рекомендую вызывать недокументированные методы в коде доставки. . Интерфейс может и будет меняться, и это будет ваша вина.
Создайте новый отдельный файл заголовка с именем «Undocumented.h» и добавьте его в свой проект. Затем создайте один блок интерфейса для каждого класса, для которого вы хотите вызвать недокументированные функции, и присвойте каждому категорию «(Недокументированный)». Затем просто включите этот файл заголовка в свой PCH. Таким образом, ваши исходные файлы заголовков остаются чистыми, остается только один файл, который нужно поддерживать, и вы можете закомментировать одну строку в своем PCH, чтобы снова включить все предупреждения.
Я также использую этот метод для устаревших функций в 'Depreciated.h' с категорией '(Depreciated)'.
Самое приятное то, что вы можете выборочно включать / отключать отдельные предупреждения, комментируя или раскомментируя отдельные прототипы.