Sign Up

Sign Up to our social questions and Answers Engine to ask questions, answer people’s questions, and connect with other people.

Have an account? Sign In

Have an account? Sign In Now

Sign In

Login to our social questions & Answers Engine to ask questions answer people’s questions & connect with other people.

Sign Up Here

Forgot Password?

Don't have account, Sign Up Here

Forgot Password

Lost your password? Please enter your email address. You will receive a link and will create a new password via email.

Have an account? Sign In Now

You must login to ask a question.

Forgot Password?

Need An Account, Sign Up Here

Please briefly explain why you feel this question should be reported.

Please briefly explain why you feel this answer should be reported.

Please briefly explain why you feel this user should be reported.

Sign InSign Up

The Archive Base

The Archive Base Logo The Archive Base Logo

The Archive Base Navigation

  • SEARCH
  • Home
  • About Us
  • Blog
  • Contact Us
Search
Ask A Question

Mobile menu

Close
Ask a Question
  • Home
  • Add group
  • Groups page
  • Feed
  • User Profile
  • Communities
  • Questions
    • New Questions
    • Trending Questions
    • Must read Questions
    • Hot Questions
  • Polls
  • Tags
  • Badges
  • Buy Points
  • Users
  • Help
  • Buy Theme
  • SEARCH
Home/ Questions/Q 864799
In Process

The Archive Base Latest Questions

Editorial Team
  • 0
Editorial Team
Asked: May 15, 20262026-05-15T09:32:19+00:00 2026-05-15T09:32:19+00:00

In Objective-C, you can invoke class methods with: [MyClass aClassMethod]; And you can query

  • 0

In Objective-C, you can invoke class methods with:

[MyClass aClassMethod];

And you can query an instance’s kind with:

[someInstance isKindOfClass:[MyClass class]];

But, why do we need to do [MyClass class], and not simply provide MyClass like this:

[someInstance isKindOfClass:MyClass];

Is there a reason that the compiler is fine with encountering MyClass as a receiver (a pointer type) but not as an argument? Is it a limitation of parsing the language? Or perhaps a limitation of the compiler?

  • 1 1 Answer
  • 0 Views
  • 0 Followers
  • 0
Share
  • Facebook
  • Report

Leave an answer
Cancel reply

You must login to add an answer.

Forgot Password?

Need An Account, Sign Up Here

1 Answer

  • Voted
  • Oldest
  • Recent
  • Random
  1. Editorial Team
    Editorial Team
    2026-05-15T09:32:20+00:00Added an answer on May 15, 2026 at 9:32 am

    Ooooh… fun question. The answer is a c-ism.

    Consider:

    @interface MyClass : NSObject
    @end
    @implementation MyClass
    @end
    

    Now, say you have:

    ...
    MyClass *m = nil;
    ...
    

    In that context, the compiler sees MyClass as a type definition. The * says that the variable m is a pointer to a hunk o' memory that contains one (or many -- don't forget your C pointer-fu) MyClass instances.

    In other words, MyClass is a type.

    But, in the context of something like:

    [someInstance isKindOfClass: x ];
    

    x must be an rvalue or, in human terms, the value of an expression. A type, however, cannot be used as an rvalue.

    That [MyClass class] works is actually a bit of a hack, both in the language and the compiler in that the grammar specifically allows a type name to be the message receiver (to be the target of a method call).

    And, as a matter of fact, you can do:

    typedef MyClass Foo;
    ....
    [MyClass class];
    [Foo Class];
    

    It’ll all work. However, you can’t do the following but the error message is illuminating:

    [NSUInteger class];
    

    error: ‘NSUInteger’ is not an Objective-C class name or alias


    Now, why not special case it everywhere as a bare name?

    That colludes type names and rvalues and you quickly end up having to swallow something like [foo isKindOfClass: (MyClass)]; while barfing on [foo isKindOfClass: (MyClass *)]; which then encroaches upon typecasting territory in a rather uncomfortable fashion.

    • 0
    • Reply
    • Share
      Share
      • Share on Facebook
      • Share on Twitter
      • Share on LinkedIn
      • Share on WhatsApp
      • Report

Sidebar

Related Questions

How can I invoke a method at runtime on an Objective-C class when all
In Objective-C, I have a base class A, with instance method -(void) doSomething. Class
Can anyone please explain me what does @class declaration do in Objective-C and what
I see many Objective-C/Cocoa SDK apis where you can specify a target and an
I'm currently writing an Objective-C class which has a relatively complex method in its
I'd like to override a method in an Objective C class that I don't
I'd like to override a method in an Objective C class that I don't
I am java and php programmer. In java i can use static class/method so
In Objective-C you can say something like: NSArray *anArray = [NSArray arrayWithObjects:obj,obj2, nil]; In
so in Objective-C I can have a reference to object that implements certain protocol

Explore

  • Home
  • Add group
  • Groups page
  • Communities
  • Questions
    • New Questions
    • Trending Questions
    • Must read Questions
    • Hot Questions
  • Polls
  • Tags
  • Badges
  • Users
  • Help
  • SEARCH

Footer

© 2021 The Archive Base. All Rights Reserved
With Love by The Archive Base

Insert/edit link

Enter the destination URL

Or link to existing content

    No search term specified. Showing recent items. Search or use up and down arrow keys to select an item.