.NET CLR 1.1 does not release the COM object reference.

Collapse
This topic is closed.
X
X
 
  • Time
  • Show
Clear All
new posts
  • johnxhc@gmail.com

    .NET CLR 1.1 does not release the COM object reference.

    We have a project in .NET 1.1 , some of the .NET methods take COM
    interface reference pointer as a parameter, somehow we have to call
    Marshal.Release ComObject to release the COM Object, otherwise the COM
    object will never get release, Even we call gc.Collect()

    But the same code compiles in .NET 2.0 works without the
    Marshal.Release ComObject. (Unfortunately the project is supposed to
    run on .NET 1.1.)


    Is this a known problem? What is the remedy besides
    Marshal.Release ComObject? (We know it is dangerous to call
    Marshal.Release ComObject since we do not have total control of the
    COM
    interface pointer )


    Thanks in advance.
    John

  • Nicholas Paldino [.NET/C# MVP]

    #2
    Re: .NET CLR 1.1 does not release the COM object reference.

    John,

    Regardless of version, you should be calling ReleaseComObjec t on
    references to COM objects that you have when you are done with them. COM
    depends on reference counting, and while garbage collection will ultimately
    take care of stray references that you have (and properly decrement the
    reference count, which will ultimately handle the disposing of the COM
    object that the Runtime Callable Wrapper holds on to), it isn't a good idea
    to not release the objects when you are done with them.

    In other words, don't remove the call in .NET 2.0 because you think it
    works.

    As for .NET 1.1, the ReleaseComObjec t method existed on the Marshal
    class in that version of the framework, so there is no reason you can't use
    it there.


    --
    - Nicholas Paldino [.NET/C# MVP]
    - mvp@spam.guard. caspershouse.co m


    <johnxhc@gmail. comwrote in message
    news:1179280286 .509480.83450@n 59g2000hsh.goog legroups.com...
    We have a project in .NET 1.1 , some of the .NET methods take COM
    interface reference pointer as a parameter, somehow we have to call
    Marshal.Release ComObject to release the COM Object, otherwise the COM
    object will never get release, Even we call gc.Collect()
    >
    But the same code compiles in .NET 2.0 works without the
    Marshal.Release ComObject. (Unfortunately the project is supposed to
    run on .NET 1.1.)
    >
    >
    Is this a known problem? What is the remedy besides
    Marshal.Release ComObject? (We know it is dangerous to call
    Marshal.Release ComObject since we do not have total control of the
    COM
    interface pointer )
    >
    >
    Thanks in advance.
    John
    >

    Comment

    • johnxhc@gmail.com

      #3
      Re: .NET CLR 1.1 does not release the COM object reference.

      Nicholas,Thanks so much for the reply, two more questions.
      1) How come in .NET 1.1, the COM object is not released even after I
      called gc.Collect multiple times as following

      GC.Collect();
      GC.WaitForPendi ngFinalizers();
      GC.Collect();

      If the above code releases the COM object, I would not be so puzzled.

      But in .NET 2.0 it was release right away.

      2) In our code, we have one method, take the COM object, stored it in
      an ArrayList, in the second method , we take the same COM object, here
      we search the ArrayList, remove the COM object from the ArrayList, it
      is here where I call the ReleaseComObjec t

      For the same .Net method. One is called by VC++ client, I only need to
      call ReleaseComObjec t once, but for the VB client I have to call
      ReleaseComObjec t 3 times before the object is release

      If I keep calling ReleaseComObjec t until the return value is 0, then
      I will get an exception
      "COM object that has been separated from its underlying RCW can not
      be used."

      That got me really worried , why 3 times ? Is it possible for me to
      get the exception by calling ReleaseComObjec t 3 times? (Because we
      have not control how the client is using our framework)

      Please advice.
      Thanks.

      On May 15, 7:03 pm, "Nicholas Paldino [.NET/C# MVP]"
      <m...@spam.guar d.caspershouse. comwrote:
      John,
      >
      Regardless of version, you should be calling ReleaseComObjec t on
      references to COM objects that you have when you are done with them. COM
      depends on reference counting, and while garbage collection will ultimately
      take care of stray references that you have (and properly decrement the
      reference count, which will ultimately handle the disposing of the COM
      object that the Runtime Callable Wrapper holds on to), it isn't a good idea
      to not release the objects when you are done with them.
      >
      In other words, don't remove the call in .NET 2.0 because you think it
      works.
      >
      As for .NET 1.1, the ReleaseComObjec t method existed on the Marshal
      class in that version of the framework, so there is no reason you can't use
      it there.
      >
      --
      - Nicholas Paldino [.NET/C# MVP]
      - m...@spam.guard .caspershouse.c om
      >
      <john...@gmail. comwrote in message
      >
      news:1179280286 .509480.83450@n 59g2000hsh.goog legroups.com...
      >
      >
      >
      We have a project in .NET 1.1 , some of the .NET methods take COM
      interface reference pointer as a parameter, somehow we have to call
      Marshal.Release ComObject to release the COM Object, otherwise the COM
      object will never get release, Even we call gc.Collect()
      >
      But the same code compiles in .NET 2.0 works without the
      Marshal.Release ComObject. (Unfortunately the project is supposed to
      run on .NET 1.1.)
      >
      Is this a known problem? What is the remedy besides
      Marshal.Release ComObject? (We know it is dangerous to call
      Marshal.Release ComObject since we do not have total control of the
      COM
      interface pointer )
      >
      Thanks in advance.
      John- Hide quoted text -
      >
      - Show quoted text -

      Comment

      • johnxhc@gmail.com

        #4
        Re: .NET CLR 1.1 does not release the COM object reference.

        Nicholas ,
        Thanks so much for the reply, two more following questions.
        1) How come in .NET 1.1, the COM object is not released even after I
        called gc.Collect multiple times as following

        GC.Collect();
        GC.WaitForPendi ngFinalizers();
        GC.Collect();

        If the above code releases the COM object, I would not be so puzzled.

        But in .NET 2.0 it was release right away.

        2) In our code, we have one method, take the COM object, stored it in
        an ArrayList, in the second method , we take the same COM object, here
        we search the ArrayList, remove the COM object from the ArrayList, it
        is here where I call the ReleaseComObjec t

        For the same .Net method. One is called by VC++ client, I only need
        to call ReleaseComObjec t once, but for the VB client I have to call
        ReleaseComObjec t 3 times before the object is release

        If I keep calling ReleaseComObjec t until the return value is 0, then
        I will get an exception
        "COM object that has been separated from its underlying RCW can not
        be used."

        That got me really worried , why 3 times ? Is it possible for me to
        get the exception by calling ReleaseComObjec t 3 times? (Because we
        have not control how the client is using our framework)

        Please advice.
        Thanks so much for your help.
        John

        On May 15, 7:03 pm, "Nicholas Paldino [.NET/C# MVP]"
        <m...@spam.guar d.caspershouse. comwrote:
        John,
        >
        Regardless of version, you should be calling ReleaseComObjec t on
        references to COM objects that you have when you are done with them. COM
        depends on reference counting, and while garbage collection will ultimately
        take care of stray references that you have (and properly decrement the
        reference count, which will ultimately handle the disposing of the COM
        object that the Runtime Callable Wrapper holds on to), it isn't a good idea
        to not release the objects when you are done with them.
        >
        In other words, don't remove the call in .NET 2.0 because you think it
        works.
        >
        As for .NET 1.1, the ReleaseComObjec t method existed on the Marshal
        class in that version of the framework, so there is no reason you can't use
        it there.
        >
        --
        - Nicholas Paldino [.NET/C# MVP]
        - m...@spam.guard .caspershouse.c om
        >
        <john...@gmail. comwrote in message
        >
        news:1179280286 .509480.83450@n 59g2000hsh.goog legroups.com...
        >
        >
        >
        We have a project in .NET 1.1 , some of the .NET methods take COM
        interface reference pointer as a parameter, somehow we have to call
        Marshal.Release ComObject to release the COM Object, otherwise the COM
        object will never get release, Even we call gc.Collect()
        >
        But the same code compiles in .NET 2.0 works without the
        Marshal.Release ComObject. (Unfortunately the project is supposed to
        run on .NET 1.1.)
        >
        Is this a known problem? What is the remedy besides
        Marshal.Release ComObject? (We know it is dangerous to call
        Marshal.Release ComObject since we do not have total control of the
        COM
        interface pointer )
        >
        Thanks in advance.
        John- Hide quoted text -
        >
        - Show quoted text -

        Comment

        • Nicholas Paldino [.NET/C# MVP]

          #5
          Re: .NET CLR 1.1 does not release the COM object reference.

          See inline:
          1) How come in .NET 1.1, the COM object is not released even after I
          called gc.Collect multiple times as following
          >
          GC.Collect();
          GC.WaitForPendi ngFinalizers();
          GC.Collect();
          >
          If the above code releases the COM object, I would not be so puzzled.
          >
          But in .NET 2.0 it was release right away.
          Without seeing the rest of the code, it is impossible to say, but the
          only reason the COM reference would be sticking around is if something was
          holding a reference to the wrapper and that wrapper had not been passed to
          ReleaseComObjec t.
          2) In our code, we have one method, take the COM object, stored it in
          an ArrayList, in the second method , we take the same COM object, here
          we search the ArrayList, remove the COM object from the ArrayList, it
          is here where I call the ReleaseComObjec t
          >
          For the same .Net method. One is called by VC++ client, I only need
          to call ReleaseComObjec t once, but for the VB client I have to call
          ReleaseComObjec t 3 times before the object is release
          >
          If I keep calling ReleaseComObjec t until the return value is 0, then
          I will get an exception
          "COM object that has been separated from its underlying RCW can not
          be used."
          >
          That got me really worried , why 3 times ? Is it possible for me to
          get the exception by calling ReleaseComObjec t 3 times? (Because we
          have not control how the client is using our framework)
          I don't think you should be calling ReleaseComObjec t three times. As a
          matter of fact, you shouldn't be calling it at all in this case. If the
          same object is going to be placed into the ArrayList, then you shouldn't be
          calling ReleaseComObjec t on the object you take out, as it is going to
          invalidate the wrapper that you are placing into the ArrayList in its place.
          Basically, you should be releasing the object when you are done with it
          (which you aren't in this case).


          --
          - Nicholas Paldino [.NET/C# MVP]
          - mvp@spam.guard. caspershouse.co m
          >
          Please advice.
          Thanks so much for your help.
          John
          >
          On May 15, 7:03 pm, "Nicholas Paldino [.NET/C# MVP]"
          <m...@spam.guar d.caspershouse. comwrote:
          >John,
          >>
          > Regardless of version, you should be calling ReleaseComObjec t on
          >references to COM objects that you have when you are done with them. COM
          >depends on reference counting, and while garbage collection will
          >ultimately
          >take care of stray references that you have (and properly decrement the
          >reference count, which will ultimately handle the disposing of the COM
          >object that the Runtime Callable Wrapper holds on to), it isn't a good
          >idea
          >to not release the objects when you are done with them.
          >>
          > In other words, don't remove the call in .NET 2.0 because you think
          >it
          >works.
          >>
          > As for .NET 1.1, the ReleaseComObjec t method existed on the Marshal
          >class in that version of the framework, so there is no reason you can't
          >use
          >it there.
          >>
          >--
          > - Nicholas Paldino [.NET/C# MVP]
          > - m...@spam.guard .caspershouse.c om
          >>
          ><john...@gmail .comwrote in message
          >>
          >news:117928028 6.509480.83450@ n59g2000hsh.goo glegroups.com.. .
          >>
          >>
          >>
          We have a project in .NET 1.1 , some of the .NET methods take COM
          interface reference pointer as a parameter, somehow we have to call
          Marshal.Release ComObject to release the COM Object, otherwise the COM
          object will never get release, Even we call gc.Collect()
          >>
          But the same code compiles in .NET 2.0 works without the
          Marshal.Release ComObject. (Unfortunately the project is supposed to
          run on .NET 1.1.)
          >>
          Is this a known problem? What is the remedy besides
          Marshal.Release ComObject? (We know it is dangerous to call
          Marshal.Release ComObject since we do not have total control of the
          COM
          interface pointer )
          >>
          Thanks in advance.
          John- Hide quoted text -
          >>
          >- Show quoted text -
          >
          >

          Comment

          Working...