2017-09-13 04:42:36 +08:00
<?xml version="1.0" encoding="UTF-8" ?>
2023-03-01 08:44:37 +08:00
<class name= "RefCounted" inherits= "Object" version= "4.1" xmlns:xsi= "http://www.w3.org/2001/XMLSchema-instance" xsi:noNamespaceSchemaLocation= "../class.xsd" >
2017-09-13 04:42:36 +08:00
<brief_description >
2019-06-26 21:57:13 +08:00
Base class for reference-counted objects.
2017-09-13 04:42:36 +08:00
</brief_description>
<description >
2019-06-26 21:57:13 +08:00
Base class for any object that keeps a reference count. [Resource] and many other helper objects inherit this class.
2021-10-08 08:16:59 +08:00
Unlike other [Object] types, [RefCounted]s keep an internal reference counter so that they are automatically released when no longer in use, and only then. [RefCounted]s therefore do not need to be freed manually with [method Object.free].
2021-06-05 00:03:15 +08:00
In the vast majority of use cases, instantiating and using [RefCounted]-derived types is all you need to do. The methods provided in this class are only for advanced users, and can cause issues if misused.
2021-10-08 08:16:59 +08:00
[b]Note:[/b] In C#, reference-counted objects will not be freed instantly after they are no longer in use. Instead, garbage collection will run periodically and will free reference-counted objects that are no longer in use. This means that unused ones will linger on for a while before being removed.
2017-09-13 04:42:36 +08:00
</description>
<tutorials >
2021-11-15 17:43:07 +08:00
<link title= "When and how to avoid using nodes for everything" > $DOCS_URL/tutorials/best_practices/node_alternatives.html</link>
2017-09-13 04:42:36 +08:00
</tutorials>
<methods >
2022-09-19 22:45:45 +08:00
<method name= "get_reference_count" qualifiers= "const" >
<return type= "int" />
<description >
Returns the current reference count.
</description>
</method>
2017-09-13 04:42:36 +08:00
<method name= "init_ref" >
2021-07-30 21:28:05 +08:00
<return type= "bool" />
2017-09-13 04:42:36 +08:00
<description >
2019-06-26 21:57:13 +08:00
Initializes the internal reference counter. Use this only if you really know what you are doing.
Returns whether the initialization was successful.
2017-09-13 04:42:36 +08:00
</description>
</method>
<method name= "reference" >
2021-07-30 21:28:05 +08:00
<return type= "bool" />
2017-09-13 04:42:36 +08:00
<description >
2019-06-26 21:57:13 +08:00
Increments the internal reference counter. Use this only if you really know what you are doing.
2019-06-22 07:04:47 +08:00
Returns [code]true[/code] if the increment was successful, [code]false[/code] otherwise.
2017-09-13 04:42:36 +08:00
</description>
</method>
<method name= "unreference" >
2021-07-30 21:28:05 +08:00
<return type= "bool" />
2017-09-13 04:42:36 +08:00
<description >
2019-06-26 21:57:13 +08:00
Decrements the internal reference counter. Use this only if you really know what you are doing.
2019-06-22 07:04:47 +08:00
Returns [code]true[/code] if the decrement was successful, [code]false[/code] otherwise.
2017-09-13 04:42:36 +08:00
</description>
</method>
</methods>
</class>