为你详解Linux安装GCC方法

2023-11-02

下载: http://ftp.gnu.org/gnu/gcc/gcc-4.5.1/gcc-4.5.1.tar.bz2
浏览: http://ftp.gnu.org/gnu/gcc/gcc-4.5.1/
查看Changes: http://gcc.gnu.org/gcc-4.5/changes.htm

现在很多程序员都应用GCC,怎样才能更好的应用GCC。目前,GCC可以用来编译C/C++、FORTRAN、JAVA、OBJC、ADA等语言的程序,可根据需要选择安装支持的语言。本文以在Redhat Linux安装GCC4.1.2为例(因在项目开发过程中要求使用,没有用最新的GCC版本),介绍Linux安装GCC过程。

安装之前,系统中必须要有cc或者gcc等编译器,并且是可用的,或者用环境变量CC指定系统上的编译器。如果系统上没有编译器,不能安装源代码形式的GCC 4.1.2。如果是这种情况,可以在网上找一个与你系统相适应的如RPM等二进制形式的GCC软件包来安装使用。本文介绍的是以源代码形式提供的GCC软件包的安装过程,软件包本身和其安装过程同样适用于其它Linux和Unix系统。

系统上原来的GCC编译器可能是把gcc等命令文件、库文件、头文件等分别存放到系统中的不同目录下的。与此不同,现在GCC建议我们将一个版本的GCC安装在一个单独的目录下。这样做的好处是将来不需要它的时候可以方便地删除整个目录即可(因为GCC没有uninstall功能);缺点是在安装完成后要做一些设置工作才能使编译器工作正常。在本文中采用这个方案安装GCC 4.1.2,并且在安装完成后,仍然能够使用原来低版本的GCC编译器,即一个系统上可以同时存在并使用多个版本的GCC编译器。

按照本文提供的步骤和设置选项,即使以前没有安装过GCC,也可以在系统上安装上一个可工作的新版本的GCC编译器。

1 下载

在GCC网站上(http://gcc.gnu.org)或者通过网上搜索可以查找到下载资源。目前GCC的最新版本为 4.2.1。可供下载的文件一般有两种形式:gcc-4.1.2.tar.gz和gcc-4.1.2.tar.bz2,只是压缩格式不一样,内容完全一致,下载其中一种即可。

2. 解压缩

拷贝gcc-4.1.2.tar.bz2(我下载的压缩文件)到/usr/local/src(根据自己喜好选择)下,根据压缩格式,选择下面相应的一种方式解包(以下的“%”表示命令行提示符):

% tar zxvf gcc-4.1.2.tar.gz

或者

% bzcat gcc-4.1.2.tar.bz2 | tar xvf -

新生成的gcc-4.1.2这个目录被称为源目录,用${srcdir}表示它。以后在出现${srcdir}的地方,应该用真实的路径来替换它。用pwd命令可以查看当前路径。

在${srcdir}/INSTALL目录下有详细的GCC安装说明,可用浏览器打开index.html阅读。

3. 建立目标目录

目标目录(用${objdir}表示)是用来存放编译结果的地方。GCC建议编译后的文件不要放在源目录${srcdir]中(虽然这样做也可以),最好单独存放在另外一个目录中,而且不能是${srcdir}的子目录。

例如,可以这样建立一个叫 /usr/local/gcc-4.1.2的目标目录:

% mkdir /usr/local/gcc-4.1.2

% cd gcc-4.1.2

以下的操作主要是在目标目录 ${objdir} 下进行。(否则会出错,后面有解释)

4. 配置

配置的目的是决定将GCC编译器安装到什么地方(${destdir}),支持什么语言以及指定其它一些选项等。其中,${destdir}不能与${objdir}或${srcdir}目录相同。

配置是通过执行${srcdir}下的configure来完成的。其命令格式为(记得用你的真实路径替换${destdir}):

% ${srcdir}/configure --prefix=${destdir} [其它选项]

例如,如果想将GCC 4.1.2安装到/usr/local/gcc-4.1.2目录下,则${destdir}就表示这个路径。

在我的机器上,我是这样配置的:

% ../gcc-4.1.2/configure --prefix=/usr/local/gcc-4.1.2 --enable-threads=posix --disable-checking --enable--long-long --host=i386-redhat-linux--with-system-zlib --enable-languages=c,c++,java

将GCC安装在/usr/local/gcc-4.1.2目录下,支持C/C++和JAVA语言,其它选项参见GCC提供的帮助说明。

5. 编译

% make

6. 安装

执行下面的命令将编译好的库文件等拷贝到${destdir}目录中(根据你设定的路径,可能需要管理员的权限):

% make install

至此,GCC 4.1.2安装过程就完成了。

7. 其它设置

GCC 4.1.2的所有文件,包括命令文件(如gcc、g++)、库文件等都在${destdir}目录下分别存放,如命令文件放在bin目录下、库文件在 lib下、头文件在include下等。由于命令文件和库文件所在的目录还没有包含在相应的搜索路径内,所以必须要作适当的设置之后编译器才能顺利地找到并使用它们。

7.1 gcc、g++、gcj的设置

要想使用GCC 4.1.2的gcc等命令,简单的方法就是把它的路径${destdir}/bin放在环境变量PATH中。我不用这种方式,而是用符号连接的方式实现,这样做的好处是我仍然可以使用系统上原来的旧版本的GCC编译器。

首先,查看原来的gcc所在的路径:

% which gcc

在我的系统上,上述命令显示:/usr/bin/gcc。因此,原来的gcc命令在/usr/bin目录下。我们可以把GCC 4.1.2中的gcc、g++、gcj等命令在/usr/bin目录下分别做一个符号连接:

% cd /usr/bin

% ln -s ${destdir}/bin/gcc gcc412

% ln -s ${destdir}/bin/g++ g++412

% ln -s ${destdir}/bin/gcj gcj412

这样,就可以分别使用gcc412、g++412、gcj412来调用GCC 4.1.2的gcc、g++、gcj完成对C、C++、JAVA程序的编译了。同时,仍然能够使用旧版本的GCC编译器中的gcc、g++等命令。

(cool,我感觉棒极了!!1)

7.2 库路径的设置

将${destdir}/lib路径添加到环境变量LD_LIBRARY_PATH中,例如,如果GCC 4.1.2安装在/usr/local/gcc-4.1.2目录下,在RH Linux下可以直接在命令行上执行

% export LD_LIBRARY_PATH=/usr/local/gcc-4.1.2/lib

最好添加到系统的配置文件中,这样就不必要每次都设置这个环境变量了,在文件$HOME/.bash_profile中添加下面两句:

LD_LIBRARY_PATH=/usr/local/gcc-4.1.2/lib:$LD_LIBRARY_PATH

export LD_LIBRARY_PATH

重启系统设置生效,或者执行命令

% source $HOME/.bash_profile

用新的编译命令(gcc412、g++412等)编译你以前的C、C++程序,检验新安装的GCC编译器是否能正常工作。

完成了Linux安装GCC,之后你就能轻松地编辑了。

from:os.51cto.com/art/200912/168804.htm

在RHLinux下安装gcc-4.0.1方法比较简单,但是安装过程中有些环节是需要注意的,否则,可能会导致安装不成功,或者安装报错。具体安装过程如下:

首先,下载并解压缩gcc的RPM包至源目录(如/opt/gcc-4.0.1)

1、解压缩RPM包:

[root@linuxopt]# tar xjvf gcc-4.0.1.tar.bz2 (解压后生成源目录/opt/gcc-4.0.1)

2、创建安装目标目录:

[root@linux opt]# mkdir /usr/local/gcc-4.0.1/

3、进入安装目标目录:

[root@linux opt]# cd /usr/local/gcc-4.0.1/ (这一步很重要,配置安装文件时,需要在目标目录下执行configure命令)

[root@linux opt]# pwd

/usr/local/gcc-4.0.1

4、配置安装文件:

[root@linux gcc-4.0.1]# /opt/gcc-4.0.1/configure --prefix=/usr/local/gcc-4.0.1/ (这一步非常重要,需要在安装的目标目录下,执行源目录 /opt/gcc-4.0.1/中的configure命令,配置将gcc安装到目标目录/usr/local/gcc-4.0.1/)

creating cache ./config.cache

checking host system type... i686-pc-linux-gnu

5、编译安装文件:

[root@linux gcc-4.0.1]# pwd

/usr/local/gcc-4.0.1

[root@linux gcc-4.0.1]# make (在目标目录下执行编译)

6、安装gcc:

[root@linux gcc-4.0.1]# pwd

/usr/local/gcc-4.0.1

[root@linux gcc-4.0.1]# make install (在目标目录下执行安装)

如果安装过程中步骤和命令没有错误,你肯定能安装成功。

 

---------------------------------------------------------------------

 

  首先,现在最新的包GCC 4.2.bz2,一般的到处都有的下,linux下的下载速度很满,20多k,很恶心,我喜欢迅雷的下载速度,在windows下下载,大概42M,下载速度2到4M,回到linux下,挂载,ntfs格式的我的,具体不说了,说安装! 

  进入到挂载的目录下,先cp GCC4.2.bz2 /azuo, 

  cd /azuo, 

  tar -xvf GCC 4.2.bz2 , 

  得到gcc-4.2, 

  cd gcc-4.2,在/usr目录下建立一个文件夹就是现在要存放新的gcc的目录, 

  mkdir /usr/gcc4 

  ./configure –prefix=/usr/gcc4 

  回车,就会有配置信息,只要不报错就可以了, 

  make,这个过程很久,因为我没有设置一些具体的选项,因此,所有的组件几乎都要编译一遍,我的电脑cpu:AMD 3200+X2 ,1.5g内存,大概花费一个半小时。 

  到这个时候为止,/usr/gcc4下还没有任何东西,编译过程都是发生在源文件夹,让我们再来一个动作,所有的要用到的东西都会配置到目标文件夹下, 

  make install; 

  这个过程也不短,等着就是了。 

  一切都已经弄好了之后就是使用最新的gcc了,可以看到,在/usr/gcc4/bin下有gcc,g++,等一些东西,都是可以用的,写两个程序: 

  aa.c: 

  1 #include 

  2 

  3 int main(void) { 

  4 printf("ad"); 

  5 return 1; 

  6 } 

  gcc -o aa aa.c 

  执行 ./aa 

  上面的这个是c的,下面这个就是c++的了: 

  a.cpp: 

  1 #include 

  2 using namespace std; 

  3 int main(void) { 

  4 cout << "Ok!" << endl; 

  5 return 1; 

  6 } 

  g++ -o a a.cpp 

  执行就是了./a 

  一切ok了,就可以让最新的gcc工具取代原来的工具了。 

  看看原来的gcc是什么版本的,我们好卸载它: 

  [root@BTazuo bin]# rpm -qa gcc 

  gcc-4.1.2-27.fc7 

  [root@BTazuo bin]# rpm -e gcc-4.1.2-27.fc7 

  error: Failed dependencies: 

  gcc is needed by (installed) systemtap-0.5.13-1.fc7.i386 

  gcc = 4.1.2-27.fc7 is needed by (installed) gcc-c++-4.1.2-27.fc7.i386 

  gcc = 4.1.2-27.fc7 is needed by (installed) gcc-gfortran- 4.1.2 -27.fc7. i386 

  [root@BTazuo bin]# rpm -e gcc-c++-4.1.2-27.fc7.i386 

  [root@BTazuo bin]# rpm -e gcc-gfortran-4.1.2-27.fc7.i386 

  [root@BTazuo bin]# rpm -e gcc-4.1.2-27.fc7 

  error: Failed dependencies: 

  gcc is needed by (installed) systemtap-0.5.13-1.fc7.i386 

  [root@BTazuo bin]# g++ 

  bash: g++: command not found 

  卸载成功 

  [root@BTazuo bin]# gcc 

  gcc: 没有输入文件 ,可见gcc犹在 

  [root@BTazuo bin]# rpm -e systemtap-0.5.13-1.fc7.i386 

  [root@BTazuo bin]# gcc 

  gcc: 没有输入文件 

  [root@BTazuo bin]# rpm -e gcc-4.1.2-27.fc7 

  [root@BTazuo bin]# gcc 

  bash: /usr/lib/ccache/gcc: 没有那个文件或目录 

  最后的卸载成功! 

  这个时候,要注意了,我的gcc在/usr/bin下面有,在/usr/lib/ccache这个目录下也有,分别在这两个下面都要建立一个链接: 

  [root@BTazuo bin]# ln -s /usr/gcc4/bin/g++ g++ 

  [root@BTazuo bin]# g++ 

  g++: 没有输入文件 

  可见g++已经装好了,可以使用了。 

  然后是gcc: 

  [root@BTazuo bin]# ln -s /usr/gcc4/bin/gcc gcc 

  [root@BTazuo bin]# gcc 

  bash: /usr/lib/ccache/gcc: 没有那个文件或目录 

  [root@BTazuo bin]# ./gcc 

  gcc: 没有输入文件 

  可见还要给另外一个目录建立一个gcc的链接: 

  [root@BTazuo lib]# ln -s /usr/gcc4/bin/gcc /usr/lib/ccache/gcc 

  [root@BTazuo lib]# gcc 

  gcc: 没有输入文件 

  到此为止,gcc和g++都已经建立好了,可以用了,最后把原来的包和解压文件都可以删除了,以节省硬盘空间!

-------------------------------------------------------------------------------------------------------

下面介绍其在Red Hat Linux 9.0编译器给gcc 3.2.2环境下的安装方法。
一.确定安装环境
本安装方法适用于Red Hat Linux 9.0操作系统,自带的GCC编译器是GCC 3.2.2版本。其他系列的linux操作系统或是其他版本GCC下安装过程可能有些细节上的不同。
注:因为不同版本的GCC编译器下一些库的定义可能有不同,因此首先要确定一下本机的GCC编译器版本。确定方法是进入命令行输入命令gcc –v得到的结果如图1.1所示:


图1.1
可见本机的GCC版本为GCC 3.2.2,根据simplescalar网站上的一些介绍,该模拟器的开发工具可能是GCC2.7左右,比较接近GCC 3.2.2,因此估计安装过程会比较顺利。
二.获得安装包
完成本安装过程的安装包可以在

http://www.simplescalar.com
下下载,本安装所需要的安装包共有以下三个

三 建立安装目录,解压安装包
建立安装目录为/root/simplescalar,将安装包复制到安装目录,整个过程如下:

解压缩,命令为tar –zxvf,加压缩完毕后用rm*.tgz命令删除压缩包,整个过程输入命令如下:
tar –zxvf simplesim-3v0d.tgz
tar –zxvf simpletools-2v0.tgz
tar –zxvf simpleutils-2v0.tgz
rm*.tgz
加压缩后得到如下七个文件夹:

四.安装binutils2.5.2
首先用configure命令配置程序的安装环境和参数,生成Makefile文件,整个过程如下:

注:configure命令的参数含义说明
-host:配置安装环境
-target:配置成littleEndian模式
-with-gnu-as 加载汇编器
-with-gnu-ld 加载链接器
-prefix 设置安装目录
此时遇到两个错误,如下所示:
  

从错误说明可以估计出错误来自于libiberty文件夹下的dummy.c文件。网上一些帖子说是dummy.c中定义的宏functions.def文件中的函数定义与声明不一致引起的,将它们改成一致就可以通过编译。但是这样做的话,继续编译依然会遇到许多错误。这里我试出了最好的方法就是将dummy.c文件中的内容全部删除(即将dummy.c变成空文件)然后再make一次,这回不报任何错误,编译一次通过!
运行make install命令,这时binutils-2.5.2安装成功!
五.安装simplescalar
Simplescalar是最简单的一个安装过程,运行下列命令即可完成安装!


六.安装gcc-2.6.3
安装好simplescalar后在安装文件夹/root/simplescalar下可以找到一个名为bin的文件夹,里面包含的是一些simplescalar自带的工具,如链接工具等,该文件内容如下:


可见,里面没有C编译工具gcc,因此还需要安装gcc2.6.3作为simplescalar的内置编译工具,下面介绍安装方法。
首先对安装环境进行配置,生成Makefile文件,具体方法如下图所示。


Makefile文件生成完毕后,运行make命令,此时出现以下错误:


由错误报告可知,这是由于sys_errlist的定义不一致造成的,打开cccp.c文件发现其194行附近有如下代码,第194行为extern char *sys_errlist[]。显然要消除冲突,只需改变宏编译的分支方向,使其不走这一分支即可。尝试在这段代码前面如175行加上#define bsd4_4,修改后再次make,该错误改正,遇到下一个错误。
  

第二个错误是sdbout.c文件中的一些常量没有定义,如下:



因此第一估计是头文件的问题,打开sdbout.c发现其包含的头文件有如下几个: 

可以肯定报错的原因是宏编译的分支的问题(走不同的宏编译分支,可能包含syms.h或者是gsyms.h)。经过多次尝试,发现在前面加上#undef  USG即可解决该错误(即把gsyms.h包含进去)。
继续make,发生第三个错误,如下:


这个错误和第一个错误一样,是由于sys_errlist定义冲突引起的,因此进入gcc.c文件,在172行之前(这里加在167行)加上#define bsd4_4即可。
继续make,发生第四个错误,如下:


和前面一样,只要在g++.c文件的第90行代码段之前(这里加在85行)加上#define bsd4_4即可。
继续make,发生第五个错误,如下: 


这里提示是将cp/g++.c文件中第213行的sys_errlist改成strerror或者strerror_r,然而改过之后会报strerror未定义的错误,上网搜了很久也没发现有这两个定义的头文件名,最后根据函数名感觉这段代码(pfatal_with_name)的功能可能是获得错误名,将其删除估计对工作影响不大,因此干脆将这个函数放空,放空后再运行make,果然OK,不报任何错误,编译通过!
运行make install,gcc 2.6.3安装成功!
返回simplescalar,进入bin文件夹,可以发现里面多了一个sslittle-na-sstrix-gcc文件,该文件是simplescalar的内建C编译器,如下所示:


进一步运行./sslittle-na-sstrix-gcc –v测试出该内建编译器版本为gcc 2.6.3。


到此为止,整个安装过程结束,下面进行测试。
七.测试
为了测试simplescalar是否能够顺利运行,我们对其进行测试,测试程序依然采用最经典的hello world!程序,程序如下:
    #include 
main()
{
printf("Hello World!\n");
return 0;
}
编辑好程序后将其保存在/root/simplescalar文件夹下,文件名为hello.c,用刚刚安装的simplescalar内建编译器编译,编译方法如下。


    运行结果如下:


八 结束语
本安装方法适用于Red Hat Linux 9.0操作系统,自带的GCC编译器是GCC 3.2.2版本。其他系列的linux操作系统或是其他版本GCC下安装过程可能有些细节上的不同,主要原因可能是高版本的GCC没有兼容低版本的一些库文件,还有就是遵循的C标准可能会有点出入。如果机器上的GCC正好是低版本的,估计可能一次编译通过!
-----------------------------------------------------------------------------------------------------

  1. 下载 
  在GCC网站上(
http://gcc.gnu.org/
)或通过网上搜索能查找到下载资源。目前GC
C的最新版本为3.4.0。可供下载的文件一般有两种形式:gcc-3.4.0.tar.gz和gcc-3.4.0.tar.bz2,
只是压缩格式不相同,内容完全一致,下载其中一种即可。 
  2. 解压缩 
  根据压缩格式,选择下面相应的一种方式解包(以下的"%"表示命令行提示符): 
  % tar xzvf gcc-3.4.0.tar.gz

% bzcat gcc-3.4.0.tar.bz2 | tar xvf - 
  新生成的gcc-3.4.0这个目录被称为源目录,用${srcdir}表示他。以后在出现${srcdir
}的地方,应该用真实的路径来替换他。用pwd命令能查看当前路径。 
  在${srcdir}/INSTALL目录下有周详的GCC安装说明,可用浏览器打开index.html阅读。 
  3. 建立目标目录 
  目标目录(用${objdir}表示)是用来存放编译结果的地方。GCC建议编译后的文件不要
放在源目录${srcdir]中(虽然这样做也能),最佳独立存放在另外一个目录中,而且不
能是${srcdir}的子目录。 
  例如,能这样建立一个叫 gcc-build
的目标目录(和源目录${srcdir}是同级目录): 
  % mkdir gcc-build
% cd gcc-build 
  以下的操作主要是在目标目录 ${objdir} 下进行。 
  4. 设置 
  设置的目的是决定将GCC编译器安装到什么地方(${destdir}),支持什么语言及指
定其他一些选项等。其中,${destdir}不能和${objdir}或${srcdir}目录相同。 
  设置是通过执行${srcdir}下的configure来完成的。其命令格式为(记得用你的真实路
径替换${destdir}): 
  % ${srcdir}/configure --prefix=${destdir} [其他选项] 
  例如,如果想将GCC
3.4.0安装到/usr/local/gcc-3.4.0目录下,则${destdir}就表示这个路径。 
  在我的机器上,我是这样设置的: 
  % ../gcc-3.4.0/configure --prefix=/usr/local/gcc-3.4.0
--enable-threads=posix --disable-checking --enable--long-long
--host=i386-redhat-linux --with-system-zlib --enable-languages=c,c++,java 
  将GCC安装在/usr/local/gcc-3.4.0目录下,支持C/C++和JAVA语言,其他选项参见GCC
提供的帮助说明。 
  5. 编译 
  % make 
  这是个漫长的过程。在我的机器上(P4-1.6),这个过程用了50多分钟。 
  6. 安装 
  执行下面的命令将编译好的库文件等拷贝到${destdir}目录中(根据你设定的路径,可
能需要管理员的权限): 
  % make install 
  至此,GCC 3.4.0安装过程就完成了。 
  6. 其他设置 
  GCC
3.4.0的所有文件,包括命令文件(如gcc、g++)、库文件等都在${destdir}目录下分别存
放,如命令文件放在bin目录下、库文件在lib下、头文件在include下等。由于命令文件和
库文件所在的目录还没有包含在相应的搜索路径内,所以必须要作适当的设置之后编译器才
能顺利地找到并使用他们。 
  6.1 gcc、g++、gcj的设置 
  要想使用GCC
3.4.0的gcc等命令,简单的方法就是把他的路径${destdir}/bin放在环境变量PATH中。我不
用这种方式,而是用符号连接的方式实现,这样做的好处是我仍然能使用系统上原来的旧
版本的GCC编译器。 
  首先,查看原来的gcc所在的路径: 
  % which gcc 
  在我的系统上,上述命令显示:/usr/bin/gcc。因此,原来的gcc命令在/usr/bin目录
下。我们能把GCC
3.4.0中的gcc、g++、gcj等命令在/usr/bin目录下分别做一个符号连接: 
  % cd /usr/bin
% ln -s ${destdir}/bin/gcc gcc34
% ln -s ${destdir}/bin/g++ g++34
% ln -s ${destdir}/bin/gcj gcj34 
  这样,就能分别使用gcc34、g++34、gcj34来调用GCC
3.4.0的gcc、g++、gcj完成对C、C++、JAVA程式的编译了。同时,仍然能够使用旧版本的GC
C编译器中的gcc、g++等命令。 
  6.2 库路径的设置 
  将${destdir}/lib路径添加到环境变量LD_LIBRARY_PATH中,最佳添加到系统的设置文
件中,这样就不必要每次都设置这个环境变量了。 
  例如,如果GCC 3.4.0安装在/usr/local/gcc-3.4.0目录下,在RH
Linux下能直接在命令行上执行或在文件/etc/profile中添加下面一句: 
  setenv LD_LIBRARY_PATH /usr/local/gcc-3.4.0/lib:$LD_LIBRARY_PATH 
  7. 测试 
  用新的编译命令(gcc34、g++34等)编译你以前的C、C++程式,检验新安装的GCC编译
器是否能正常工作。 
  8. 根据需要,能删除或保留${srcdir}和${objdir}目录。


本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

为你详解Linux安装GCC方法 的相关文章

  • 无法链接 Boost 正则表达式

    我目前正在尝试编译一个KIT 的收缩层次实现 http algo2 iti kit edu english routeplanning php这需要 Boost Regex 提供的 Makefile 已经确保 并且我还手动仔细检查了这一点
  • 如何在shell中输出返回码?

    我正在尝试通过调用自定义 shell 脚本sh bin sh c myscript sh gt log txt 2 gt 1 echo 该命令的输出是创建的后台进程的 PID 我想指导 bin sh保存返回码myscript sh到某个文件
  • Linux 中什么处理 ping?

    我想覆盖 更改 linux 处理 ping icmp echo 请求数据包的方式 这意味着我想运行自己的服务器来回复传入的 icmp 回显请求或其他 数据包 但为了使其正常工作 我想我需要禁用 Linux 的默认 ping icmp 数据包
  • SSE:跨页边界的未对齐加载和存储

    我在页面边界旁边执行未对齐加载或存储之前读过某处 例如使用 mm loadu si128 mm storeu si128内在函数 代码应首先检查整个向量 在本例中为 16 个字节 是否属于同一页 如果不属于同一页 则切换到非向量指令 我知道
  • 查找哪些页面不再与写入时复制共享

    假设我在 Linux 中有一个进程 我从中fork 另一个相同的过程 后forking 因为原始进程将开始写入内存 Linux写时复制机制将为进程提供与分叉进程使用的不同的唯一物理内存页 在执行的某个时刻 我如何知道原始进程的哪些页面已被写
  • ftrace:仅打印trace_printk()的输出

    是否可以只转储trace printk 输出于trace文件 我的意思是过滤掉函数跟踪器 或任何其他跟踪器 中的所有函数 一般来说 您可以在选项目录中关闭选项 sys kernel debug tracing options Use ls显
  • 如何使用 GOPATH 的 Samba 服务器位置?

    我正在尝试将 GOPATH 设置为共享网络文件夹 当我进入 export GOPATH smb path to shared folder I get go GOPATH entry is relative must be absolute
  • 内核模式下的线程(和进程)与用户模式下的线程(和进程)有什么区别?

    我的问题 1 书中现代操作系统 它说线程和进程可以处于内核模式或用户模式 但没有明确说明它们之间有什么区别 2 为什么内核态线程和进程的切换比用户态线程和进程的切换花费更多 3 现在 我正在学习Linux 我想知道如何在LINUX系统中分别
  • MySQL 中的创建/写入权限

    我的设备遇到一些权限问题SELECT INTO OUTFILE陈述 当我登录数据库并执行简单的导出命令时 例如 mysql gt select from XYZ into outfile home mropa Photos Desktop
  • 需要一些建议来开始在 ARM(使用 Linux)平台上编程

    我 也许 很快就会在托管 Linux 发行版的 ARM 平台上工作 我不知道哪个发行版 我知道该项目涉及视频流 但我无法告诉你更多信息 其实我只收到通知 还没见到任何人 我从来没有在这样的平台上工作过 所以我的想法是在项目开始之前进行测试
  • 使用 Grep 查找两个短语之间的文本块(包括短语)

    是否可以使用 grep 来高亮所有以以下内容开头的文本 mutablePath CGPathCreateMutable 并以以下内容结尾 CGPathAddPath skinMutablePath NULL mutablePath 这两个短
  • 如果在等待“read -s”时中断,在子进程中运行 bash 会破坏 tty 的标准输出吗?

    正如 Bakuriu 在评论中指出的那样 这基本上与BASH 输入期间按 Ctrl C 会中断当前终端 https stackoverflow com questions 31808863 bash ctrlc during input b
  • Urwid:使光标不可见

    我正在使用 urwid 它是一个用于在 ncurses 中设计终端用户界面的 Python 框架 但有一件事我在 urwid 中无法做到 而这在 Curses 中很容易做到 使光标不可见 现在 选择按钮时光标是可见的 而且看起来很丑 有办法
  • 如何查询X11显示分辨率?

    这似乎是一个简单的问题 但我找不到答案 如何查询 通过 X11 存在哪些监视器及其分辨率 查看显示宏 http tronche com gui x xlib display display macros html and 屏幕宏 http
  • 为什么C Clock()返回0

    我有这样的事情 clock t start end start clock something else end clock printf nClock cycles are d d n start end 我总是得到输出 时钟周期是 0
  • Capistrano 3 部署无法连接到 GitHub - 权限被拒绝(公钥)

    我使用 Capistrano v3 和 capistrano symfony gem 设置了以下部署脚本 我正在使用 Ubuntu 14 4 部署到 AWS EC2 实例 我正在连接从 AWS 下载的 pem 文件 我的deploy rb中
  • git 错误:无法处理 https

    当我尝试使用 git clone 时https xxx https xxx我收到以下错误我不处理协议 https 有人可以帮我吗 完整消息 dementrock dementrock A8Se git 克隆https git innosta
  • 成员初始值设定项列表中的求值顺序是什么?

    我有一个带有一些参数的构造函数 我假设它们是按照列出的顺序初始化的 但在一种情况下 它们似乎是按相反的顺序初始化的 导致中止 当我反转参数时 程序停止中止 下面是我正在使用的语法的示例 a 之前需要初始化b 在这种情况下 你能保证这个初始化
  • 在 unix 中编译 dhrystone 时出错

    我是使用基准测试和 makefile 的新手 我已经从下面的链接下载了 Dhrystone 基准测试 我正在尝试编译它 但我遇到了奇怪的错误 我尝试解决它 但没有成功 有人可以帮助我运行 dhrystone 基准测试吗 以下是我尝试编译的两
  • Windows 上 libcurl 的静态库[重复]

    这个问题在这里已经有答案了 如何将此库 libcurl 静态链接到 exe 我努力了 disable share enable static 没有帮助 我使用的是MingW32 有没有一种简单的方法来静态链接这个库 这样我的应用程序就不再有

随机推荐