This warning is reported in situations when one object is cast to another object with the possibility of lost data or even program failure.

Vulnerability and risk

Either data may be lost, or the program may fail. This can happen when a program tries to access a nonexistent class field after a cast.


  public class Object1 : Object2 {
     public int a;
  public class Object2 {
     public int a;
  public class ClassCastTests {
     public void foo() {
        Object1 o1;
       Object2 o2 = new Object2();
       o1 = (Object1)o2;

Object o1 of class Object1 and object o2 of class Object2 are declared on lines 9-10. Then, on line 11, Object2 is cast to Object1, which is invalid.

Security training

Application security training materials provided by Secure Code Warrior.