关于GCC中Hash_map 编译错误(这个留着有待思考)

现象:在32位Linux、Gcc 4.4.6 版中编译代码报这个错误:

/usr/lib/gcc/i686-redhat-linux/4.4.6/../../../../include/c++/4.4.6/backward/hashtable.h:590: error: no match for call to '(const __gnu_cxx::hash<long long unsigned int>) (const long long unsigned int&)'

使用到的代码:

#include <ext/hash_map>

hash_map<uint64_t, uint64_t> m_hmUseBuff;
bool CTimerBrd::Delete(void* dItem)
{
    // 元素有效性验证
    TimerItem* pItem = reinterpret_cast<TimerItem*> (dItem);

#ifdef USE_SPINLOCK
    pthread_spin_lock(&m_spinlock);
#else
    m_mutex.Lock();
#endif

    // 判断传入的handle是否已经被删除 或者位置错误
    if((NULL == dItem)
        || (pItem->uiPosition > MAXTIMERCNT)
        || (pItem->Checksum != (pItem->uiPosition ^ pItem->uiCycle)
        || (m_hmUseBuff.end() == m_hmUseBuff.find((uint64_t)dItem))))    
    {
        // 校验验证
        m_pOwner->m_stTimerStat.ulKillFail++;               //删除失败统计
    #ifdef USE_SPINLOCK
        pthread_spin_unlock(&m_spinlock);
    #else
        m_mutex.Unlock();
    #endif

        if (m_pOwner->m_stTimerStat.ulKillFail % 5000 == 1) //日志打印频率控制
        {
            LOGGER_ERROR(m_pLogger, " KillTimer时指定了无效的参数. Item = [" << dItem << "] 校验失败");
        }

    return false;
    }
...................................................

在代码中使用到了hash_map的一个查找find,。

解决方法:

在hash_map 中加入支持64位的类型结构体,就能编译通过, eg:(这是为什么呢??)

template<>
struct hash<long long int>
{
    size_t
    operator()(long long int _x) const
    {
        return _x;
    }
};

template<>
struct hash<unsigned long long int >
{
    size_t 
    operator()(unsigned long long int _x) const
    {
        return _x;
    }
};

 

转载于:https://my.oschina.net/panpanxiong/blog/60456

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
GCC 是 C/C++ 编译器,不支持直接编译 Java 代码。Java 代码需要先被编译成字节码,然后由 Java 虚拟机(JVM)解释执行或者编译成本地代码执行。 Java 编译器通常使用 javac 命令进行编译。下面是一个简单的编译示例: ``` javac HelloWorld.java ``` 这将会编译名为 HelloWorld.java 的 Java 源代码文件,并生成一个名为 HelloWorld.class 的字节码文件。 如果你想使用 GCC 编译 Java 代码,你需要先将 Java 代码编译成字节码,然后再使用 GCC 编译字节码文件所生成的头文件和源文件。 下面是一个基本的步骤: 1. 使用 javac 命令编译 Java 代码文件: ``` javac HelloWorld.java ``` 2. 使用 javah 命令生成头文件: ``` javah HelloWorld ``` 这将生成一个名为 HelloWorld.h 的头文件。 3. 将头文件和字节码文件一起使用 JNI 编写 C 代码。在 C 代码,你需要包含 Java 的头文件和 JNI 库,这样就可以调用 Java 方法了。 4. 使用 GCC 编译 C 代码: ``` gcc -c -I/usr/lib/jvm/java-8-openjdk-amd64/include -I/usr/lib/jvm/java-8-openjdk-amd64/include/linux HelloWorld.c ``` 其,-I 选项指定了 Java 和 JNI 的头文件所在的目录。 5. 使用 GCC 链接 C 代码和 Java 库: ``` gcc -shared -o libHelloWorld.so HelloWorld.o -lc -ljvm ``` 这将生成一个名为 libHelloWorld.so 的共享库,可以在 Java 使用 System.loadLibrary() 方法加载。 需要注意的是,由于 GCC 不是专为编译 Java 代码而设计的,因此使用 GCC 编译 Java 代码可能会比较麻烦,并且可能会出现一些问题。建议还是使用专门的 Java 编译器 javac 来编译 Java 代码。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值