• Python调用C的方法


    参考:http://www.cnblogs.com/fxjwind/archive/2011/07/05/2098636.html

             http://amazingjxq.com/2012/01/09/python%E8%B0%83%E7%94%A8c%E5%87%BD%E6%95%B0/

     >>>cd /home/jxq/code/

    gcc -fPIC -shared bob_hash.c -o bob_hash.so

    然后在python里面用ctypes加载刚才的动态库。argtypes和restype分别对应函数的参数和返回值的类型。这样就可以直接调用了。


    >>> from ctypes import CDLL, c_int, c_void_p
    >>> bob_hash = CDLL('/home/jxq/code/bob_hash.so')
    >>> hash_string = bob_hash.hash_string
    >>> hash_string.argtypes = [c_void_p]
    >>> hash_string.restype = c_int
    >>> hash_string('123')

    代码:

    #include <stdio.h>
    #include <string.h>
    #define mix(a,b,c)                              
        {                                          
            a -= b; a -= c; a ^= (c >> 13);        
            b -= c; b -= a; b ^= (a << 8);          
            c -= a; c -= b; c ^= (b >> 13);        
            a -= b; a -= c; a ^= (c >> 12);        
            b -= c; b -= a; b ^= (a << 16);        
            c -= a; c -= b; c ^= (b >> 5);          
            a -= b; a -= c; a ^= (c >> 3);          
            b -= c; b -= a; b ^= (a << 10);        
            c -= a; c -= b; c ^= (b >> 15);        
        }

    unsigned int bob_hash(void *val, unsigned int length)
    {
        char *k = (char *)val;
        unsigned long a,b,c,len;

        /* Set up the internal state */
        len = length;
        a = b = c = 0x9e3779b9;  /* the golden ratio; an arbitrary value */

        /* Handle most of the key */
        while (len >= 12)
        {
            a += (k[0] +((unsigned long)k[1] << 8) +((unsigned long)k[2] << 16) +((unsigned long)k[3] << 24));
            b += (k[4] +((unsigned long)k[5] << 8) +((unsigned long)k[6] << 16) +((unsigned long)k[7] << 24));
            c += (k[8] +((unsigned long)k[9] << 8) +((unsigned long)k[10]<< 16)+((unsigned long)k[11] << 24));
            mix(a,b,c);
            k += 12; len -= 12;
        }

        /* Handle the last 11 bytes */
        c += length;
        switch(len)              /* all the case statements fall through */
        {
        case 11: c+=((unsigned long)k[10] << 24);
        case 10: c+=((unsigned long)k[9]  << 16);
        case 9 : c+=((unsigned long)k[8]  << 8);
            /* the first byte of c is reserved for the length */
        case 8 : b+=((unsigned long)k[7] << 24);
        case 7 : b+=((unsigned long)k[6] << 16);
        case 6 : b+=((unsigned long)k[5] << 8);
        case 5 : b+=k[4];
        case 4 : a+=((unsigned long)k[3] << 24);
        case 3 : a+=((unsigned long)k[2] << 16);
        case 2 : a+=((unsigned long)k[1] << 8);
        case 1 : a+=k[0];
        }
        mix(a,b,c);

        return c;
    }

    int hash_string(void *tmpstr)
    {
        int hash = (int)bob_hash(tmpstr, strlen(tmpstr));
        if(hash < 0)
        {
            hash = -hash;
        }
        return (int)(hash % 200);
    }

  • 相关阅读:
    java 获取未知枚举的集合(get unknown enum list)
    解析Disruptor:写入ring buffer
    解析Disruptor:拼接依赖
    Python3.x在linux下print中文问题
    Python3源码方式编译
    正则表达式学习
    PHP传值和传引用、传地址的区别
    php中关于sizeof()函数
    [原]JointJS流程图
    [原]OpeanLayers3 For ArcGIS MapServer
  • 原文地址:https://www.cnblogs.com/li-baibo/p/3178548.html
Copyright © 2020-2023  润新知