[ROOT] / doc / toc / ARCCore / Class / REx / __TOCDet
Key | Value |
---|---|
Assembly | ARCCore |
DocFragType | Class |
Name | REx |
Namespace | ARCCore |
Type | REx |
ClassAttribute
Key | Value |
---|---|
AssemblyName | ARCCore |
BaseTypes | -Exception-; -ApplicationException- |
ClassNamespace | ARCCore |
ClassType | REx |
Interfaces | -ISerializable- |
REx = 'TooDeepRecursiveDepthException'
Functionality that helps to guard against infinite recursion.
Usage:
void RecursiveMethod() {
try {
REx.Inc()
.... Some code calling RecursiveMethod again, either directly or indirectly ...
} finally {
REx.Dec()
}
}
Alternatively, you can just do:
REx.Inc() + RecursiveMethod() + REx.Inc()
whenever RecursiveMethod returns a string.
This later approach is useful in expressions, meaning you do not have to build statements in order to use this class. If exceptions should occur in RecursiveMethod however, the recursive counter may 'leak' upwards.
Note how the class uses a recursion counter that is 1) static and 2) common for the whole application.
1) Using a static counter is due to the fact that some methods may be recursive without directly calling itself. For instance methodA could call B, which calls C, which then calls A without knowing about call coming from A (This means that passing a recursion counter would not help because it would get lost on its way.
2) Having a common counter for the whole application is just a pragmatic choice.
One has to be aware of threading of course, that is, the max recursion depth (default = 100) has to take into account other threads, and therefore be set to a somewhat higher value than the one suitable for single-threaded environments.
NOTE: Infinite recursion problems manifest themselves as a StackOverflowException (unless caught by safeguards like this).
Generated 2025-10-24 07:00:49.136 UTC