Is objective C 2.0 a proper superset of C?

安稳与你 提交于 2019-11-28 01:57:24

nil is not a keyword. nil is defined in objc.h [on Mac OS X] (and __DARWIN_NULL is really just NULL):

#ifndef nil
#define nil __DARWIN_NULL   /* id of Nil instance */
#endif

That is, nil isn't really part of the compiled language, but a convention used during compilation that is perpetuated by the system libraries.

Splitting hairs, obviously. You really could compile Objective-C source without nil, though.

It is akin to asking "Can I write a tool that has variables named deflate while still using the zlib.h interface?". Sure. But it'll be ugly.

And, in fact, the compiler does not automatically include objc.h. This:

#include <stdio.h>

int main() {
    int nil = 5;
    fprintf(stdout, "Hello %d\n", nil);
    return 0;
}

Compiles and runs just fine in a standard Foundation tool project (in the main.m) once you remove the precompiled/prefix header that imports Foundation and, hence, objc.h. (So, yes, out of the box, the Xcode templates do cause objc.h to be imported by way of importing Cocoa/Cocoa.h or Foundation/Foundation.h.)

Objective-C a proper superset of C, as everything that works in C will work with Objective-C.

BUT,

as it is a superset, it adds some new types, definitions and directives.

That means that if you use a reserved definition like nil, you are getting into serious trouble.

That's why the above program does not compile.

易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!