开发者

Recursion in Error Handling?

开发者 https://www.devze.com 2023-03-03 23:00 出处:网络
I\'m writing a file reader that returns an object and I\'d like it to warn on parse errors and continue to the next record.

I'm writing a file reader that returns an object and I'd like it to warn on parse errors and continue to the next record.

The code below is the obvious implementation of this, but involves recursing from inside the catch block. Is there any technical or stylistic reason not to do this?

public RecordType nextRecord() throws IOException{
    if (reader == null){
        throw new IllegalStateException("Reader closed.");
    }
    String line = reader.readLine();
    if (line == null){
        return null;
    }else{
        try {
            return parseRecord(line);
        }catch (ParseException pex){
            logger.warn("Record ignored due to parse error: " 
                + pex.getMessage());
            //Note the recursion here
            return nextRecor开发者_StackOverflow社区d();
        }
    }
}


I would prefer to use a loop. With recursion, you never know how deep you can safely go.

String line;
while((line = reader.readLine()) != null) {
    try {
        return parseRecord(line);
    }catch (ParseException pex){
        logger.warn("Record ignored due to parse error: " + pex);
    }
}
return null;


Why not replace the recursion with a loop:

public RecordType nextRecord() throws IOException {
    if (reader == null) {
        throw new IllegalStateException("Reader closed.");
    }
    for (;;) {
        String line = reader.readLine();
        if (line == null) {
            return null;
        } else {
            try {
                return parseRecord(line);
            } catch (ParseException pex) {
                logger.warn("Record ignored due to parse error: "
                        + pex.getMessage());
                // continue to the next record
            }
        }
    }
}

Stylistically, I find this preferable.


Would it be cleaner to let the ParseException propagate back to the caller? The caller could then decide what to do about it.


What it seems like to me is that whatever is calling your method is going to keep calling it until the method returns null.

I would probably follow the advice of the previous posters and use a loop, however I would look at whatever is calling the method (as it is probably already using a loop), have it skip the line by looking for an exception to be thrown.

0

精彩评论

暂无评论...
验证码 换一张
取 消