Monday, 3 May 2021

How does one properly close a captain proto struct to avoid memory leaks?

I think I have memory issues and I want to close the file I've read using pycapnp. How is the best way to do this? Is doing:

    def __getitem__(self, idx: int) -> DagNode:
        # gets the file idx for the value we want
        file_idx = self.get_file_index(idx)
        file_name = self.list_files_current_split[file_idx]
        f = open(file_name)
        capnp_file = dag_api_capnp.Dag.read_packed(f, traversal_limit_in_words=2 ** 64 - 1)
        # do stuff with it
        node = DagNode(capnp_file.field1)
        # close both files
        capnp_file.finish()
        f.close()
        return node

in my scenario I have a data set saved in the captian proto format and I want to close the captain proto file after I've extracted the information I need from it (so to avoid memory issues and not waste space!). What is the proper way to do this, the

.finish()

method guaranteed to do this? I don't have to call the garbage collector...right?

Thanks in advance!

reference:



from How does one properly close a captain proto struct to avoid memory leaks?

No comments:

Post a Comment