Where to put the error handing test?

Lie Ryan lie.1296 at gmail.com
Mon Nov 23 22:44:16 EST 2009


Peng Yu wrote:
> Suppose that I have function f() that calls g(), I can put a test on
> the argument 'x' in either g() or f(). I'm wondering what is the
> common practice.
> 
> My thought is that if I put the test in g(x), the code of g(x) is
> safer, but the test is not necessary when g() is called by h().
> 
> If I put the test in f(), then g() becomes more efficient when other
> code call g() and guarantee x will pass the test even though the test
> code in not in g(). But there might be some caller of g() that pass an
> 'x' that might not pass the test, if there were the test in g().

Typically, you test for x as early as possible, e.g. just after user 
input (or file or url load or whatever). After that test, you can (or 
should be able to) assume that all function calls will always be called 
with the correct argument. This is the ideal situation, it's not always 
easy to do.

In any case though, don't optimize early.



More information about the Python-list mailing list