質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.48%
Java

Javaは、1995年にサン・マイクロシステムズが開発したプログラミング言語です。表記法はC言語に似ていますが、既存のプログラミング言語の短所を踏まえていちから設計されており、最初からオブジェクト指向性を備えてデザインされています。セキュリティ面が強力であることや、ネットワーク環境での利用に向いていることが特徴です。Javaで作られたソフトウェアは基本的にいかなるプラットフォームでも作動します。

例外

例外(exception)とは、プログラムの処理実行中に発生する、通常の処理の続行を妨げる特殊な事象のことを呼びます。この「例外」が発生した場合に、現在の処理を中断し、変わりに別の処理を実行させる事を「例外処理」と呼びます。

Eclipse

Eclipseは、IBM社で開発された統合開発環境のひとつです。2001年11月にオープンソース化されました。 たくさんのプラグインがあり自由に機能を追加をすることができるため、開発ツールにおける共通プラットフォームとして位置づけられています。 Eclipse自体は、Javaで実装されています。

Q&A

解決済

1回答

1366閲覧

[Java]例外の表示がずれる

snowshink

総合スコア138

Java

Javaは、1995年にサン・マイクロシステムズが開発したプログラミング言語です。表記法はC言語に似ていますが、既存のプログラミング言語の短所を踏まえていちから設計されており、最初からオブジェクト指向性を備えてデザインされています。セキュリティ面が強力であることや、ネットワーク環境での利用に向いていることが特徴です。Javaで作られたソフトウェアは基本的にいかなるプラットフォームでも作動します。

例外

例外(exception)とは、プログラムの処理実行中に発生する、通常の処理の続行を妨げる特殊な事象のことを呼びます。この「例外」が発生した場合に、現在の処理を中断し、変わりに別の処理を実行させる事を「例外処理」と呼びます。

Eclipse

Eclipseは、IBM社で開発された統合開発環境のひとつです。2001年11月にオープンソース化されました。 たくさんのプラグインがあり自由に機能を追加をすることができるため、開発ツールにおける共通プラットフォームとして位置づけられています。 Eclipse自体は、Javaで実装されています。

1グッド

0クリップ

投稿2020/02/01 11:02

インターフェースの学習でデモを実行してみたのですが、
コードを部分的に抽象的に書くと

java

1for(){ 2 if(){ 3 print() 4 println() 5 }else{ 6 throw Exception 7 } 8}

としていて、if分の判定は、0番目の要素はtrueで1番目の要素はfalseです。
print -> println -> throw の順番で呼び出されると想定していたのですが、
なぜか print -> throw(前部分) -> println -> throw(後部分)のような順番で出力されました。
なぜでしょうか。

java

1for(){ 2 if(){ 3 print() 4 println() 5 print() 6 }else{ 7 throw Exception 8 } 9}

のようにすると期待通りの表示になります。
(上の関数等は状況がわかる程度に省略しています。)

☟実際のコード

プログラムの概要

Interface Soundable{ void sound();} ... 鳴ける生き物につけるインターフェース Class Being ... 生物(抽象)クラス Class Dog extends Being implements Soundable , Class Beatle extends Being...実装クラス Class Main ... 実行クラス

Java

1package main; 2 3import java.util.ArrayList; 4import java.util.List; 5 6import Objects.Beatle; 7import Objects.Being; 8import Objects.Dog; 9import interfaces.Soundable; 10 11public class Main { 12 13 public static void main(String[] args) throws Exception { 14 // TODO Auto-generated method stub 15 List<Being> beings = new ArrayList<Being>(); 16 beings.addAll(List.of(new Dog("Vertex"), new Beatle("Alex"))); 17 18 for (Being being : beings) { 19 if(being instanceof Soundable) { 20 System.out.print(being.getName() + " "); 21 ((Soundable) being).Sound(); 22 23 //これをいれると直る(しっかり改行される) 24 //System.out.print(""); 25 }else { 26 //System.out.println(being.getName() + " cannot make a sound."); 27 throw new Exception(being.getName() + " cannot make a sound."); 28 } 29 } 30 } 31 32} 33

↓標準出力

Vertex Exception in thread "main" Wan Wan java.lang.Exception: Alex cannot make a sound. at main.Main.main(Main.java:24)

java

1package interfaces; 2 3public interface Soundable { 4 public void Sound(); 5}

java

1package Objects; 2 3public abstract class Being { 4 protected String type = "Being"; 5 protected String name = ""; 6 7 public String getType() { 8 return type; 9 } 10 public String getName() { 11 return name; 12 } 13 14}

java

1package Objects; 2 3import interfaces.Soundable; 4 5public class Dog extends Being implements Soundable{ 6 7 8 public Dog(String name){ 9 type = "Dog"; 10 this.name = name; 11 } 12 13 @Override 14 public void Sound() { 15 // TODO Auto-generated method stub 16 System.out.println("Wan Wan"); 17 } 18 19}

java

1package Objects; 2 3import interfaces.Soundable; 4 5public class Dog extends Being implements Soundable{ 6 7 8 public Dog(String name){ 9 type = "Dog"; 10 this.name = name; 11 } 12 13 @Override 14 public void Sound() { 15 // TODO Auto-generated method stub 16 System.out.println("Wan Wan"); 17 } 18 19}
LouiS0616👍を押しています

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答1

0

ベストアンサー

System.out.println()は標準出力(System.out)、スローされた例外は標準エラー(System.err)に出力されているからでしょう。コンソールには、標準出力と標準エラー双方が混ざって出力されているので、乱れているように見えているのでしょう。

java

1try { 2 System.out.println(...); 3} catch(Exception e) { 4 e.printlStackTrace(System.out); 5}

として、スタックトレースも標準出力に吐き出すか、

java

1 System.out.println(...); 2 System.out.flush();

として、標準出力を都度フラッシュすれば想定通りの順序で出力されるはずです。

投稿2020/02/01 14:11

編集2020/02/01 14:14
shiketa

総合スコア3971

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

snowshink

2020/02/02 03:56

そうなんですね。勉強になります。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問