zoukankan      html  css  js  c++  java
  • gcc利用-m32编译报错问题处理

    以32位的方式去编译.c文件:

    gcc -m32 test.c

    报错:

    致命错误:gnu/stubs-32.h:没有那个文件或目录

    去安装了32位的glibc库文件:

    yum install -y glibc-devel.i686

    再次运行,报libgcc_s.so的错误:

    /usr/bin/ld: 当搜索用于 /usr/lib/gcc/x86_64-redhat-linux/4.8.5/libgcc_s.so 时跳过不兼容的 -lgcc_s 
    /usr/bin/ld: 找不到 -lgcc_s

    上面的错误含义是链接时,找不到32位的libgcc_s.so(上面错误中提到的.so文件是64位下的,可以通过 ll 文件名看到其详细信息)

    [root@centos7 lib]# ll /usr/lib/gcc/x86_64-redhat-linux/4.8.5/libgcc_s.so
    lrwxrwxrwx. 1 root root 20 5月   5 22:19 /usr/lib/gcc/x86_64-redhat-linux/4.8.5/libgcc_s.so -> /lib64/libgcc_s.so.1

    因此问题转向了安装32位版本的libgcc_s.so了.

    yum install -y libgcc.i686

    这个时候就可以看到lib文件夹下已经存在该.so了.(lib对应的32版本的)

    [root@centos7 lib]# ll|grep gcc
    drwxr-xr-x.  3 root root      33 5月   5 22:54 gcc
    -rwxr-xr-x.  1 root root  104224 8月   7 2019 libgcc_s-4.8.5-20150702.so.1
    lrwxrwxrwx.  1 root root      28 5月   5 23:57 libgcc_s.so.1 -> libgcc_s-4.8.5-20150702.so.1

    感谢提供正确答案的stackoverflow:https://stackoverflow.com/questions/23638271/how-to-compile-32-bit-apps-on-64-bit-rhel

    拓展:

    libstdc++的32位包名: libstdc++-devel.i686
    (devel代表开发版本,里面至少包含头文件和链接库,有的还可能包括开发文档,演示代码等)
    新战场:https://blog.csdn.net/Stephen___Qin
  • 相关阅读:
    Uploadify v3.2.1 上传图片并预览
    mybatis批量操作
    500 拦截错误输出
    jsnop
    java目录
    设置360调用样式 IE调用样式
    Spring加载resource时classpath*:与classpath:的区别
    context:annotation-config 与context:component-scan
    Andriod调用http请求
    JDK环境变量
  • 原文地址:https://www.cnblogs.com/Stephen-Qin/p/12831247.html
Copyright © 2011-2022 走看看