Error “illegal generic type for instanceof” when using local classes Announcing the arrival of Valued Associate #679: Cesar Manara Planned maintenance scheduled April 17/18, 2019 at 00:00UTC (8:00pm US/Eastern) Data science time! April 2019 and salary with experience Should we burninate the [wrap] tag? The Ask Question Wizard is Live!“illegal generic type of instanceof” when using instanceof on an inner class type?How to refer to a class when both simple and fully-qualified names clashCreate instance of generic type in Java?Calling a static method on a generic type parameterCollections.emptyList() returns a List<Object>?How to get the type of T from a member of a generic class or method?“illegal generic type of instanceof” when using instanceof on an inner class type?Get generic type of class at runtimeHow to get a class instance of generics type THow to make a Java Generic method static?Google Gson - deserialize list<class> object? (generic type)Get “Illegal generic type for instanceof” error when coparison

How discoverable are IPv6 addresses and AAAA names by potential attackers?

Single word antonym of "flightless"

Why are there no cargo aircraft with "flying wing" design?

Identifying polygons that intersect with another layer using QGIS?

Dating a Former Employee

When do you get frequent flier miles - when you buy, or when you fly?

51k Euros annually for a family of 4 in Berlin: Is it enough?

What does an IRS interview request entail when called in to verify expenses for a sole proprietor small business?

Why is my conclusion inconsistent with the van't Hoff equation?

Denied boarding although I have proper visa and documentation. To whom should I make a complaint?

Generate an RGB colour grid

Why did the rest of the Eastern Bloc not invade Yugoslavia?

At the end of Thor: Ragnarok why don't the Asgardians turn and head for the Bifrost as per their original plan?

How to bypass password on Windows XP account?

Book where humans were engineered with genes from animal species to survive hostile planets

List *all* the tuples!

How does the particle を relate to the verb 行く in the structure「A を + B に行く」?

The logistics of corpse disposal

Why didn't this character "real die" when they blew their stack out in Altered Carbon?

Should I discuss the type of campaign with my players?

Is there a problem creating Diff Backups every hour instead of Logs and DIffs?

Can a USB port passively 'listen only'?

A coin, having probability p of landing heads and probability of q=(1-p) of landing on heads.

Output the ŋarâþ crîþ alphabet song without using (m)any letters



Error “illegal generic type for instanceof” when using local classes



Announcing the arrival of Valued Associate #679: Cesar Manara
Planned maintenance scheduled April 17/18, 2019 at 00:00UTC (8:00pm US/Eastern)
Data science time! April 2019 and salary with experience
Should we burninate the [wrap] tag?
The Ask Question Wizard is Live!“illegal generic type of instanceof” when using instanceof on an inner class type?How to refer to a class when both simple and fully-qualified names clashCreate instance of generic type in Java?Calling a static method on a generic type parameterCollections.emptyList() returns a List<Object>?How to get the type of T from a member of a generic class or method?“illegal generic type of instanceof” when using instanceof on an inner class type?Get generic type of class at runtimeHow to get a class instance of generics type THow to make a Java Generic method static?Google Gson - deserialize list<class> object? (generic type)Get “Illegal generic type for instanceof” error when coparison



.everyoneloves__top-leaderboard:empty,.everyoneloves__mid-leaderboard:empty,.everyoneloves__bot-mid-leaderboard:empty height:90px;width:728px;box-sizing:border-box;








31















I have the following Java code that uses a local class.



import java.util.Arrays;

public class X<T>
void m()
class Z

for (Object o : Arrays.asList(1, 2, 3))
if (o instanceof Z)




It does not compile with the following error message:



X.java:8: error: illegal generic type for instanceof
if (o instanceof Z)
^
1 error


I understand that the local class Z inherits the generic type signature of X<T>, being an inner class. The same kind of compilation error appears in this example, where Z is not local, but still inner:



import java.util.Arrays;

public class X<T>
class Z

void m()
for (Object o : Arrays.asList(1, 2, 3))
if (o instanceof Z) // Compilation error




It can be worked around either by making Z non-inner / static:



import java.util.Arrays;

public class X<T>
static class Z

void m()
for (Object o : Arrays.asList(1, 2, 3))
if (o instanceof Z) // Compiles now




Or by qualifying X.Z:



import java.util.Arrays;

public class X<T>
class Z

void m()
for (Object o : Arrays.asList(1, 2, 3))
if (o instanceof X.Z) // Compiles now
if (o instanceof X<?>.Z) // Also





But how can I qualify a local class, or work around this limitation, without changing the local class itself?










share|improve this question
























  • I think this is a kind of compiler pathology. It's a strange way of telling you the type is not reifiable. It's even worse in Eclipse - it tells you "Use the form Z instead".

    – RealSkeptic
    16 hours ago






  • 1





    @RealSkeptic: Eclipse's compiler message is just "unlucky" here. It is usually a helpful extra information.

    – Lukas Eder
    16 hours ago






  • 2





    A corollary of this is that Z[] array = new Z[0]; is also illegal.

    – Andy Turner
    16 hours ago


















31















I have the following Java code that uses a local class.



import java.util.Arrays;

public class X<T>
void m()
class Z

for (Object o : Arrays.asList(1, 2, 3))
if (o instanceof Z)




It does not compile with the following error message:



X.java:8: error: illegal generic type for instanceof
if (o instanceof Z)
^
1 error


I understand that the local class Z inherits the generic type signature of X<T>, being an inner class. The same kind of compilation error appears in this example, where Z is not local, but still inner:



import java.util.Arrays;

public class X<T>
class Z

void m()
for (Object o : Arrays.asList(1, 2, 3))
if (o instanceof Z) // Compilation error




It can be worked around either by making Z non-inner / static:



import java.util.Arrays;

public class X<T>
static class Z

void m()
for (Object o : Arrays.asList(1, 2, 3))
if (o instanceof Z) // Compiles now




Or by qualifying X.Z:



import java.util.Arrays;

public class X<T>
class Z

void m()
for (Object o : Arrays.asList(1, 2, 3))
if (o instanceof X.Z) // Compiles now
if (o instanceof X<?>.Z) // Also





But how can I qualify a local class, or work around this limitation, without changing the local class itself?










share|improve this question
























  • I think this is a kind of compiler pathology. It's a strange way of telling you the type is not reifiable. It's even worse in Eclipse - it tells you "Use the form Z instead".

    – RealSkeptic
    16 hours ago






  • 1





    @RealSkeptic: Eclipse's compiler message is just "unlucky" here. It is usually a helpful extra information.

    – Lukas Eder
    16 hours ago






  • 2





    A corollary of this is that Z[] array = new Z[0]; is also illegal.

    – Andy Turner
    16 hours ago














31












31








31


1






I have the following Java code that uses a local class.



import java.util.Arrays;

public class X<T>
void m()
class Z

for (Object o : Arrays.asList(1, 2, 3))
if (o instanceof Z)




It does not compile with the following error message:



X.java:8: error: illegal generic type for instanceof
if (o instanceof Z)
^
1 error


I understand that the local class Z inherits the generic type signature of X<T>, being an inner class. The same kind of compilation error appears in this example, where Z is not local, but still inner:



import java.util.Arrays;

public class X<T>
class Z

void m()
for (Object o : Arrays.asList(1, 2, 3))
if (o instanceof Z) // Compilation error




It can be worked around either by making Z non-inner / static:



import java.util.Arrays;

public class X<T>
static class Z

void m()
for (Object o : Arrays.asList(1, 2, 3))
if (o instanceof Z) // Compiles now




Or by qualifying X.Z:



import java.util.Arrays;

public class X<T>
class Z

void m()
for (Object o : Arrays.asList(1, 2, 3))
if (o instanceof X.Z) // Compiles now
if (o instanceof X<?>.Z) // Also





But how can I qualify a local class, or work around this limitation, without changing the local class itself?










share|improve this question
















I have the following Java code that uses a local class.



import java.util.Arrays;

public class X<T>
void m()
class Z

for (Object o : Arrays.asList(1, 2, 3))
if (o instanceof Z)




It does not compile with the following error message:



X.java:8: error: illegal generic type for instanceof
if (o instanceof Z)
^
1 error


I understand that the local class Z inherits the generic type signature of X<T>, being an inner class. The same kind of compilation error appears in this example, where Z is not local, but still inner:



import java.util.Arrays;

public class X<T>
class Z

void m()
for (Object o : Arrays.asList(1, 2, 3))
if (o instanceof Z) // Compilation error




It can be worked around either by making Z non-inner / static:



import java.util.Arrays;

public class X<T>
static class Z

void m()
for (Object o : Arrays.asList(1, 2, 3))
if (o instanceof Z) // Compiles now




Or by qualifying X.Z:



import java.util.Arrays;

public class X<T>
class Z

void m()
for (Object o : Arrays.asList(1, 2, 3))
if (o instanceof X.Z) // Compiles now
if (o instanceof X<?>.Z) // Also





But how can I qualify a local class, or work around this limitation, without changing the local class itself?







java generics local-class






share|improve this question















share|improve this question













share|improve this question




share|improve this question








edited 2 hours ago









Peter Mortensen

13.9k1987114




13.9k1987114










asked 17 hours ago









Lukas EderLukas Eder

137k74448987




137k74448987












  • I think this is a kind of compiler pathology. It's a strange way of telling you the type is not reifiable. It's even worse in Eclipse - it tells you "Use the form Z instead".

    – RealSkeptic
    16 hours ago






  • 1





    @RealSkeptic: Eclipse's compiler message is just "unlucky" here. It is usually a helpful extra information.

    – Lukas Eder
    16 hours ago






  • 2





    A corollary of this is that Z[] array = new Z[0]; is also illegal.

    – Andy Turner
    16 hours ago


















  • I think this is a kind of compiler pathology. It's a strange way of telling you the type is not reifiable. It's even worse in Eclipse - it tells you "Use the form Z instead".

    – RealSkeptic
    16 hours ago






  • 1





    @RealSkeptic: Eclipse's compiler message is just "unlucky" here. It is usually a helpful extra information.

    – Lukas Eder
    16 hours ago






  • 2





    A corollary of this is that Z[] array = new Z[0]; is also illegal.

    – Andy Turner
    16 hours ago

















I think this is a kind of compiler pathology. It's a strange way of telling you the type is not reifiable. It's even worse in Eclipse - it tells you "Use the form Z instead".

– RealSkeptic
16 hours ago





I think this is a kind of compiler pathology. It's a strange way of telling you the type is not reifiable. It's even worse in Eclipse - it tells you "Use the form Z instead".

– RealSkeptic
16 hours ago




1




1





@RealSkeptic: Eclipse's compiler message is just "unlucky" here. It is usually a helpful extra information.

– Lukas Eder
16 hours ago





@RealSkeptic: Eclipse's compiler message is just "unlucky" here. It is usually a helpful extra information.

– Lukas Eder
16 hours ago




2




2





A corollary of this is that Z[] array = new Z[0]; is also illegal.

– Andy Turner
16 hours ago






A corollary of this is that Z[] array = new Z[0]; is also illegal.

– Andy Turner
16 hours ago













4 Answers
4






active

oldest

votes


















20














To me this seems to be an oversight or limitation in the Java language and I do not think it is possible.



The referenced type in an instanceof expression must be reifiable according to JLS 4.7, meaning that it must be expressed as a reifiable type by its fully qualified name. At the same time, JLS 6.7 states that local classes do not have a fully qualified name, they can therefore not be expressed as reifiable.



If you declare Z as generic, the instanceof operator treats Z as a raw type where all generic properties to it - in this case the enclosing class - are considered raw as well. (Similar to a generic methods of a raw type being considered as raw despite any generic signature. This is a measure to retain backwards compatiblity of type generification.) Since any raw type is reifiable, declaring Z to be generic will compile.






share|improve this answer

























  • It's true, but curiously, it does allow it if Z itself is generic, despite the fact that you have no way to qualify it.

    – RealSkeptic
    16 hours ago











  • "oversight" - You're here to pick a fight with the JLS designers, right? :)

    – Lukas Eder
    16 hours ago






  • 3





    Generics were patched into the language and there are some corner cases such as class literals that were not properly covered. Nothing is perfect, I think there is a chance for an oversight. ;)

    – Rafael Winterhalter
    16 hours ago











  • I extended my answer to explain why generification of Z does the trick.

    – Rafael Winterhalter
    16 hours ago











  • @LukasEder I think oversight is right. It's sort of like this question: these cases could have been designed around, but they haven't been; I make no judgment as to whether they should have been.

    – Andy Turner
    16 hours ago



















14














A possible workaround is to use reflection:



import java.util.Arrays;

public class X<T>
void m()
class Z

for (Object o : Arrays.asList(1, 2, 3))
if (Z.class.isInstance(o))







share|improve this answer






























    2














    Apparently, by making Z generic compilation succeeds. I expected that to require <T> as the type parameter, but you just have to make it generic, so anything will do



    import java.util.Arrays;

    public class X<T>
    void m()
    class Z<Anything>

    for (Object o : Arrays.asList(1, 2, 3))
    if (Z.class.isInstance(o))




    Proper solution would be qualify the local class, but I don't think you can. Either you refactor it to a private static class or that's probably the best you can get.






    share|improve this answer




















    • 2





      Once you make Z generic, you don't need to apply the reflection workaround anymore...

      – Lukas Eder
      16 hours ago


















    0














    This should work either. Using reflection too. But seems a valid solution.



    import java.util.Arrays;

    public class X<T>


    void m()

    class Z2


    for(Object o: Arrays.asList(1,2,3))
    if(Z2.class.isAssignableFrom(o.getClass()))












    share|improve this answer

























    • I didn't downvote, but I guess it's because there's a slightly better way to use reflection here, as I've mentioned in my own answer

      – Lukas Eder
      16 hours ago











    Your Answer






    StackExchange.ifUsing("editor", function ()
    StackExchange.using("externalEditor", function ()
    StackExchange.using("snippets", function ()
    StackExchange.snippets.init();
    );
    );
    , "code-snippets");

    StackExchange.ready(function()
    var channelOptions =
    tags: "".split(" "),
    id: "1"
    ;
    initTagRenderer("".split(" "), "".split(" "), channelOptions);

    StackExchange.using("externalEditor", function()
    // Have to fire editor after snippets, if snippets enabled
    if (StackExchange.settings.snippets.snippetsEnabled)
    StackExchange.using("snippets", function()
    createEditor();
    );

    else
    createEditor();

    );

    function createEditor()
    StackExchange.prepareEditor(
    heartbeatType: 'answer',
    autoActivateHeartbeat: false,
    convertImagesToLinks: true,
    noModals: true,
    showLowRepImageUploadWarning: true,
    reputationToPostImages: 10,
    bindNavPrevention: true,
    postfix: "",
    imageUploader:
    brandingHtml: "Powered by u003ca class="icon-imgur-white" href="https://imgur.com/"u003eu003c/au003e",
    contentPolicyHtml: "User contributions licensed under u003ca href="https://creativecommons.org/licenses/by-sa/3.0/"u003ecc by-sa 3.0 with attribution requiredu003c/au003e u003ca href="https://stackoverflow.com/legal/content-policy"u003e(content policy)u003c/au003e",
    allowUrls: true
    ,
    onDemand: true,
    discardSelector: ".discard-answer"
    ,immediatelyShowMarkdownHelp:true
    );



    );













    draft saved

    draft discarded


















    StackExchange.ready(
    function ()
    StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f55703849%2ferror-illegal-generic-type-for-instanceof-when-using-local-classes%23new-answer', 'question_page');

    );

    Post as a guest















    Required, but never shown

























    4 Answers
    4






    active

    oldest

    votes








    4 Answers
    4






    active

    oldest

    votes









    active

    oldest

    votes






    active

    oldest

    votes









    20














    To me this seems to be an oversight or limitation in the Java language and I do not think it is possible.



    The referenced type in an instanceof expression must be reifiable according to JLS 4.7, meaning that it must be expressed as a reifiable type by its fully qualified name. At the same time, JLS 6.7 states that local classes do not have a fully qualified name, they can therefore not be expressed as reifiable.



    If you declare Z as generic, the instanceof operator treats Z as a raw type where all generic properties to it - in this case the enclosing class - are considered raw as well. (Similar to a generic methods of a raw type being considered as raw despite any generic signature. This is a measure to retain backwards compatiblity of type generification.) Since any raw type is reifiable, declaring Z to be generic will compile.






    share|improve this answer

























    • It's true, but curiously, it does allow it if Z itself is generic, despite the fact that you have no way to qualify it.

      – RealSkeptic
      16 hours ago











    • "oversight" - You're here to pick a fight with the JLS designers, right? :)

      – Lukas Eder
      16 hours ago






    • 3





      Generics were patched into the language and there are some corner cases such as class literals that were not properly covered. Nothing is perfect, I think there is a chance for an oversight. ;)

      – Rafael Winterhalter
      16 hours ago











    • I extended my answer to explain why generification of Z does the trick.

      – Rafael Winterhalter
      16 hours ago











    • @LukasEder I think oversight is right. It's sort of like this question: these cases could have been designed around, but they haven't been; I make no judgment as to whether they should have been.

      – Andy Turner
      16 hours ago
















    20














    To me this seems to be an oversight or limitation in the Java language and I do not think it is possible.



    The referenced type in an instanceof expression must be reifiable according to JLS 4.7, meaning that it must be expressed as a reifiable type by its fully qualified name. At the same time, JLS 6.7 states that local classes do not have a fully qualified name, they can therefore not be expressed as reifiable.



    If you declare Z as generic, the instanceof operator treats Z as a raw type where all generic properties to it - in this case the enclosing class - are considered raw as well. (Similar to a generic methods of a raw type being considered as raw despite any generic signature. This is a measure to retain backwards compatiblity of type generification.) Since any raw type is reifiable, declaring Z to be generic will compile.






    share|improve this answer

























    • It's true, but curiously, it does allow it if Z itself is generic, despite the fact that you have no way to qualify it.

      – RealSkeptic
      16 hours ago











    • "oversight" - You're here to pick a fight with the JLS designers, right? :)

      – Lukas Eder
      16 hours ago






    • 3





      Generics were patched into the language and there are some corner cases such as class literals that were not properly covered. Nothing is perfect, I think there is a chance for an oversight. ;)

      – Rafael Winterhalter
      16 hours ago











    • I extended my answer to explain why generification of Z does the trick.

      – Rafael Winterhalter
      16 hours ago











    • @LukasEder I think oversight is right. It's sort of like this question: these cases could have been designed around, but they haven't been; I make no judgment as to whether they should have been.

      – Andy Turner
      16 hours ago














    20












    20








    20







    To me this seems to be an oversight or limitation in the Java language and I do not think it is possible.



    The referenced type in an instanceof expression must be reifiable according to JLS 4.7, meaning that it must be expressed as a reifiable type by its fully qualified name. At the same time, JLS 6.7 states that local classes do not have a fully qualified name, they can therefore not be expressed as reifiable.



    If you declare Z as generic, the instanceof operator treats Z as a raw type where all generic properties to it - in this case the enclosing class - are considered raw as well. (Similar to a generic methods of a raw type being considered as raw despite any generic signature. This is a measure to retain backwards compatiblity of type generification.) Since any raw type is reifiable, declaring Z to be generic will compile.






    share|improve this answer















    To me this seems to be an oversight or limitation in the Java language and I do not think it is possible.



    The referenced type in an instanceof expression must be reifiable according to JLS 4.7, meaning that it must be expressed as a reifiable type by its fully qualified name. At the same time, JLS 6.7 states that local classes do not have a fully qualified name, they can therefore not be expressed as reifiable.



    If you declare Z as generic, the instanceof operator treats Z as a raw type where all generic properties to it - in this case the enclosing class - are considered raw as well. (Similar to a generic methods of a raw type being considered as raw despite any generic signature. This is a measure to retain backwards compatiblity of type generification.) Since any raw type is reifiable, declaring Z to be generic will compile.







    share|improve this answer














    share|improve this answer



    share|improve this answer








    edited 16 hours ago

























    answered 16 hours ago









    Rafael WinterhalterRafael Winterhalter

    28.5k1368149




    28.5k1368149












    • It's true, but curiously, it does allow it if Z itself is generic, despite the fact that you have no way to qualify it.

      – RealSkeptic
      16 hours ago











    • "oversight" - You're here to pick a fight with the JLS designers, right? :)

      – Lukas Eder
      16 hours ago






    • 3





      Generics were patched into the language and there are some corner cases such as class literals that were not properly covered. Nothing is perfect, I think there is a chance for an oversight. ;)

      – Rafael Winterhalter
      16 hours ago











    • I extended my answer to explain why generification of Z does the trick.

      – Rafael Winterhalter
      16 hours ago











    • @LukasEder I think oversight is right. It's sort of like this question: these cases could have been designed around, but they haven't been; I make no judgment as to whether they should have been.

      – Andy Turner
      16 hours ago


















    • It's true, but curiously, it does allow it if Z itself is generic, despite the fact that you have no way to qualify it.

      – RealSkeptic
      16 hours ago











    • "oversight" - You're here to pick a fight with the JLS designers, right? :)

      – Lukas Eder
      16 hours ago






    • 3





      Generics were patched into the language and there are some corner cases such as class literals that were not properly covered. Nothing is perfect, I think there is a chance for an oversight. ;)

      – Rafael Winterhalter
      16 hours ago











    • I extended my answer to explain why generification of Z does the trick.

      – Rafael Winterhalter
      16 hours ago











    • @LukasEder I think oversight is right. It's sort of like this question: these cases could have been designed around, but they haven't been; I make no judgment as to whether they should have been.

      – Andy Turner
      16 hours ago

















    It's true, but curiously, it does allow it if Z itself is generic, despite the fact that you have no way to qualify it.

    – RealSkeptic
    16 hours ago





    It's true, but curiously, it does allow it if Z itself is generic, despite the fact that you have no way to qualify it.

    – RealSkeptic
    16 hours ago













    "oversight" - You're here to pick a fight with the JLS designers, right? :)

    – Lukas Eder
    16 hours ago





    "oversight" - You're here to pick a fight with the JLS designers, right? :)

    – Lukas Eder
    16 hours ago




    3




    3





    Generics were patched into the language and there are some corner cases such as class literals that were not properly covered. Nothing is perfect, I think there is a chance for an oversight. ;)

    – Rafael Winterhalter
    16 hours ago





    Generics were patched into the language and there are some corner cases such as class literals that were not properly covered. Nothing is perfect, I think there is a chance for an oversight. ;)

    – Rafael Winterhalter
    16 hours ago













    I extended my answer to explain why generification of Z does the trick.

    – Rafael Winterhalter
    16 hours ago





    I extended my answer to explain why generification of Z does the trick.

    – Rafael Winterhalter
    16 hours ago













    @LukasEder I think oversight is right. It's sort of like this question: these cases could have been designed around, but they haven't been; I make no judgment as to whether they should have been.

    – Andy Turner
    16 hours ago






    @LukasEder I think oversight is right. It's sort of like this question: these cases could have been designed around, but they haven't been; I make no judgment as to whether they should have been.

    – Andy Turner
    16 hours ago














    14














    A possible workaround is to use reflection:



    import java.util.Arrays;

    public class X<T>
    void m()
    class Z

    for (Object o : Arrays.asList(1, 2, 3))
    if (Z.class.isInstance(o))







    share|improve this answer



























      14














      A possible workaround is to use reflection:



      import java.util.Arrays;

      public class X<T>
      void m()
      class Z

      for (Object o : Arrays.asList(1, 2, 3))
      if (Z.class.isInstance(o))







      share|improve this answer

























        14












        14








        14







        A possible workaround is to use reflection:



        import java.util.Arrays;

        public class X<T>
        void m()
        class Z

        for (Object o : Arrays.asList(1, 2, 3))
        if (Z.class.isInstance(o))







        share|improve this answer













        A possible workaround is to use reflection:



        import java.util.Arrays;

        public class X<T>
        void m()
        class Z

        for (Object o : Arrays.asList(1, 2, 3))
        if (Z.class.isInstance(o))








        share|improve this answer












        share|improve this answer



        share|improve this answer










        answered 17 hours ago









        Lukas EderLukas Eder

        137k74448987




        137k74448987





















            2














            Apparently, by making Z generic compilation succeeds. I expected that to require <T> as the type parameter, but you just have to make it generic, so anything will do



            import java.util.Arrays;

            public class X<T>
            void m()
            class Z<Anything>

            for (Object o : Arrays.asList(1, 2, 3))
            if (Z.class.isInstance(o))




            Proper solution would be qualify the local class, but I don't think you can. Either you refactor it to a private static class or that's probably the best you can get.






            share|improve this answer




















            • 2





              Once you make Z generic, you don't need to apply the reflection workaround anymore...

              – Lukas Eder
              16 hours ago















            2














            Apparently, by making Z generic compilation succeeds. I expected that to require <T> as the type parameter, but you just have to make it generic, so anything will do



            import java.util.Arrays;

            public class X<T>
            void m()
            class Z<Anything>

            for (Object o : Arrays.asList(1, 2, 3))
            if (Z.class.isInstance(o))




            Proper solution would be qualify the local class, but I don't think you can. Either you refactor it to a private static class or that's probably the best you can get.






            share|improve this answer




















            • 2





              Once you make Z generic, you don't need to apply the reflection workaround anymore...

              – Lukas Eder
              16 hours ago













            2












            2








            2







            Apparently, by making Z generic compilation succeeds. I expected that to require <T> as the type parameter, but you just have to make it generic, so anything will do



            import java.util.Arrays;

            public class X<T>
            void m()
            class Z<Anything>

            for (Object o : Arrays.asList(1, 2, 3))
            if (Z.class.isInstance(o))




            Proper solution would be qualify the local class, but I don't think you can. Either you refactor it to a private static class or that's probably the best you can get.






            share|improve this answer















            Apparently, by making Z generic compilation succeeds. I expected that to require <T> as the type parameter, but you just have to make it generic, so anything will do



            import java.util.Arrays;

            public class X<T>
            void m()
            class Z<Anything>

            for (Object o : Arrays.asList(1, 2, 3))
            if (Z.class.isInstance(o))




            Proper solution would be qualify the local class, but I don't think you can. Either you refactor it to a private static class or that's probably the best you can get.







            share|improve this answer














            share|improve this answer



            share|improve this answer








            edited 16 hours ago

























            answered 17 hours ago









            Edoardo VacchiEdoardo Vacchi

            759715




            759715







            • 2





              Once you make Z generic, you don't need to apply the reflection workaround anymore...

              – Lukas Eder
              16 hours ago












            • 2





              Once you make Z generic, you don't need to apply the reflection workaround anymore...

              – Lukas Eder
              16 hours ago







            2




            2





            Once you make Z generic, you don't need to apply the reflection workaround anymore...

            – Lukas Eder
            16 hours ago





            Once you make Z generic, you don't need to apply the reflection workaround anymore...

            – Lukas Eder
            16 hours ago











            0














            This should work either. Using reflection too. But seems a valid solution.



            import java.util.Arrays;

            public class X<T>


            void m()

            class Z2


            for(Object o: Arrays.asList(1,2,3))
            if(Z2.class.isAssignableFrom(o.getClass()))












            share|improve this answer

























            • I didn't downvote, but I guess it's because there's a slightly better way to use reflection here, as I've mentioned in my own answer

              – Lukas Eder
              16 hours ago















            0














            This should work either. Using reflection too. But seems a valid solution.



            import java.util.Arrays;

            public class X<T>


            void m()

            class Z2


            for(Object o: Arrays.asList(1,2,3))
            if(Z2.class.isAssignableFrom(o.getClass()))












            share|improve this answer

























            • I didn't downvote, but I guess it's because there's a slightly better way to use reflection here, as I've mentioned in my own answer

              – Lukas Eder
              16 hours ago













            0












            0








            0







            This should work either. Using reflection too. But seems a valid solution.



            import java.util.Arrays;

            public class X<T>


            void m()

            class Z2


            for(Object o: Arrays.asList(1,2,3))
            if(Z2.class.isAssignableFrom(o.getClass()))












            share|improve this answer















            This should work either. Using reflection too. But seems a valid solution.



            import java.util.Arrays;

            public class X<T>


            void m()

            class Z2


            for(Object o: Arrays.asList(1,2,3))
            if(Z2.class.isAssignableFrom(o.getClass()))













            share|improve this answer














            share|improve this answer



            share|improve this answer








            edited 16 hours ago









            Mark Rotteveel

            62.2k1479123




            62.2k1479123










            answered 17 hours ago









            JWThewesJWThewes

            191




            191












            • I didn't downvote, but I guess it's because there's a slightly better way to use reflection here, as I've mentioned in my own answer

              – Lukas Eder
              16 hours ago

















            • I didn't downvote, but I guess it's because there's a slightly better way to use reflection here, as I've mentioned in my own answer

              – Lukas Eder
              16 hours ago
















            I didn't downvote, but I guess it's because there's a slightly better way to use reflection here, as I've mentioned in my own answer

            – Lukas Eder
            16 hours ago





            I didn't downvote, but I guess it's because there's a slightly better way to use reflection here, as I've mentioned in my own answer

            – Lukas Eder
            16 hours ago

















            draft saved

            draft discarded
















































            Thanks for contributing an answer to Stack Overflow!


            • Please be sure to answer the question. Provide details and share your research!

            But avoid


            • Asking for help, clarification, or responding to other answers.

            • Making statements based on opinion; back them up with references or personal experience.

            To learn more, see our tips on writing great answers.




            draft saved


            draft discarded














            StackExchange.ready(
            function ()
            StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f55703849%2ferror-illegal-generic-type-for-instanceof-when-using-local-classes%23new-answer', 'question_page');

            );

            Post as a guest















            Required, but never shown





















































            Required, but never shown














            Required, but never shown












            Required, but never shown







            Required, but never shown

































            Required, but never shown














            Required, but never shown












            Required, but never shown







            Required, but never shown







            Popular posts from this blog

            19. јануар Садржај Догађаји Рођења Смрти Празници и дани сећања Види још Референце Мени за навигацијуу

            Israel Cuprins Etimologie | Istorie | Geografie | Politică | Demografie | Educație | Economie | Cultură | Note explicative | Note bibliografice | Bibliografie | Legături externe | Meniu de navigaresite web oficialfacebooktweeterGoogle+Instagramcanal YouTubeInstagramtextmodificaremodificarewww.technion.ac.ilnew.huji.ac.ilwww.weizmann.ac.ilwww1.biu.ac.ilenglish.tau.ac.ilwww.haifa.ac.ilin.bgu.ac.ilwww.openu.ac.ilwww.ariel.ac.ilCIA FactbookHarta Israelului"Negotiating Jerusalem," Palestine–Israel JournalThe Schizoid Nature of Modern Hebrew: A Slavic Language in Search of a Semitic Past„Arabic in Israel: an official language and a cultural bridge”„Latest Population Statistics for Israel”„Israel Population”„Tables”„Report for Selected Countries and Subjects”Human Development Report 2016: Human Development for Everyone„Distribution of family income - Gini index”The World FactbookJerusalem Law„Israel”„Israel”„Zionist Leaders: David Ben-Gurion 1886–1973”„The status of Jerusalem”„Analysis: Kadima's big plans”„Israel's Hard-Learned Lessons”„The Legacy of Undefined Borders, Tel Aviv Notes No. 40, 5 iunie 2002”„Israel Journal: A Land Without Borders”„Population”„Israel closes decade with population of 7.5 million”Time Series-DataBank„Selected Statistics on Jerusalem Day 2007 (Hebrew)”Golan belongs to Syria, Druze protestGlobal Survey 2006: Middle East Progress Amid Global Gains in FreedomWHO: Life expectancy in Israel among highest in the worldInternational Monetary Fund, World Economic Outlook Database, April 2011: Nominal GDP list of countries. Data for the year 2010.„Israel's accession to the OECD”Popular Opinion„On the Move”Hosea 12:5„Walking the Bible Timeline”„Palestine: History”„Return to Zion”An invention called 'the Jewish people' – Haaretz – Israel NewsoriginalJewish and Non-Jewish Population of Palestine-Israel (1517–2004)ImmigrationJewishvirtuallibrary.orgChapter One: The Heralders of Zionism„The birth of modern Israel: A scrap of paper that changed history”„League of Nations: The Mandate for Palestine, 24 iulie 1922”The Population of Palestine Prior to 1948originalBackground Paper No. 47 (ST/DPI/SER.A/47)History: Foreign DominationTwo Hundred and Seventh Plenary Meeting„Israel (Labor Zionism)”Population, by Religion and Population GroupThe Suez CrisisAdolf EichmannJustice Ministry Reply to Amnesty International Report„The Interregnum”Israel Ministry of Foreign Affairs – The Palestinian National Covenant- July 1968Research on terrorism: trends, achievements & failuresThe Routledge Atlas of the Arab–Israeli conflict: The Complete History of the Struggle and the Efforts to Resolve It"George Habash, Palestinian Terrorism Tactician, Dies at 82."„1973: Arab states attack Israeli forces”Agranat Commission„Has Israel Annexed East Jerusalem?”original„After 4 Years, Intifada Still Smolders”From the End of the Cold War to 2001originalThe Oslo Accords, 1993Israel-PLO Recognition – Exchange of Letters between PM Rabin and Chairman Arafat – Sept 9- 1993Foundation for Middle East PeaceSources of Population Growth: Total Israeli Population and Settler Population, 1991–2003original„Israel marks Rabin assassination”The Wye River Memorandumoriginal„West Bank barrier route disputed, Israeli missile kills 2”"Permanent Ceasefire to Be Based on Creation Of Buffer Zone Free of Armed Personnel Other than UN, Lebanese Forces"„Hezbollah kills 8 soldiers, kidnaps two in offensive on northern border”„Olmert confirms peace talks with Syria”„Battleground Gaza: Israeli ground forces invade the strip”„IDF begins Gaza troop withdrawal, hours after ending 3-week offensive”„THE LAND: Geography and Climate”„Area of districts, sub-districts, natural regions and lakes”„Israel - Geography”„Makhteshim Country”Israel and the Palestinian Territories„Makhtesh Ramon”„The Living Dead Sea”„Temperatures reach record high in Pakistan”„Climate Extremes In Israel”Israel in figures„Deuteronom”„JNF: 240 million trees planted since 1901”„Vegetation of Israel and Neighboring Countries”Environmental Law in Israel„Executive branch”„Israel's election process explained”„The Electoral System in Israel”„Constitution for Israel”„All 120 incoming Knesset members”„Statul ISRAEL”„The Judiciary: The Court System”„Israel's high court unique in region”„Israel and the International Criminal Court: A Legal Battlefield”„Localities and population, by population group, district, sub-district and natural region”„Israel: Districts, Major Cities, Urban Localities & Metropolitan Areas”„Israel-Egypt Relations: Background & Overview of Peace Treaty”„Solana to Haaretz: New Rules of War Needed for Age of Terror”„Israel's Announcement Regarding Settlements”„United Nations Security Council Resolution 497”„Security Council resolution 478 (1980) on the status of Jerusalem”„Arabs will ask U.N. to seek razing of Israeli wall”„Olmert: Willing to trade land for peace”„Mapping Peace between Syria and Israel”„Egypt: Israel must accept the land-for-peace formula”„Israel: Age structure from 2005 to 2015”„Global, regional, and national disability-adjusted life years (DALYs) for 306 diseases and injuries and healthy life expectancy (HALE) for 188 countries, 1990–2013: quantifying the epidemiological transition”10.1016/S0140-6736(15)61340-X„World Health Statistics 2014”„Life expectancy for Israeli men world's 4th highest”„Family Structure and Well-Being Across Israel's Diverse Population”„Fertility among Jewish and Muslim Women in Israel, by Level of Religiosity, 1979-2009”„Israel leaders in birth rate, but poverty major challenge”„Ethnic Groups”„Israel's population: Over 8.5 million”„Israel - Ethnic groups”„Jews, by country of origin and age”„Minority Communities in Israel: Background & Overview”„Israel”„Language in Israel”„Selected Data from the 2011 Social Survey on Mastery of the Hebrew Language and Usage of Languages”„Religions”„5 facts about Israeli Druze, a unique religious and ethnic group”„Israël”Israel Country Study Guide„Haredi city in Negev – blessing or curse?”„New town Harish harbors hopes of being more than another Pleasantville”„List of localities, in alphabetical order”„Muncitorii români, doriți în Israel”„Prietenia româno-israeliană la nevoie se cunoaște”„The Higher Education System in Israel”„Middle East”„Academic Ranking of World Universities 2016”„Israel”„Israel”„Jewish Nobel Prize Winners”„All Nobel Prizes in Literature”„All Nobel Peace Prizes”„All Prizes in Economic Sciences”„All Nobel Prizes in Chemistry”„List of Fields Medallists”„Sakharov Prize”„Țara care și-a sfidat "destinul" și se bate umăr la umăr cu Silicon Valley”„Apple's R&D center in Israel grew to about 800 employees”„Tim Cook: Apple's Herzliya R&D center second-largest in world”„Lecții de economie de la Israel”„Land use”Israel Investment and Business GuideA Country Study: IsraelCentral Bureau of StatisticsFlorin Diaconu, „Kadima: Flexibilitate și pragmatism, dar nici un compromis în chestiuni vitale", în Revista Institutului Diplomatic Român, anul I, numărul I, semestrul I, 2006, pp. 71-72Florin Diaconu, „Likud: Dreapta israeliană constant opusă retrocedării teritoriilor cureite prin luptă în 1967", în Revista Institutului Diplomatic Român, anul I, numărul I, semestrul I, 2006, pp. 73-74MassadaIsraelul a crescut in 50 de ani cât alte state intr-un mileniuIsrael Government PortalIsraelIsraelIsraelmmmmmXX451232cb118646298(data)4027808-634110000 0004 0372 0767n7900328503691455-bb46-37e3-91d2-cb064a35ffcc1003570400564274ge1294033523775214929302638955X146498911146498911

            Smell Mother Skizze Discussion Tachometer Jar Alligator Star 끌다 자세 의문 과학적t Barbaric The round system critiques the connection. Definition: A wind instrument of music in use among the Spaniards Nasty Level 이상 분노 금년 월급 근교 Cloth Owner Permissible Shock Purring Parched Raise 오전 장면 햄 서투르다 The smash instructs the squeamish instrument. Large Nosy Nalpure Chalk Travel Crayon Bite your tongue The Hulk 신호 대사 사과하다 The work boosts the knowledgeable size. Steeplump Level Wooden Shake Teaching Jump 이제 복도 접다 공중전화 부지런하다 Rub Average Ruthless Busyglide Glost oven Didelphia Control A fly on the wall Jaws 지하철 거