array(2) { ["docs"]=> array(10) { [0]=> array(10) { ["id"]=> string(3) "428" ["text"]=> string(77) "Visual Studio 2017 单独启动MSDN帮助(Microsoft Help Viewer)的方法" ["intro"]=> string(288) "目录 ECharts 异步加载 ECharts 数据可视化在过去几年中取得了巨大进展。开发人员对可视化产品的期望不再是简单的图表创建工具,而是在交互、性能、数据处理等方面有更高的要求。 chart.setOption({ color: [ " ["username"]=> string(8) "DonetRen" ["tagsname"]=> string(55) "Visual Studio 2017|MSDN帮助|C#程序|.NET|Help Viewer" ["tagsid"]=> string(23) "[401,402,403,"300",404]" ["catesname"]=> string(0) "" ["catesid"]=> string(2) "[]" ["createtime"]=> string(10) "1511400964" ["_id"]=> string(3) "428" } [1]=> array(10) { ["id"]=> string(3) "427" ["text"]=> string(42) "npm -v;报错 cannot find module "wrapp"" ["intro"]=> string(288) "目录 ECharts 异步加载 ECharts 数据可视化在过去几年中取得了巨大进展。开发人员对可视化产品的期望不再是简单的图表创建工具,而是在交互、性能、数据处理等方面有更高的要求。 chart.setOption({ color: [ " ["username"]=> string(4) "zzty" ["tagsname"]=> string(50) "node.js|npm|cannot find module "wrapp“|node" ["tagsid"]=> string(19) "[398,"239",399,400]" ["catesname"]=> string(0) "" ["catesid"]=> string(2) "[]" ["createtime"]=> string(10) "1511400760" ["_id"]=> string(3) "427" } [2]=> array(10) { ["id"]=> string(3) "426" ["text"]=> string(54) "说说css中pt、px、em、rem都扮演了什么角色" ["intro"]=> string(288) "目录 ECharts 异步加载 ECharts 数据可视化在过去几年中取得了巨大进展。开发人员对可视化产品的期望不再是简单的图表创建工具,而是在交互、性能、数据处理等方面有更高的要求。 chart.setOption({ color: [ " ["username"]=> string(12) "zhengqiaoyin" ["tagsname"]=> string(0) "" ["tagsid"]=> string(2) "[]" ["catesname"]=> string(0) "" ["catesid"]=> string(2) "[]" ["createtime"]=> string(10) "1511400640" ["_id"]=> string(3) "426" } [3]=> array(10) { ["id"]=> string(3) "425" ["text"]=> string(83) "深入学习JS执行--创建执行上下文(变量对象,作用域链,this)" ["intro"]=> string(288) "目录 ECharts 异步加载 ECharts 数据可视化在过去几年中取得了巨大进展。开发人员对可视化产品的期望不再是简单的图表创建工具,而是在交互、性能、数据处理等方面有更高的要求。 chart.setOption({ color: [ " ["username"]=> string(7) "Ry-yuan" ["tagsname"]=> string(33) "Javascript|Javascript执行过程" ["tagsid"]=> string(13) "["169","191"]" ["catesname"]=> string(0) "" ["catesid"]=> string(2) "[]" ["createtime"]=> string(10) "1511399901" ["_id"]=> string(3) "425" } [4]=> array(10) { ["id"]=> string(3) "424" ["text"]=> string(30) "C# 排序技术研究与对比" ["intro"]=> string(288) "目录 ECharts 异步加载 ECharts 数据可视化在过去几年中取得了巨大进展。开发人员对可视化产品的期望不再是简单的图表创建工具,而是在交互、性能、数据处理等方面有更高的要求。 chart.setOption({ color: [ " ["username"]=> string(9) "vveiliang" ["tagsname"]=> string(0) "" ["tagsid"]=> string(2) "[]" ["catesname"]=> string(8) ".Net Dev" ["catesid"]=> string(5) "[199]" ["createtime"]=> string(10) "1511399150" ["_id"]=> string(3) "424" } [5]=> array(10) { ["id"]=> string(3) "423" ["text"]=> string(72) "【算法】小白的算法笔记:快速排序算法的编码和优化" ["intro"]=> string(288) "目录 ECharts 异步加载 ECharts 数据可视化在过去几年中取得了巨大进展。开发人员对可视化产品的期望不再是简单的图表创建工具,而是在交互、性能、数据处理等方面有更高的要求。 chart.setOption({ color: [ " ["username"]=> string(9) "penghuwan" ["tagsname"]=> string(6) "算法" ["tagsid"]=> string(7) "["344"]" ["catesname"]=> string(0) "" ["catesid"]=> string(2) "[]" ["createtime"]=> string(10) "1511398109" ["_id"]=> string(3) "423" } [6]=> array(10) { ["id"]=> string(3) "422" ["text"]=> string(64) "JavaScript数据可视化编程学习(二)Flotr2,雷达图" ["intro"]=> string(288) "目录 ECharts 异步加载 ECharts 数据可视化在过去几年中取得了巨大进展。开发人员对可视化产品的期望不再是简单的图表创建工具,而是在交互、性能、数据处理等方面有更高的要求。 chart.setOption({ color: [ " ["username"]=> string(7) "chengxs" ["tagsname"]=> string(28) "数据可视化|前端学习" ["tagsid"]=> string(9) "[396,397]" ["catesname"]=> string(18) "前端基本知识" ["catesid"]=> string(5) "[198]" ["createtime"]=> string(10) "1511397800" ["_id"]=> string(3) "422" } [7]=> array(10) { ["id"]=> string(3) "421" ["text"]=> string(36) "C#表达式目录树(Expression)" ["intro"]=> string(288) "目录 ECharts 异步加载 ECharts 数据可视化在过去几年中取得了巨大进展。开发人员对可视化产品的期望不再是简单的图表创建工具,而是在交互、性能、数据处理等方面有更高的要求。 chart.setOption({ color: [ " ["username"]=> string(4) "wwym" ["tagsname"]=> string(0) "" ["tagsid"]=> string(2) "[]" ["catesname"]=> string(4) ".NET" ["catesid"]=> string(7) "["119"]" ["createtime"]=> string(10) "1511397474" ["_id"]=> string(3) "421" } [8]=> array(10) { ["id"]=> string(3) "420" ["text"]=> string(47) "数据结构 队列_队列实例:事件处理" ["intro"]=> string(288) "目录 ECharts 异步加载 ECharts 数据可视化在过去几年中取得了巨大进展。开发人员对可视化产品的期望不再是简单的图表创建工具,而是在交互、性能、数据处理等方面有更高的要求。 chart.setOption({ color: [ " ["username"]=> string(7) "idreamo" ["tagsname"]=> string(40) "C语言|数据结构|队列|事件处理" ["tagsid"]=> string(23) "["246","247","248",395]" ["catesname"]=> string(12) "数据结构" ["catesid"]=> string(7) "["133"]" ["createtime"]=> string(10) "1511397279" ["_id"]=> string(3) "420" } [9]=> array(10) { ["id"]=> string(3) "419" ["text"]=> string(47) "久等了,博客园官方Android客户端发布" ["intro"]=> string(288) "目录 ECharts 异步加载 ECharts 数据可视化在过去几年中取得了巨大进展。开发人员对可视化产品的期望不再是简单的图表创建工具,而是在交互、性能、数据处理等方面有更高的要求。 chart.setOption({ color: [ " ["username"]=> string(3) "cmt" ["tagsname"]=> string(0) "" ["tagsid"]=> string(2) "[]" ["catesname"]=> string(0) "" ["catesid"]=> string(2) "[]" ["createtime"]=> string(10) "1511396549" ["_id"]=> string(3) "419" } } ["count"]=> int(200) } 222 Linux下编译安装源代码的三个步骤 - 菲宇 - 爱码网
fungitive

View Post

Linux下编译安装源代码的三个步骤

Linux下编译安装源代码无非就是三个步骤,./configure,make,make install

第一步进入源代码的目录

运行命令

1 ./configure --prefix=安装目录 --target=目标平台

上面这两个是最基本的,有些源代码的安装需要好几十个参数,具体就只能参考具体的说明了。

./configure常见参数解析


\'configure\'脚本有大量的命令行选项。对不同的软件包来说,这些选项可能会有变 化,但是许多基本的选项是不会改变的。带上\'--help\'选项执行\'configure\'脚本可以看到可用的所有选项。尽管许多选项是很少用到的,但是 当你为了特殊的需求而configure一个包时,知道他们的存在是很有益处的。下面对每一个选项进行简略的介绍:

--cache-file=FILE

\'configure\'会在你的系统上测试存在的特性(或者bug!)。为了加速随后 进行的配置,测试的结果会存储在一个cache file里。当configure一个每个子树里都有\'configure\'脚本的复杂的源码树时,一个很好的cache file的存在会有很大帮助。

--help

输出帮助信息。即使是有经验的用户也偶尔需要使用使用\'--help\'选项,因为一个复杂的项目会包含附加的选项。例如,GCC包里的\'configure\'脚本就包含了允许你控制是否生成和在GCC中使用GNU汇编器的选项。


--no-create


\'configure\'中的一个主要函数会制作输出文件。此选项阻止\'configure\'生成这个文件。你可以认为这是一种演习(dry run),尽管缓存(cache)仍然被改写了。


--quiet

--silent


当\'configure\'进行他的测试时,会输出简要的信息来告诉用户正在作什么。这样作是因为\'configure\'可能会比较慢,没有这种输出的话用户将会被扔在一旁疑惑正在发生什么,使用这两个选项中的任何一个都会把你扔到一旁。(译注:这两句话比较有意思,原文是这样的:If there was no such output, the user would be left wondering what is happening. By using this option, you too can be left wondering!)


--version


打印用来产生\'configure\'脚本的Autoconf的版本号。


--prefix=PEWFIX


\'--prefix\'是最常用的选项。制作出的\'Makefile\'会查看随此选项传递的参数,当一个包在安装时可以彻底的重新安置他的结构独立部分。举一个例子,当安装一个包,例如说Emacs,下面的命令将会使Emacs Lisp file被安装到"/opt/gnu/share":

$ ./configure --prefix=/opt/gnu


--exec-prefix=EPREFIX


与\'--prefix\'选项类似,但是他是用来设置结构倚赖的文件的安装位置,编译好的\'emacs\'二进制文件就是这样一个问件。如果没有设置这个选项的话,默认使用的选项值将被设为和\'--prefix\'选项值一样。


--bindir=DIR


指定二进制文件的安装位置,这里的二进制文件定义为可以被用户直接执行的程序。


--sbindir=DIR


指定超级二进制文件的安装位置。这是一些通常只能由超级用户执行的程序。


--libexecdir=DIR


指定可执行支持文件的安装位置。与二进制文件相反,这些文件从来不直接由用户执行,但是可以被上面提到的二进制文件所执行。


--datadir=DIR


指定通用数据文件的安装位置。


--sysconfdir=DIR


指定在单个机器上使用的只读数据的安装位置。


--sharedstatedir=DIR

指定可以在多个机器上共享的可写数据的安装位置。


--localstatedir=DIR

指定只能单机使用的可写数据的安装位置。

--libdir=DIR

指定库文件的安装位置。


--includedir=DIR

指定C头文件的安装位置。其他语言如C++的头文件也可以使用此选项。


--oldincludedir=DIR

指定为除GCC外编译器安装的C头文件的安装位置。


--infodir=DIR

指定Info格式文档的安装位置.Info是被GNU工程所使用的文档格式。


--mandir=DIR

指定手册页的安装位置。


--srcdir=DIR

这个选项对安装没有作用,他会告诉\'configure\'源码的位置。一般来说不用指定此选项,因为\'configure\'脚本一般和源码文件在同一个目录下。


--program-prefix=PREFIX

指定将被加到所安装程序的名字上的前缀。例如,使用\'--program- prefix=g\'来configure一个名为\'tar\'的程序将会使安装的程序被命名为\'gtar\'。当和其他的安装选项一起使用时,这个选项只有当他被`Makefile.in\'文件使用时才会工作。


--program-suffix=SUFFIX

指定将被加到所安装程序的名字上的后缀。


--program-transform-name=PROGRAM

这里的PROGRAM是一个sed脚本。当一个程序被安装时,他的名字将经过`sed -e PROGRAM\'来产生安装的名字。


--build=BUILD

指定软件包安装的系统平台。如果没有指定,默认值将是\'--host\'选项的值。


--host=HOST

指定软件运行的系统平台。如果没有指定。将会运行`config.guess\'来检测。


--target=GARGET

指定软件面向(target to)的系统平台。这主要在程序语言工具如编译器和汇编器上下文中起作用。如果没有指定,默认将使用\'--host\'选项的值。


--disable-FEATURE

一些软件包可以选择这个选项来提供为大型选项的编译时配置,例如使用Kerberos认证系统或者一个实验性的编译器最优配置。如果默认是提供这些特性,可以使用\'--disable-FEATURE\'来禁用它,这里\'FEATURE\'是特性的名字,例如:

$ ./configure --disable-gui


-enable-FEATURE[=ARG]

相反的,一些软件包可能提供了一些默认被禁止的特性,可以使用\'--enable-FEATURE\'来起用它。这里\'FEATURE\'是特性的名字。一个特性可能会接受一个可选的参数。例如:

$ ./configure --enable-buffers=128

`--enable-FEATURE=no\'与上面提到的\'--disable-FEATURE\'是同义的。


--with-PACKAGE[=ARG]

在自由软件社区里,有使用已有软件包和库的优秀传统。当用\'configure\'来配置一个源码树时,可以提供其他已经安装的软件包的信息。例如,倚赖于Tcl和Tk的BLT器件工具包。要配置BLT,可能需要给\'configure\'提供一些关于我们把Tcl和Tk装的何处的信息:

$ ./configure --with-tcl=/usr/local --with-tk=/usr/local

\'--with-PACKAGE=no\'与下面将提到的\'--without-PACKAGE\'是同义的。


--without-PACKAGE

有时候你可能不想让你的软件包与系统已有的软件包交互。例如,你可能不想让你的新编译器使用GNU ld。通过使用这个选项可以做到这一点:

$ ./configure --without-gnu-ld


--x-includes=DIR

这个选项是\'--with-PACKAGE\'选项的一个特例。在Autoconf最初被开发出来时,流行使用\'configure\'来作为Imake的一个变通方法来制作运行于X的软件。\'--x-includes\'选项提供了向 \'configure\'脚本指明包含X11头文件的目录的方法。


--x-libraries=DIR

类似的,\'--x-libraries\'选项提供了向\'configure\'脚本指明包含X11库的目录的方法。

 


 

make的使用

一般情况下,只需要直接用make即可,但是有时候,生成的Makefile文件中并没有指定C编译器或者C++编译器,那么就需要手动指定了,不然就有可能出现编译错误。

make CC=指定C语言编译器

make CXX=指定C++编译器


 

最后就简单了

使用make install即可。

分类:

技术点:

相关文章:

  • 2018-02-02
  • 2018-12-31
  • 2021-11-14
  • 2020-07-16
  • 2020-03-14
  • 2018-03-04
  • 2021-11-30
  • 2018-03-09
猜你喜欢
  • 2018-08-26
  • 2019-03-17
  • 2021-10-11
  • 2017-12-20
  • 2018-07-21
  • 2018-11-06
  • 2020-07-14
  • 2018-12-19
相关资源
相似解决方案