Make文件链接问题架构x86_64的未定义符号 [英] Make file Linking issue Undefined symbols for architecture x86_64

查看:219
本文介绍了Make文件链接问题架构x86_64的未定义符号的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

我正在努力使用我的make文件和c ++链接到一些文件,并得到以下错误时运行make。

I am working on getting a few files to link together using my make file and c++ and am getting the following error when running make.

g++ -bind_at_load `pkg-config --cflags opencv`   -c -o compute_gist.o compute_gist.cpp
g++ -bind_at_load `pkg-config --cflags opencv`   -c -o gist.o gist.cpp
g++ -bind_at_load `pkg-config --cflags opencv`   -c -o standalone_image.o standalone_image.cpp
g++ -bind_at_load `pkg-config --cflags opencv`   -c -o IplImageConverter.o IplImageConverter.cpp
g++ -bind_at_load `pkg-config --cflags opencv`   -c -o GistCalculator.o GistCalculator.cpp
g++ -bind_at_load `pkg-config --cflags opencv` `pkg-config --libs opencv` compute_gist.o gist.o standalone_image.o IplImageConverter.o GistCalculator.o -o rungist
Undefined symbols for architecture x86_64:
    "color_gist_scaletab(color_image_t*, int, int, int const*)", referenced from:
    _main in compute_gist.o
ld: symbol(s) not found for architecture x86_64
collect2: ld returned 1 exit status
make: *** [rungist] Error 1


$ b b

我的makefile如下(注意,我不需要opencv绑定,但将在opencv中编码。

My makefile is as follows (Note, I don't need opencv bindings yet, but will be coding in opencv later.

CXX = g++
CXXFLAGS = -bind_at_load `pkg-config --cflags opencv`
LFLAGS = `pkg-config --libs opencv`

SRC = \
compute_gist.cpp \
gist.cpp \
standalone_image.cpp \
IplImageConverter.cpp \
GistCalculator.cpp

OBJS = $(SRC:.cpp=.o)

rungist: $(OBJS)
$(CXX) $(CXXFLAGS) $(LFLAGS) $(OBJS) -o $@
all: rungist

clean:
rm -rf $(OBJS) rungist

方法头位于gist.h

The method header is located in gist.h

float *color_gist_scaletab(color_image_t *src, int nblocks, int n_scale, const int *n_orientations);

并且方法在gist.cpp中定义

And the method is defined in gist.cpp

float *color_gist_scaletab(color_image_t *src, int w, int n_scale, const int *n_orientation) {

最后是compute_gist.cpp(主文件)

And finally the compute_gist.cpp (main file)

#include <stdio.h>
#include <stdlib.h>
#include <string.h>


#include "gist.h"


static color_image_t *load_ppm(const char *fname) {
  FILE *f=fopen(fname,"r");
  if(!f) {
    perror("could not open infile");
    exit(1);
  }
  int width,height,maxval;
  if(fscanf(f,"P6 %d %d %d",&width,&height,&maxval)!=3 || maxval!=255) {
  fprintf(stderr,"Error: input not a raw PPM with maxval 255\n");
  exit(1);    
  }
  fgetc(f); /* eat the newline */
  color_image_t *im=color_image_new(width,height);

  int i;
  for(i=0;i<width*height;i++) {
    im->c1[i]=fgetc(f);
    im->c2[i]=fgetc(f);
    im->c3[i]=fgetc(f);    
  }

  fclose(f);
  return im;
}


static void usage(void) {
  fprintf(stderr,"compute_gist options... [infilename]\n"
      "infile is a PPM raw file\n"
      "options:\n"
      "[-nblocks nb] use a grid of nb*nb cells (default 4)\n"
      "[-orientationsPerScale o_1,..,o_n] use n scales and compute o_i orientations for scale i\n"
      );

  exit(1);
}




int main(int argc,char **args) {

const char *infilename="/dev/stdin";
int nblocks=4;
int n_scale=3;
int orientations_per_scale[50]={8,8,4};


while(*++args) {
  const char *a=*args;

  if(!strcmp(a,"-h")) usage();
  else if(!strcmp(a,"-nblocks")) {
    if(!sscanf(*++args,"%d",&nblocks)) {
      fprintf(stderr,"could not parse %s argument",a); 
      usage();
    }
  } else if(!strcmp(a,"-orientationsPerScale")) {
    char *c;
    n_scale=0;
    for(c=strtok(*++args,",");c;c=strtok(NULL,",")) {
      if(!sscanf(c,"%d",&orientations_per_scale[n_scale++])) {
        fprintf(stderr,"could not parse %s argument",a); 
        usage();         
      }
    }
  } else {
    infilename=a;
  }
}

color_image_t *im=load_ppm(infilename);

//Here's the method call -> :(
float *desc=color_gist_scaletab(im,nblocks,n_scale,orientations_per_scale);

int i;

int descsize=0;
//compute descriptor size
for(i=0;i<n_scale;i++) 
  descsize+=nblocks*nblocks*orientations_per_scale[i];

  descsize*=3; // color

  //print descriptor
  for(i=0;i<descsize;i++) 
    printf("%.4f ",desc[i]);

    printf("\n");

    free(desc);

    color_image_delete(im);

    return 0; 
}

任何帮助将非常感谢。

Any help would be greatly appreciated. I hope this is enough info. Let me know if I need to add more.

推荐答案

我怀疑 color_gist_scaletab 应该在头文件中声明为 externC

I suspect that color_gist_scaletab should be declared as extern "C" in your header file:

extern "C" {
  float *color_gist_scaletab(color_image_t *src, int nblocks, int n_scale, const int *n_orientations);
}

这篇关于Make文件链接问题架构x86_64的未定义符号的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

查看全文
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆