2017-08-10 3 views
0

J'ai quelques problèmes de liaison avec la classe actuelle qui étend rocksdb :: Comparator.Implémentation d'un comparateur pour RocksDB

"NumericKeyComparator.cpp"

#include <rocksdb/db.h> 
#include <rocksdb/comparator.h> 
#include "../../structure/structure.h" 
#include "../../NumberToString.h" 
#include <map> 
#include <string> 
#include "rocksdb/db.h" 
#include "rocksdb/env.h" 

namespace rocksdb { 
    namespace { 
     class NumericKeyComparator : public Comparator { 
     public: 
      ~NumericKeyComparator() {} 

      NumericKeyComparator() {} 

      // Three-way comparison function: 
      // if a < b: negative result 
      // if a > b: positive result 
      // else: zero result 
      virtual int Compare(const Slice &a, const Slice &b) const override { 
       LONG_NUMERIC x, y; 
       x = StringToNumber<LONG_NUMERIC>(std::string(a.data())); 
       y = StringToNumber<LONG_NUMERIC>(std::string(b.data())); 
       if (x == y) return 0; 
       if (x < y) return -1; 
       return 1; 
      }; 

      virtual bool Equal(const Slice &a, const Slice &b) const override { 
       return StringToNumber<LONG_NUMERIC>(std::string(a.data())) == 
         StringToNumber<LONG_NUMERIC>(std::string(b.data())); 
      } 

      // Ignore the following methods for now: 
      virtual const char *Name() const { return "NumericKeyComparator"; }; 

      virtual void FindShortestSeparator(std::string *, const Slice &) const override {}; 

      virtual void FindShortSuccessor(std::string *) const {}; 
     }; 
    } 
} 

const rocksdb::Comparator* nkcmp() { 
    static rocksdb::NumericKeyComparator cmp; 
    return &cmp; 
} 

En particulier, la classe d'origine (fourni par un fichier .h) est la suivante, équivalente à la classe en LevelDB:

< rocksdb /comparator.h>

class Comparator { 
public: 
    virtual ~Comparator(); 
    virtual int Compare(const Slice& a, const Slice& b) const = 0; 
    virtual bool Equal(const Slice& a, const Slice& b) const { 
    return Compare(a, b) == 0; 
    } 
    virtual const char* Name() const = 0; 
    virtual void FindShortestSeparator(
     std::string* start, 
     const Slice& limit) const = 0; 
    virtual void FindShortSuccessor(std::string* key) const = 0; 
    virtual const Comparator* GetRootComparator() const { return this; } 
}; 

Pendant la phase de liaison se à l'exécutable, l'erreur suivante concernant le fichier .o est élevé:

NumericKeyComparator.cpp.o:(.data.rel.ro+0x10): undefined rederence to "typeinfo for rocksdb::Comparator"

collect2: error: ld returned 1 exit status

Même si je pense qu'il ya un problème sur la façon dont j'ai étendu la classe (mais Sincerly parlant, je ne sais pas, puisque je « ai essayé de suivre l'exemple fourni dans comparator_db_test.cc, la liaison est automagiquement fournie par CMake comme, en utilisant le drapeau bavard, se révèle être les suivantes:

/usr/bin/c++ -fopenmp -lpthread -lrt -lsnappy -lz -lbz2 -llz4 -lzstd -lnuma -g CMakeFiles/.dir//main.cpp.o ... CMakeFiles/.dir//lib/serializer/rocksdb/comparators/NumericKeyComparator.cpp.o -o -L/usr/lib/x86_64-linux-gnu/libsnappy.so -L/usr/lib/x86_64-linux-gnu/liblz4.so -L/usr/local/lib/librocksdb.a -Wl,-rpath,/usr/lib/x86_64-linux-gnu/libsnappy.so:/usr/lib/x86_64-linux-gnu/liblz4.so:/usr/local/lib/librocksdb.a ../_tests/lib/googletest/googlemock/gtest/libgtest.a /usr/local/lib/libstxxl_debug.a -lpthread /usr/lib/x86_64-linux-gnu/libboost_graph.a /usr/lib/x86_64-linux-gnu/libboost_serialization.a /usr/lib/x86_64-linux-gnu/libboost_system.a /usr/lib/x86_64-linux-gnu/libboost_filesystem.a /usr/local/BerkeleyDB.6.2/lib/libdb-6.2.a -lrocksdb -lpthread -lm -lsnappy -llz4 -lz -lbz2 -lzstd

la classe Comparator est virtuel et fourni dans un en-tête , donc ça ne devrait pas être un problème de liaison. J'essaie même de définir les drapeaux -frtti lors de la compilation du fichier .cpp et même de déplacer la déclaration de classe vers le .h lui-même, mais rien ne s'est passé. J'ai lu toutes les réponses ici sur StackOverflow, mais je n'ai pas trouvé de solution.

Répondre