交叉编译中的build,host,target

【实例】
当前我有一个x86计算机,它上面工具很全,至少有gcc。这时我有了一个arm处理器的上网本。

我想为我的arm上网本写点程序,但是因为上网本性能很差我不想在arm上开发编译,于是我就想在自己电脑上开发然后copy过去给他用。这时我就需要一个在我的x86 (build)上编译一个“可以在我x86 (host)本机上运行的gcc,这个新gcc编出来的程序是可以在arm (target)上运行的”。 此时选项为 build=x86,host=x86,target = arm。
此时我用这个gcc编译一个helloworld,这个helloworld的build=x86,host=arm

后来我又得到了一个超强服务器计算机,假设框架叫Super。我想用服务器编译比用我的x86要快的多,于是我就想在Super上用Gcc编译arm程序。但是我怎么得到在Super上能跑起来的gcc呢?当然是自己编译。于是我就需要在我的x86 (build)上编译一个能在Super (host)上运行的gcc,而且它编出来的程序是在arm (target)上运行。此时选项为 build=x86,host=Super,target = arm。
此时我用这个gcc编译一个helloworld,这个helloworld的build=Super,host=arm

【build】当前你使用的计算机。

【host】你的目的是编译出来的程序可以在host上运行。

【target】普通程序没有这个概念。对于想编译出编译器的人来说此属性决定了新编译器编译出的程序可以运行在哪!


转自:http://blog.csdn.net/chrisniu1984/article/details/6620709

你可能感兴趣的:(交叉编译中的build,host,target)