如何在最新版本的 Ubuntu下(14.10)来安装、编译Objective-C?php
Ubuntu已经有了对Objective-C的编译器(gobjc)的安装,所以安装gobjc的步骤可省,若是你用的Ubuntu的旁系系统没有安装可使用如下命令进行安装:html
sudo apt-get install gobjc
接下来,咱们主要就是对gnustep库的安装。对OS X或iOS编程过的朋友应该对Foundation库不陌生吧,这个就是在gnustep库里的,若是不装此库,你连NSObject都用不了,呼呼~先安装gnustep:编程
sudo apt-get install gnustep
完成以后,咱们再安装gnustep-devel:bash
sudo apt-get install gnustep-devel
这样整个须要安装的环境都安装好了。咱们下面就能够写段代码进行编译了。app
在编译以前,咱们进入 /usr/share/GNUstep/Makefiles 目录,来对编译环境进行设置,在当前控制台(terminal)执行:编程语言
sudo bash /usr/share/GNUstep/Makefiles/GNUstep.sh
这样,当前控制台的GNUStep的编译环境就创建好了。而后咱们准备作个项目工程,能够在任意地方新建一个文件夹。而后在里面先创建一个main.m文件:函数
#import <Foundation/Foundation.h> int main(void) { NSAutoreleasePool *pool = [[NSAutoreleasePool alloc] init]; NSLog(@"Hello, world!"); unichar c = u'加'; NSLog(@"The character is: %C", c); [pool drain]; }
以后,咱们在同一文件夹下建立一个make文件,命名为:GNUmakefile(无后缀):ui
GNUSTEP_MAKEFILES = /usr/share/GNUstep/Makefiles include $(GNUSTEP_MAKEFILES)/common.make ADDITIONAL_FLAGS += -std=gnu11 TOOL_NAME = test test_OBJC_FILES = main.m include $(GNUSTEP_MAKEFILES)/tool.make
因为咱们在源代码中使用了C11标准中才引入的Unicode前缀字面量表达式——u'加',表示一个UTF-16字符,所以咱们在GNUmakefile中也加入了-std=gnu11这个编译选项来使得编译器使用最新的C11标准与GNU规范语法扩展。spa
这里要注意的是,对于其它Linux版本的系统,GNUStep的默认安装路径可能不是在/usr/share/之中,所以须要根据当前 GNUStep/Makefiles的路径对GNUSTEP_MAKEFILES进行设置。并且这个变量必须在include以前定义好。命令行
而下面的TOOL_NAME指定了make以后最终的目标可执行文件名。这里命名为test。
完了以后,若是咱们以前已经执行过GNUstep.sh,那么能够直接敲make,而后回车。工程即构建完成。若是有“gcc: error trying to exec 'cc1obj': execvp: No such file or directory”之类的错误,那么说明还须要安装gobjc。
下面提供其它参考连接:
http://www.techotopia.com/index.php/Installing_and_Using_GNUstep_and_Objective-C_on_Linux
http://www.gnustep.org/resources/documentation/Developer/Base/ProgrammingManual/manual_1.html#SEC11
这里注意,对于第一个连接中,若是直接在命令行敲gcc,是没法成功经过链接的,由于gnustep的库都找不到。因此最好的方式仍是经过利用makefile来解决问题,呼呼~
下面在提一下Objective-C与纯C以及汇编混编的状况。因为GNUStep提供的makefile package仅仅提供了C、C++、Objective-C以及Objective-C++这四种编程语言,而不支持汇编语言,所以,若是要在 GNUStep工程中使用汇编,我这里的作法是将汇编文件单独编译成.o目标文件,而后再跟其它makefile编译好的目标文件进行链接。下面列出了对 几种源文件类型的支持(其中,斜体的appname就是你最终输出可执行文件的名称):
一、appname_C_FILES
: C源文件,通常是.c
二、appname_OBJC_FILES
:Objective-C源文件,通常是.m
三、appname_CC_FILES
:C++源文件,通常是.cpp或.cc
四、appname_OBJCC_FILES:Objective-C++源文件,通常是.mm
以上这些变量后面就跟着相应的要编译的源文件名,多个源文件名之间用空格分隔。
其他一些可用的make变量见以下连接:
下面将举一个例子来讲明将一个Objective-C源文件与汇编文件一块儿链接成最终的可执行文件。
Objective-C源文件(main.m)以下:
#import <Foundation/Foundation.h> extern int __attribute__((fastcall)) MyASMFunc(int a, int b); int main(void) { NSAutoreleasePool *pool = [[NSAutoreleasePool alloc] init]; NSLog(@"Hello, world!"); unichar c = u'加'; NSLog(@"The character is: %C", c); NSLog(@"The value is: %d", MyASMFunc(10, 20)); [pool drain]; }
这里,__attribute__((fastcall))使得MyASMFunc函数的参数与返回值都能经过寄存器进行传递,这样方便汇编过程的实现。
下面是汇编文件(hello.s):
.text .align 2 .globl MyASMFunc MyASMFunc: // ECX contains the first parameter // EDX contains the second parameter mov %ecx, %eax add %edx, %eax ret
汇编文件hello.s写完以后,能够先用gcc将其汇编成目标文件hello.o,而后咱们能够写GNUmakefile:
GNUSTEP_MAKEFILES = /usr/share/GNUstep/Makefiles include $(GNUSTEP_MAKEFILES)/common.make ADDITIONAL_FLAGS += -std=gnu11 TOOL_NAME = test test_OBJC_FILES = main.m include $(GNUSTEP_MAKEFILES)/tool.make ALL_LDFLAGS += hello.o