

执行编译、链接嵌入式软件的计算机
运行嵌入式软件的硬件平台
用来生成在与编译器本身所在的计算机和操作系统(平台)相同的环境下运行的目标代码,例如 Windows 环境生成 Windows 目标代码。
用来生成在其它平台上运行的目标代码,例如 Windows
编译器命名规则
例: arm-none-eabi-gcc
用于编译 ARM 架构的裸机系统
例:arm-none-linux-gnueabi-gcc
用于基于 ARM 架构的 Linux 系统,基于GCC,使用 Glibc 库
经过Codesourcery 公司优化过推出的编译器,用于编译 ARM 架构的 u-boot、Linux内核、linux应用等。
几个重要目录:
编译器工具所在目录:FriendlyARM/toolchain/4.9.3/bin

编译器头文件所在目录:FriendlyARM/toolchain/4.9.3/arm-cortexa9-linux-gnueabihf/sys-root/usr/include
库文件所在目录:FriendlyARM/toolchain/4.9.3/arm-cortexa9-linux-gnueabihf/sys-root/usr/lib
编译器下载及安装
可以去官网下载,http://www.linaro.org/downloads/
但是速度比较慢,可以直接用我下载好的。
链接: https://pan.baidu.com/s/1jL_G6kbTC9h_bF8HHXBWxw 提取码: 67u4
1.先把下载好的安装包移动到根目录下的tmp目录中(/tmp)
2.使用tar命令解压安装包,即在Terminal中输入以下命令:(前面的sudo表示使用root权限执行该命令)
sudo tar -xjvf /tmp/arm-linux-gcc-4.6.4-arm-x86_64.tar.bz2 -C /
注意是大写的字母C,此命令会把安装包解压到根目录下的opt的TuxamitoSoftToolchains里面(/opt/TuxamitoSoftToolchains)
3.解压完成后,再在(/usr/local)中创建一个新目录arm,即在Terminal中输入以下命令:
sudo mkdir /usr/local/arm
创建arm目录成功后,还需要给它解放全部权限,即在Terminal中输入以下命令:
sudo chmod 777 /usr/local/arm
4.在解压出来的目录中找到并把整个gcc-4.6.4目录复制到刚刚建好的arm目录中,命令如下:
先cd切换到gcc-4.6.4所在目录(切换后先ls看一下有没有gcc-4.6.4目录):
cd /opt/TuxamitoSoftToolchains/arm-arm1176jzfssf-linux-gnueabi/
在执行 cp 复制命令,-r 表示整个目录以及里面的任何东西
sudo cp -r gcc-4.6.4 /usr/local/arm
5.打开(/etc/profile)配置环境变量和库变量,目的是以后可以在任何位置使用该交叉编译器,命令如下:
sudo vi /etc/profile
用vi或者vim打开后,在文件最后添加两行,并输入以下代码:第一行是添加执行程序的环境变量,第二行是库文件的路径
export PATH=$PATH:/usr/local/arm/gcc-4.6.4/bin
export LD_LIBRARY_PATH=$LD_LIBRARY_PATH:/usr/local/arm/gcc-4.6.4/lib
然后保存退出即可。

6.使用source命令重新加载生效该配置文件
source /etc/profile
1
7.检验是否安装成功,在 Terminal 输入以下命令输出版本信息:
arm-linux-gcc -v

arm-linux-gcc语法形式:arm-linux-gcc [ option | filename ]...
通常情况下,产生一个新的程序需要经过四个阶段:预处理、编译、汇编,链接
当然我们可以通过参数决定该编译操作执行到何步结束
参数繁多,在Linux环境下寻求帮助:man arm-linux -gcc
例:arm-linux -gcc -E hello.c -o hello1.c

预处理后,hello1.c 中的内容:

例: arm-linux -gcc -S hello.c
上例中就会产生一个汇编文件 hello.s

-c
只对文件进行编译和汇编,但是并不进行链接,也就是说只把程序做成 obj 文件。
例: arm-linux -gcc -c hello.c –o hello.o
-o
指定目标名称,缺省的时候,gcc 编译出来的文件是 a.out
例:
arm-linux -gcc hello.c 默认编译出 hello.out
arm-linux -gcc -o hello.bin hello.c 指定目标名词是 hello.bin
arm-linux -gcc -o hello.s -S hello.c
-include file
包含某个代码,简单来说,就是编译某个文件时需要另一个文件的时候,就可以用它设定,功能就相当于在代码中使用#include。
例:arm-linux -gcc hello.c -include type.h
-I dir
如果使用#include"file"的时候,gcc/g++ 会先在当前目录查找你所指定的头文件,如果没有找到,编译器会到缺省的头文件目录找;
如果使用-I指定了目录, 编译器会先到你所指定的目录查找,然后再按常规的顺序去找。
例: arm-linux -gcc -o hello -I/xxx/include hello.c
-I
就是取消前一个参数的功能,所以一般在-I dir之后使用

-iprefix prefix 和 -iwithprefix dir
这两个参数一般一起使用,当-I的目录查找失败,会到prefix+dir下查找
-l库名
指定编译的时候使用的库(静态库.a / 动态库.so)
例:arm-linux-gcc -lpthread hello.c
指定用到了 phtread.c 库
-L目录
指定编译的时候,搜索库的路径。比如自己的库,就可以用-L指定到你的库所在的目录,不然编译器将只在标准库的目录找。这个dir就是目录的名称。
例:arm-linux-gcc –L./ hello.c –o hello

gcc 优化
gcc 提供了为了满足用户不同程度的的优化需要,提供了近百种优化选项,用来对 {编译时间,目标文件长度,执行效率} 这个三维模型进行不同的取舍和平衡。优化的方法不一而足,总体上将有以下几类:
精简操作指令;
尽量满足cpu的流水操作;
通过对程序行为的猜测,重新调整代码的执行顺序;
充分使用寄存器;
对简单的调用进行展开等
-O0,-O1,-O2,-O3
O0:不做任何优化,这是默认的编译选项
O3:优化级别最高
-g
例:arm-linux –gcc –o hello -g hello.c

(1) 看门狗部件属于(硬件模块),其核心功能为(侦测软件代码跑飞)和(当系统“跑飞”而进入死循环时,恢复系统的运行)。
(2) 假设C程序代码 fun.c,将其编译成目标代码 fun.o,编译命令为arm-linux-gcc -c fun.c -o fun.o;如果 fun.c 使用了库函数 libcurses.a,将其和 main.c 一起编译成可执行文件 smartfun,则编译命令为arm-linux-gcc -c fun.c main.c -lcurses -o smartfun。
我正在学习如何使用Nokogiri,根据这段代码我遇到了一些问题:require'rubygems'require'mechanize'post_agent=WWW::Mechanize.newpost_page=post_agent.get('http://www.vbulletin.org/forum/showthread.php?t=230708')puts"\nabsolutepathwithtbodygivesnil"putspost_page.parser.xpath('/html/body/div/div/div/div/div/table/tbody/tr/td/div
我有一个Ruby程序,它使用rubyzip压缩XML文件的目录树。gem。我的问题是文件开始变得很重,我想提高压缩级别,因为压缩时间不是问题。我在rubyzipdocumentation中找不到一种为创建的ZIP文件指定压缩级别的方法。有人知道如何更改此设置吗?是否有另一个允许指定压缩级别的Ruby库? 最佳答案 这是我通过查看rubyzip内部创建的代码。level=Zlib::BEST_COMPRESSIONZip::ZipOutputStream.open(zip_file)do|zip|Dir.glob("**/*")d
类classAprivatedeffooputs:fooendpublicdefbarputs:barendprivatedefzimputs:zimendprotecteddefdibputs:dibendendA的实例a=A.new测试a.foorescueputs:faila.barrescueputs:faila.zimrescueputs:faila.dibrescueputs:faila.gazrescueputs:fail测试输出failbarfailfailfail.发送测试[:foo,:bar,:zim,:dib,:gaz].each{|m|a.send(m)resc
很好奇,就使用rubyonrails自动化单元测试而言,你们正在做什么?您是否创建了一个脚本来在cron中运行rake作业并将结果邮寄给您?git中的预提交Hook?只是手动调用?我完全理解测试,但想知道在错误发生之前捕获错误的最佳实践是什么。让我们理所当然地认为测试本身是完美无缺的,并且可以正常工作。下一步是什么以确保他们在正确的时间将可能有害的结果传达给您? 最佳答案 不确定您到底想听什么,但是有几个级别的自动代码库控制:在处理某项功能时,您可以使用类似autotest的内容获得关于哪些有效,哪些无效的即时反馈。要确保您的提
假设我做了一个模块如下:m=Module.newdoclassCendend三个问题:除了对m的引用之外,还有什么方法可以访问C和m中的其他内容?我可以在创建匿名模块后为其命名吗(就像我输入“module...”一样)?如何在使用完匿名模块后将其删除,使其定义的常量不再存在? 最佳答案 三个答案:是的,使用ObjectSpace.此代码使c引用你的类(class)C不引用m:c=nilObjectSpace.each_object{|obj|c=objif(Class===objandobj.name=~/::C$/)}当然这取决于
我正在尝试使用ruby和Savon来使用网络服务。测试服务为http://www.webservicex.net/WS/WSDetails.aspx?WSID=9&CATID=2require'rubygems'require'savon'client=Savon::Client.new"http://www.webservicex.net/stockquote.asmx?WSDL"client.get_quotedo|soap|soap.body={:symbol=>"AAPL"}end返回SOAP异常。检查soap信封,在我看来soap请求没有正确的命名空间。任何人都可以建议我
关闭。这个问题是opinion-based.它目前不接受答案。想要改进这个问题?更新问题,以便editingthispost可以用事实和引用来回答它.关闭4年前。Improvethisquestion我想在固定时间创建一系列低音和高音调的哔哔声。例如:在150毫秒时发出高音调的蜂鸣声在151毫秒时发出低音调的蜂鸣声200毫秒时发出低音调的蜂鸣声250毫秒的高音调蜂鸣声有没有办法在Ruby或Python中做到这一点?我真的不在乎输出编码是什么(.wav、.mp3、.ogg等等),但我确实想创建一个输出文件。
我在我的项目目录中完成了compasscreate.和compassinitrails。几个问题:我已将我的.sass文件放在public/stylesheets中。这是放置它们的正确位置吗?当我运行compasswatch时,它不会自动编译这些.sass文件。我必须手动指定文件:compasswatchpublic/stylesheets/myfile.sass等。如何让它自动运行?文件ie.css、print.css和screen.css已放在stylesheets/compiled。如何在编译后不让它们重新出现的情况下删除它们?我自己编译的.sass文件编译成compiled/t
我想将html转换为纯文本。不过,我不想只删除标签,我想智能地保留尽可能多的格式。为插入换行符标签,检测段落并格式化它们等。输入非常简单,通常是格式良好的html(不是整个文档,只是一堆内容,通常没有anchor或图像)。我可以将几个正则表达式放在一起,让我达到80%,但我认为可能有一些现有的解决方案更智能。 最佳答案 首先,不要尝试为此使用正则表达式。很有可能你会想出一个脆弱/脆弱的解决方案,它会随着HTML的变化而崩溃,或者很难管理和维护。您可以使用Nokogiri快速解析HTML并提取文本:require'nokogiri'h
我想为Heroku构建一个Rails3应用程序。他们使用Postgres作为他们的数据库,所以我通过MacPorts安装了postgres9.0。现在我需要一个postgresgem并且共识是出于性能原因你想要pggem。但是我对我得到的错误感到非常困惑当我尝试在rvm下通过geminstall安装pg时。我已经非常明确地指定了所有postgres目录的位置可以找到但仍然无法完成安装:$envARCHFLAGS='-archx86_64'geminstallpg--\--with-pg-config=/opt/local/var/db/postgresql90/defaultdb/po