我编写了一个使用一些低级I / O的基本UNIX程序。没什么特别的,如果你想看一下这就是代码:
#include <fcntl.h>
#include <limits.h>
#include <stdio.h>
#include <stdlib.h>
#include <unistd.h>
#define BUFFSIZE 1024
int main(int argc, char *argv[])
{
// Character buffer
char buffer[BUFFSIZE];
// File 1 descriptor
int file1Desc = 0;
// File 2 descriptor
int file2Desc = 0;
// Output file descriptor
int outfileDesc = 0;
// Count # of chars read in
int n = 0;
// Boolean: no stdin reads?
unsigned char zeroSTDIN = 1;
// Need at least two arguments, no more than 3
if((argc < 3) || (argc > 4)){
printf("ERROR!!!\nUsage: kitty file1 file2 <outfile>\n");
return EXIT_FAILURE;
}
/** TRY TO OPEN FILES 1 AND 2 FOR READING **/
// Check for stdin read flag
if(argv[1][0] == '-' && argv[1][1] == '\0'){
file1Desc = STDIN_FILENO;
zeroSTDIN = 0;
}
// Otherwise just open file 1 for reading
else{
if((file1Desc = open(argv[1],O_RDONLY)) < 0){
perror(argv[1]);
printf("ERROR!!!\nUnable to open %s for reading\n",argv[1]);
return EXIT_FAILURE;
}
}
// Check for stdin read flag
if(argv[2][0] == '-' && argv[2][1] == '\0'){
// Only one read from stdin
if(!zeroSTDIN){
perror(argv[2]);
printf("ERROR!!!\nOnly one read from stdin\n",argv[1]);
}
file2Desc = STDIN_FILENO;
}
// Otherwise just open file2 for reading
else{
if((file2Desc = open(argv[2],O_RDONLY)) < 0){
perror(argv[2]);
printf("ERROR!!!\nUnable to open %s for reading\n",argv[2]);
if(file1Desc != STDIN_FILENO)
close(file1Desc);
return EXIT_FAILURE;
}
}
// If argument specified, try to open output file for writing
if(argc == 4){
if((outfileDesc = open(argv[3],O_WRONLY|O_CREAT|O_TRUNC)) < 0){
perror(argv[2]);
printf("ERROR!!!\nUnable to open %s for writing\n",argv[3]);
// Can't forget these
if(file1Desc != STDIN_FILENO)
close(file1Desc);
if(file2Desc != STDIN_FILENO);
close(file2Desc);
return EXIT_FAILURE;
}
}
// stdout otherwise
else{
outfileDesc = STDOUT_FILENO;
}
// While there is anything left to read from file 1
while((n = read(file1Desc, buffer, BUFFSIZE)) > 0){
// Write n chars to output file
if(write(outfileDesc, buffer, n) != n){
printf("Error writing to output file from file 1\n");
return EXIT_FAILURE;
}
}
// While there is anything left to read from file 2
while((n = read(file2Desc, buffer, BUFFSIZE)) > 0){
// Write n chars to output file
if(write(outfileDesc, buffer, n) != n){
printf("Error writing to output file from file 1\n");
return EXIT_FAILURE;
}
}
// Exit program
if(file1Desc != STDIN_FILENO)
close(file1Desc);
if(file2Desc != STDIN_FILENO);
close(file2Desc);
if(argc == 4)
close(outfileDesc);
return 0;
}
它编译时没有任何特殊选项。但是,我想在32位模式下编译。我正在运行Fedora 15 64位,它默认为64位编译。
我正在尝试使用以下选项:
gcc -S -m32 -O3 -o llio.asm llio.c
所以我想看看正在生成的汇编代码,但是我得到以下编译错误:
In file included from /usr/include/features.h:387:0,
from /usr/include/fcntl.h:27,
from kitty.c:1:
/usr/include/gnu/stubs.h:7:27: fatal error: gnu/stubs-32.h: No such file or directory
compilation terminated.
此网站似乎知道我的问题:http://www.cyberciti.biz/faq/x86_64-linux-error-gnustub-32h-missing-error-and-solution/
然而,我看,这些文件似乎已经安装好了。我错过了什么?
答案 0 :(得分:4)
我和你曾经在同一条船上,这是我在我的一个笔记文件中写下的内容:
yum install glibc-devel.i686
注意:我 6 86而非 3 86
然后就像你一样:gcc -m32...
答案 1 :(得分:1)
当在大多数Linux发行版的64位安装上,没有安装32位开发库...在Ubuntu上例如你要安装libc6-i386-dev(和gcc-multilib,但我认为无论如何都安装为依赖项)