rspec/rules/S2693/java/rule.adoc

23 lines
704 B
Plaintext
Raw Normal View History

2021-04-28 16:49:39 +02:00
The problem with invoking ``++Thread.start()++`` in a constructor is that you'll have a confusing mess on your hands if the class is ever extended because the superclass' constructor will start the thread before the child class has truly been initialized.
This rule raises an issue any time ``++start++`` is invoked in the constructor of a non-``++final++`` class.
== Noncompliant Code Example
----
public class MyClass {
Thread thread = null;
public MyClass(Runnable runnable) {
thread = new Thread(runnable);
thread.start(); // Noncompliant
}
}
----
== See
* https://wiki.sei.cmu.edu/confluence/x/FDdGBQ[CERT, TSM02-J.] - Do not use background threads during class initialization