Granularity of OSError

Grant Edwards invalid at invalid.com
Fri Sep 18 22:30:22 EDT 2009


On 2009-09-19, Christian Heimes <lists at cheimes.de> wrote:
> kj wrote:
>> For example, LBYL would look like this:
>> 
>> if os.path.isfile(some_file):
>>     os.unlink(some_file)
>> 
>> In contrast, EAFP would look like this:
>> 
>> try:
>>     os.unlink(some_file)
>> except OSError:
>>     pass
>
>
> The two version aren't equal. The first one suffers from a race
> condition which may lead to a severe security issue. The file may be
> gone or replaced by a different file in the time span between the check
> and the call to unlink().

IOW, just be cause you look before you leap, it doesn't mean
you're not going to land on anybody and have to ask for
forgiveness afterwards.

Since you always have to handle the error case, there's not
much point in checking first unless the error case has bad
side-effects that you're trying to avoid.  In this case,
attempting to unlink a non-existent file has no bad
side-effects, so there's no point in checking before the
unlink.

-- 
Grant




More information about the Python-list mailing list