Pokechu22
Pokechu22

Reputation: 5046

When might an IOError be thrown?

I have never seen a case when an IOError is thrown. The only thing that the docs say about IOError it this:

Thrown when a serious I/O error has occurred.

There aren't any subclasses or anything else obvious.

Is there ever a case when IOError would be thrown in java? What might cause it?

(This is not to be confused with IOException -- IOException is thrown in a wide range of cases, and is commonly used; I know that. I'm wondering about the less common IOError).

Upvotes: 31

Views: 12781

Answers (8)

hfontanez
hfontanez

Reputation: 6178

I am not sure why so many people state that errors are Runtime Exceptions. They are not. Simply look at the API. Error is a different Throwable category than Exception. RuntimeException is a subtype of Exception.

In simple terms, Error (and its subtypes) are used to indicate serious problems that a reasonable application should not try to catch. On the other hand Exception are used to indicate conditions that a reasonable application MIGHT want to catch. It doesn't say that you MUST. The reason it states MIGHT is because RuntimeException is a subtype of Exception and any condition that result on a runtime exception should be fixed (most likely) during development time so that when the application is deployed, there should not be any need to handle those types of conditions. However, the option is open to continue to use a catch clause for them.

Bottom line: Error IS NOT a RuntimeException. To state this is simply wrong.

Upvotes: -1

Jean-François Savard
Jean-François Savard

Reputation: 21004

Is there ever a case when IOError would be thrown in java?

import java.io.IOError;

public class Test {

    public static void main(String[] args) {
        throw new IOError(new Exception());
    }

}

will result in

Exception in thread "main" java.io.IOError: java.lang.Exception
    at test.Test.main(Test.java:13)
Caused by: java.lang.Exception
    ... 1 more
Java Result: 1

I believe you expect a case which is more likely to happen.

An IOError would be thrown for example when trying to read from a console where the input stream has been closed.

You can try to run this snippet

import java.io.*;

public class Test {

    public static void main(String[] s) {
        Console con = System.console();
        try {
            InputStreamReader reader = new InputStreamReader(System.in);
            reader.close();
            String st = con.readLine("%s", "Enter a line");
        } catch (IOException e) {
            e.printStackTrace();
        } catch (IOError error) {
            error.printStackTrace();
        }
    }
}

That would result in

java.io.IOError: java.io.IOException: Stream Closed
    at java.io.Console.readLine(Console.java:254)
    at Test.main(Test.java:10)
Caused by: java.io.IOException: Stream Closed
    at java.io.FileInputStream.readBytes(Native Method)
    at java.io.FileInputStream.read(FileInputStream.java:246)
    at sun.nio.cs.StreamDecoder.readBytes(StreamDecoder.java:284)
    at sun.nio.cs.StreamDecoder.implRead(StreamDecoder.java:326)
    at sun.nio.cs.StreamDecoder.read(StreamDecoder.java:178)
    at java.io.Console$LineReader.read(Console.java:437)
    at java.io.Console.readline(Console.java:376)
    at java.io.Console.readLine(Console.java:250)
    ... 1 more

Upvotes: 6

RRM
RRM

Reputation: 2679

Here is an explanation from Mark Reinhold from Oracle:

The new IOError class was defined in combination with the new java.io.Console class. It’s for use in situations where an unrecoverable I/O error occurs and the most appropriate response is to terminate the program rather than attempt to handle the exception.

The IOError class, along with many other enhancements, will be documented in the forthcoming Mustang maintenance review in the JCP.

http://cafe.elharo.com/blogroll/undocumented-changes-in-java-6-mustang-ioerror/

Upvotes: 6

Buhake Sindi
Buhake Sindi

Reputation: 89179

Just to add to this, RedHat JBoss Wildfly domain management library explicitly throws IOError for their ConsoleWrapper interface. The only implementation I've seen, so far of the interface is JavaConsole class.

Source:

/*
 * JBoss, Home of Professional Open Source.
 * Copyright 2012, Red Hat, Inc., and individual contributors
 * as indicated by the @author tags. See the copyright.txt file in the
 * distribution for a full listing of individual contributors.
 *
 * This is free software; you can redistribute it and/or modify it
 * under the terms of the GNU Lesser General Public License as
 * published by the Free Software Foundation; either version 2.1 of
 * the License, or (at your option) any later version.
 *
 * This software is distributed in the hope that it will be useful,
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
 * Lesser General Public License for more details.
 *
 * You should have received a copy of the GNU Lesser General Public
 * License along with this software; if not, write to the Free
 * Software Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA
 * 02110-1301 USA, or see the FSF site: http://www.fsf.org.
 */

package org.jboss.as.domain.management.security.adduser;

import java.io.IOError;
import java.util.IllegalFormatException;

/**
 * Wrap the console commands
 *
 * @author <a href="mailto:[email protected]">Flemming Harms</a>
 */
public interface ConsoleWrapper<T> {

    /**
     * Writes a formatted string to this console's output stream using
     * the specified format string and arguments.
     * see <a href="../util/Formatter.html#syntax">Format string syntax</a>
     * @param fmt
     * @param args
     */
    T format(String fmt, Object ...args) throws IllegalFormatException;

    /**
     * A convenience method to write a formatted string to this console's
     * output stream using the specified format string and arguments.
     *
     * @param format
     * @param args
     * @throws IllegalStateException
     */
    void printf(String format, Object ... args) throws IllegalFormatException;

    /**
     * Provides a formatted prompt, then reads a single line of text from the
     * console.
     *
     * @param fmt
     * @param args
     * @return A string containing the line read from the console, not
     *          including any line-termination characters, or <tt>null</tt>
     *          if an end of stream has been reached.
     * @throws IOError
     */
    String readLine(String fmt, Object ... args) throws IOError;

    /**
     * Provides a formatted prompt, then reads a password or passphrase from
     * the console with echoing disabled.
     *
     * @param fmt
     * @param args
     * @return  A character array containing the password or passphrase read
     *          from the console.
     * @throws IOError
     */
    char[] readPassword(String fmt, Object ... args) throws IllegalFormatException, IOError;

    /**
     *  Return the console object
     *
     * @return Return the console object
     */
    T getConsole();
}

Upvotes: 2

Rohitdev
Rohitdev

Reputation: 880

IOError being a runtime exception and being classified under Error category it is an unchecked exception. To me this seems to occur when you interact with the system using JNI/native calls by the JVM to the underlying OS system calls. This might be to gain access to the IO devices( Storage,keyboard,display,network etc.) . But i have hardly seen it being used in the Java API docs.Most probably the reason being that the implementers wanted to keep the dependency on the underlying system to the minimal.

Upvotes: 3

M A
M A

Reputation: 72874

One official source to look for is the Java Bug Database where you can search for bugs involving IOError by using the search keyword. This can show some real cases involving this error.

One occurrence that directly references this error (at least that's what I've been able to find) was in JDK-6347312 which deals with Console.readLine().

There are also few usages in the JDK. Most probably it is used to a signal a "critical" IOException-like exception that the caller is not supposed to handle (as is the case with other runtime exceptions).

Upvotes: 4

eckes
eckes

Reputation: 10423

IOError is seldomly used. I think its major usecase is in java.io.Console#readLine() and readPassword(), which by default do not throw IOExeption (but wrap it) in order to signal I/O problems.

My guess the motivation for this is, that it is so seldom they did not want to declare a checked exception. It can happen when the terminals have problems - and this is nowadays where you don't have serial lines anymore only happening on severe system conditions like running out of memory or handles.

Upvotes: 4

Makoto
Makoto

Reputation: 106470

Console, Path#toAbsolutePath, and Path#toUri declare this particular exception to be thrown. Of course, that's a documentation fact and not an actual declaration; since Error is a runtime exception, declaring it to be thrown in the signature would have no meaning.

From what it looks like in code, Console#readLine and Console#readPassword catch an IOException that results through its normal operation, then propagate that to an IOError.

Essentially, IOError represents a critical failing of the underlying filesystem, or accessing some resource that ties Java to the file system. It's not thrown often, but it has the potential to be thrown if something serious happens from within the file system.

Upvotes: 18

Related Questions