JavaRush /جاوا بلاگ /Random-SD /6 جاوا استثنون جيڪي نئين سکندڙن کي متاثر ڪن ٿا
gram2005
سطح

6 جاوا استثنون جيڪي نئين سکندڙن کي متاثر ڪن ٿا

گروپ ۾ شايع ٿيل
وقت بوقت مون کي نوان ڊولپرز ملن ٿا جيڪي هيٺ ڏنل سادي استثنائن کي سمجهڻ تي بيٺا آهن ۽ مون کي انهن سڀني کي ٻيهر بيان ڪرڻو پوندو. گهڻو ڪري، ڪيترائي تجربا جاوا ڊولپر پاڻ کي ساڳي صورتحال ۾ ڳوليندا آهن ۽ نون نون کي هيٺين استثنا سان منهن ڏيڻ ۾ مدد ڪن ٿا. تنهن ڪري، مون فيصلو ڪيو ته هي مضمون لکڻ ۽ مستقبل ۾ ان جو حوالو ڏيو. تبصرا ۽ اخراج جي فهرست ۾ اضافو ڀلي ڪري آيا. 6 جاوا جا استثنا جيڪي نوانين کي متاثر ڪن ٿا - 1
  1. NoClassDefFoundError: هي انهن استثنان مان هڪ آهي جيڪو Exception in thread “main“ NoClassDefFoundErrorاڪثر ڪري نئين ڊولپرز کي جاوا پروگرامنگ جي دنيا ۾ ڀليڪار ڪري ٿو. هي هيلو ورلڊ پروگرام لکندا آهن، ڪمانڊ لائن ڏانهن ويندا آهن ۽ لکندا آهن “ java ” - ڪم ڪرڻ جو حڪم ۽ “BAM” :-) ٿوري دير کان پوءِ، شروعات ڪندڙ سمجهندا ته هن استثنا کي ڪيئن حل ڪجي ۽ ڏسندا ته سندن هيلو ورلڊ ڪيئن ڇپجي.

    NoClassDefFoundErrorتڏهن ٿئي ٿو جڏهن جاوا ورچوئل مشين (JVM) رن ٽائم تي ڪلاس تائين رسائي حاصل ڪرڻ جي ڪوشش ڪري ٿي ۽ ڪلاس نه ملي ٿو جيتوڻيڪ اهو ساڳيو ڪلاس ڪمپائل ٽائيم تي موجود هو. گهڻو ڪري، هي استثنا تڏهن ٿئي ٿو جڏهن جاوا پروگرام هلائي رهيو آهي "java" ڪمانڊ ذريعي غلط پيٽرولر ويل سان classpath. [ Classpathپيراميٽر آهي جيڪو ڪمانڊ لائن ذريعي يا ماحول جي متغير ذريعي مقرر ڪيو ويو آهي، جاوا ورچوئل مشين يا جاوا ڪمپلر ڏانهن اشارو ڪري ٿو جتي صارف پاران اعلان ڪيل ڪلاس يا پيڪيجز کي ڳولڻ لاءِ - تقريبن. مترجم] خارج ڪرڻ جا ممڪن سبب:

    • ڪلاس ۾ دستياب ناهي Classpath.
    • گهڻو ڪري اسڪرپٽ جيڪو عمل ڪيو ويندو آهي جڏهن آپريٽنگ سسٽم شروع ٿئي ٿو ماحول جي متغير جي قدر کي تبديل ڪري ٿو classpath. توھان ھن کي چيڪ ڪري سگھو ٿا "" ڪمانڊ ونڊوز ڪمانڊ لائن تي ھلائي set۽ ڏسو ته ڇا ڪلاس جي تعريف ويل ۾ شامل آھي classpath. جيڪڏھن توھان چاھيو، توھان ھن استثنا کي وڌيڪ ڳولي سگھوٿا Javarevisited بلاگ تي .
  2. ClassNotFoundException: Исключение ClassNotFoundException это еще одно исключение, из-за которого новичкам, только начинающим программировать на Java, снятся кошмары. Интересно что для среднего разработчика нужно некоторое время чтобы перестать путать ClassNotFoundException и NoClassDefFoundError между собой. И поэтому вопрос о разнице этих двух исключений остается одним из часто задаваемых на собеседовании на позицию junior Java разработчика.
    ClassNotFoundException случается когда JVM пытается загрузить определенный класс и не обнаруживает такого же в classpath. Обычно новички сталкиваются с этим в codeе, который подключается к базе данных используя JDBC библиотеку. Пытаясь загрузить драйвер с помощью следующего codeа Class.forName( “JDBCdriver”). Хороший материал по ClassNotFoundException можно найти здесь. Так же рекомендуется ознакомиться и понять концепцию загрузчиков классов в Java чтобы эффективно справляться с этим исключением. Вы возможно захотите посмотреть следующую page о том How настроить classpath в окружениях Win/Unix. А так, How следует из documentации Java, это исключение случается в следующих случаях:

    1. Когда пытаются загрузить класс используя метод Class.forName и файл .class не существует в classpath. Это самый частый случай из всех трех.
    2. Когда загрузчик класса пытается загрузить класс используя метод loadClass.
    3. Когда загрузчик класса пытается загрузить класс используя findSystemClass.
  3. NullPointerException: исключение NullPointerExceptionпонять легче и новички с ним справляются быстрее нежели с двумя предыдущими. В тоже время причину исключения очень легко найти так How приводится номер строки где оно случилось. В первую очередь исключение случается когда JVM пытается обратиться к null в том месте где должен был быть an object. Чаще всего это случается когда JVM пытается вызвать метод используя an object и оказывается что an object equals null. Другие случаи, How упоминается в documentации Java, могут быть следующими:

    1. Получая доступ к or изменяя метод an object, который equals null.
    2. Получая длину массива когда он equals null.
    3. Получая доступ к or меняя an objectы, которые являются заключенными в массив, который equals null.
    Самый простой способ избежать этого исключения это добавить проверку на неequalsство null (далее – проверка на null – прим. переводчика). Поэтому рано or поздно разработчик начинает это использовать и тогда проверки на null появляются везде. Интересно что использовать везде проверку на null не считается примером хорошего программирования. Основная причина почему проверка на null используется разработчиками это передавать an object null в случаи ошибки. В место этого пример хорошего программирования, который должен пропагандироваться программистами, это передавать пустой an object когда condition для главной/рабочей ветви программы не удовлетворяется. Это в свою очередь уменьшило бы количество проверок на null. Все-таки легче говорить нежели применять это на практике.:)

  4. ClassCastException: это еще одно из исключений, с которым знакомятся новички когда пытаются привести an object к классу, экземпляром которого он не является. Опять же его довольно легко понять, найти причину и исправить. Один из способов избежать этого исключения, когда во время исполнения тип an object не известен, это использовать проверку является ли an object экземпляром определенного класса: “instanceof”.

  5. ArrayIndexOutOfBoundsException: название этого исключения говорит само за себя. Оно случается когда JVM пытается получить доступ к элементу массива используя неверный индекс, на пример, отрицательный (-1) or больший or равный размеру массива. Его легко понять, найти причину и исправить. Следующий пример codeа поможет избежать этого исключения: for( index = 0; index < array.length; index++ )
    Обратите внимание что индекс начинается с 0 и возрастает до величины на 1 меньше размера массива.

  6. IllegalArgumentException: Это исключение самое простое, его легко понять, найти его причину и исправить. Оно случается когда JVM пытается передать методу неподходящий аргумент or аргумент неправильного типа.

تبصرا
TO VIEW ALL COMMENTS OR TO MAKE A COMMENT,
GO TO FULL VERSION