devxlogo

Avoid Out of Memory Conditions

Avoid Out of Memory Conditions

Byte[] pdf = toPdf(file);

Here, a method creates a PDF file from some input and returns the binary PDF data as a byte array. This code expects that the generated file is small enough to adjust into the available heap memory.

If this code can not make this 100% sure, then it is vulnerable to an out of memory condition. Moreover, if this code is running server-side, which usually means numerous parallel threads — bulk data must never be handled with byte arrays. Streams should be used and the data should be spooled to disk or a database.

File pdf = to Pdf(file);

A similar anti-pattern is to buffer streaming input from an “untrusted” source, such as buffering data that arrives on a network socket. If the application doesn’t know how much data will arrive, it must make sure that it keeps an eye on the amount of the data. If the volume of buffered data exceeds limits, an error condition (exception) should be signaled to the caller.

See also  Java Developer Jobs: Your Guide to Landing the Perfect Position in 2024
devxblackblue

About Our Editorial Process

At DevX, we’re dedicated to tech entrepreneurship. Our team closely follows industry shifts, new products, AI breakthroughs, technology trends, and funding announcements. Articles undergo thorough editing to ensure accuracy and clarity, reflecting DevX’s style and supporting entrepreneurs in the tech sphere.

See our full editorial policy.

About Our Journalist