Исключение нулевого указателя - это индикатор того, что вы используете объект, не инициализируя его.
Например, ниже - класс ученика, который будет использовать его в нашем коде.
public class Student {
private int id;
public int getId() {
return this.id;
}
public setId(int newId) {
this.id = newId;
}
}
Приведенный ниже код дает вам исключение с нулевым указателем.
public class School {
Student obj_Student;
public School() {
try {
obj_Student.getId();
}
catch(Exception e) {
System.out.println("Null Pointer ");
}
}
}
Поскольку вы используете Obj_Student
, но вы забыли инициализировать его, как в правильном коде, показанном ниже:
public class School {
Student obj_Student;
public School() {
try {
obj_Student = new Student();
obj_Student.setId(12);
obj_Student.getId();
}
catch(Exception e) {
System.out.println("Null Pointer ");
}
}
}
Согласно Вашей кавычке, URL являются ASCII. Это - все.
URIs OTOH, допускайте большие наборы символов; обычно UTF-8, поскольку Вы говорили себя.
точка для запоминания - то, что URL являются подмножеством URIs. Поэтому реальный вопрос, какой из них является тем, что Вы пишете в браузере?
я предположил бы, что можно записать URI, и браузер должен стараться изо всех сил преобразовывать к URL (который является что поддержка HTTP/1.1, AFAICR). Для символов неASCII, который означает hexcodes, обычно кодируя UTF-8.
Я верю спецификации, которую Вы ищете, RFC 3987 , который описывает IRIs - Интернационализировавшие Идентификаторы ресурсов.