[petsc-dev] XXXDestroy() mistaken design in PETSc

Barry Smith bsmith at mcs.anl.gov
Tue Feb 15 16:47:35 CST 2011


  In MPI one calls MPI_Comm_free(&comm) to allow the MPI implementation to set the pointer explicitly to 0 after the object is destroyed.

  In Petsc XXXDestroy() does not pass the pointer (because it seemed too unnatural to me in 1994) thus not allowing 0ing the pointer. 

   Was this a bad design decision? Should it be revisited? 

   Barry

  Two use cases 

1) error detection when someone tries to reuse a freed object

2) when removing some objects from a data structure that will be used data one currently needs to do

  XXXXDestroy(mystruct->something);CHKERRQ(ierr); mystruct->something = 0; 

instead of the cleaner XXXDestroy(&mystruct->something);CHKERRQ(ierr); 


More information about the petsc-dev mailing list