Was this page helpful?
Your feedback about this content is important. Let us know what you think.
Additional feedback?
1500 characters remaining
Export (0) Print
Expand All

ILease Interface


Defines a lifetime lease object that is used by the remoting lifetime service.

Namespace:   System.Runtime.Remoting.Lifetime
Assembly:  mscorlib (in mscorlib.dll)

Public Interface ILease


Gets the amount of time remaining on the lease.


Gets the current LeaseState of the lease.


Gets or sets the initial time for the lease.


Gets or sets the amount of time by which a call to the remote object renews the CurrentLeaseTime.


Gets or sets the amount of time to wait for a sponsor to return with a lease renewal time.


Registers a sponsor for the lease without renewing the lease.

System_CAPS_pubmethodRegister(ISponsor, TimeSpan)

Registers a sponsor for the lease, and renews it by the specified TimeSpan.


Renews a lease for the specified time.


Removes a sponsor from the sponsor list.

Distributed garbage collection controls when server applications can be deleted. Traditionally, distributed garbage collection uses reference counts and pinging for control. This works well when there are a few clients per object, but does not work well when there are thousands of clients per each object. The lifetime service can assume the function of a traditional distributed garbage collector, and scales well when the number of clients increases.

The lifetime service associates a lease with each remotely activated object. When the lease expires, the object is removed. A lease can specify that an object has an infinite lifetime.

Each AppDomain contains a lease manager that administers the leases in the domain. The lease manager periodically examines the leases for time expiration. If a lease has expired, it can either be canceled by removing its reference to the lease, or renewed by invoking one or more of the lease's sponsors.

A lease contains properties that determine its policies, and methods that renew the lease time. The lease exposes the ILease interface.

For an example showing how to use the ILease interface see .334a30e5-33cb-4f0f-a38a-ed4abc5560fa

.NET Framework
Available since 1.1
Return to top
Was this page helpful?
(1500 characters remaining)
Thank you for your feedback
© 2015 Microsoft