Automatic recovery from resource exhaustion exceptions by collecting leaked resources

作者:Dai, Zi ying; Mao, Xiao guang*; Chen, Li qian; Lei, Yan
来源:Journal of Zhejiang University-Science C(Computers and Electronics), 2014, 15(8): 622-635.
DOI:10.1631/jzus.C1300352

摘要

Despite the availability of garbage collectors, programmers must manually manage non-memory finite system resources such as file descriptors. Resource leaks can gradually consume all available resources and cause programs to raise resource exhaustion exceptions. However, programmers commonly provide no effective recovery approach for resource exhaustion exceptions, which often causes programs to halt without completing their tasks. In this paper, we propose to automatically recover programs from resource exhaustion exceptions caused by resource leaks. We transform programs to catch resource exhaustion exceptions, collect leaked resources, and then retry the failure code. A resource collector is designed to identify leaked resources and safely release them. We implement our approach for Java programs. Experimental results show that our approach can successfully handle resource exhaustion exceptions caused by reported resource leaks and allow programs to complete their tasks with an average execution time increase of 2.52% and negligible bytecode size increase.

全文