首页 > 解决方案 > 如何在c中使用make文件创建可执行文件

问题描述

我正在使用 aMakefile创建一个可执行文件,这样当我运行我刚刚编写的可执行文件时./ft_ls,就会出现这个错误,下面是我的 Makefile 的代码。

“ar: ft_ls: 不适当的文件类型或格式”

但是当我创建一个库并添加我的main.c文件和 gcc 时,它会运行file.so. 如何从以下 Makefile 创建可执行文件?

14 NAME = ft_ls
 15
 16 SRCS =  main.c\
 17         ft_perm.c\
 18         ft_group.c\
 19         count.c\
 20         ls_l.c\
 21         ls.c\
 22         ls_a.c\
 23         ls_rr.c\
 24         ls_r.c\
 25         ls_r_m.c\
 26         multi_args_l.c\
 27         ft_anigma.c\
 28         ls_g.c\
 29         ft_printf/ft_printf.c\
 30         ft_printf/precision.c ft_printf/mask_unicode.c ft_printf/width.c ft_printf/null_char.c ft_printf/wstr_precision.c\
 31         ft_printf/flags/flags.c ft_printf/flags/type_flags.c ft_printf/flags/checking_for.c ft_printf/n_func.c\
 32         ft_printf/conv/applying.c ft_printf/conv/conversion.c ft_printf/conv/zero_conv.c\
 33         ft_printf/alloc/ft_alloc.c ft_printf/alloc/to_str.c ft_printf/libft/ft_atoi.c ft_printf/alloc/ft_del_str.c\
 34         ft_printf/libft/ft_strncpy.c ft_printf/libft/ft_strcmp.c libft/ft_strncmp.c ft_printf/libft/ft_putstr.c ft_printf/color_part_two.c \
 35         ft_printf/libft/ft_strcpy.c ft_printf/libft/ft_strlen.c ft_printf/libft/ft_strdup.c \
 36         ft_printf/test/h_test.c ft_printf/test/jz_test.c ft_printf/test/l_test.c ft_printf/test/basic_test.c \
 37         ft_printf/itoa/ft_itoa_ll.c ft_printf/itoa/reverse.c ft_printf/libft/ft_strwdup.c ft_printf/color.c \
 38
 39 OB =    main.o \
 40         ft_perm.o\
 41         ft_group.o\
 42         count.o\
 43         ls_l.o\
 44         ls.o\
 45         ls_a.o\
 46         ls_rr.o\
 47         ls_r.o\
 48         ls_r_m.o\
 49         multi_args_l.o\
 50         ft_anigma.o\
 51         ls_g.o\
 52         ft_printf.o\
 53         type_flags.o applying.o basic_test.o checking_for.o conversion.o \
 54         flags.o ft_alloc.o ft_atoi.o mask_unicode.o n_func.o\
 55         ft_printf.o ft_strcmp.o ft_strcpy.o to_str.o wstr_precision.o\
 56         ft_strdup.o ft_strlen.o ft_strncpy.o h_test.o jz_test.o l_test.o precision.o \
 57         reverse.o width.o ft_itoa_ll.o null_char.o zero_conv.o ft_strwdup.o color.o \
 58         ft_putstr.o color_part_two.o ft_del_str.o ft_strncmp.o\
 59
 60 FLAGS = -Werror -Wall -Wextra
 61
 62 $(NAME):
 63     gcc  $(FLAGS) $(SRCS)  -o $(NAME)
 64
 65 all:    $(NAME)
 66
 67 clean:
 68     rm -f $(OB)
 69
 70 fclean: clean
 71     rm -f $(NAME)
 72
 73 re:     fclean all

标签: makefile

解决方案


 66 $(NAME):
 67     gcc -c $(FLAGS) -o ft_ls $(MAIN) $(OBJ)
 68     ar rc $(NAME) $(OB)

在上面的代码片段中,你有一个没有任何依赖关系的目标 $(NAME) [= ft_ls] 和两个命令,它们试图创建一个可执行文件和一个库。此外,您定义了一个名为 OB 的变量,但引用了一个名为 OBJ 的变量。我怀疑你应该只创建一个可执行文件,像这样

$(NAME): $(MAIN) $(OB)
    gcc $(FLAGS) -o ft_ls $(MAIN) $(OB)

如果您使用的是 GNU make,那么您可以使用 $@ 作为目标,使用 $^ 作为依赖项(这使您的 Makefile 更易于维护),就像这样

$(NAME): $(MAIN) $(OB)
    gcc $(FLAGS) -o $@ $^

目前尚不清楚您的目标文件是如何编译的。如果您只有一堆 .c 文件并需要一些 .o 文件,那么它可能suffix rule会被使用(请参见此处),因此您需要类似

.c.o:
        $(CC) -c $(FLAGS) -o $@ $<

推荐阅读