Skip to Content

request_id

Posted on 2 mins read

缘起:请求调用中,有个 bigint 的 Request_id 需要传递,在 Lua 中也需要使用。 这个 Request_id 在 Java、C 或者 Golang 类似的强类型语言中是 int64 的一个无符号整数,在其他语言比如 PHP 或者 Lua 中,作为字符串使用。 需要解决的问题: 当一个请求到 Lua 后,CoSocket 接收到的是一个字节数组。 1.接收到请求后,需要把这个字节数组转化为 字符串。 2.响应请求的时候,需要把这个字符串转化为字节数组,返回去。 以上两步操作都是大端序。

因为 Lua 只有 Number 类型,而 Number 是双精度浮点型,能处理的最大 Int 小于 int64 的最大值 2^64 -1,所以需要把这部分操作用 C 语言实现,保证在 Lua 中处理的都是字符串。

实现以下 2 个功能: 1.Lua cosokect receive 一个 8 个字节的字节数组,将此数组传递给 C 函数,C 函数将这个字节数组转换为 int64 的整型,再转换成对应的字符串返回。 2.接收一个 Request_id 的字符串,将这个字符串转换成 int64 的整数,再转换成一个 8 个字节的字符串返回给 Lua,Lua 将这个 id TCP 返回给调用方。

实现的过程中我遇到的问题: 字符串转换成字节数组的问题,C 里面接收到请求的 Request_id 为 “%11%01%00” 这样的字符串,如何转换成字节数组 {0x11, 0x01, 0x00} 字节数组转换得到的 int64 为整数 比如 : 12345 如何转换成字符串 “12345” 实现 10 进制的 itoa 函数 正在调试

char *itoa(u_int64_t value, char *result, int base);
char *itoa(u_int64_t value, char *result, int base)
{
	// check that the base if valid
	if (base < 2 || base > 36)
	{
		*result = '\0';
		return result;
	}

	char *ptr = result, *ptr1 = result, tmp_char;
	u_int64_t tmp_value;

	do
	{
		tmp_value = value;
		value /= base;
		*ptr++ = "zyxwvutsrqponmlkjihgfedcba9876543210123456789abcdefghijklmnopqrstuvwxyz"[35 + (tmp_value - value * base)];
	} while (value);

	// Apply negative sign
	if (tmp_value < 0)
		*ptr++ = '-';
	*ptr-- = '\0';
	while (ptr1 < ptr)
	{
		tmp_char = *ptr;
		*ptr-- = *ptr1;
		*ptr1++ = tmp_char;
	}
	return result;
}

将接收到的4字节数组数据转换为int型: 两种方法: 1.移位 2.利用memcpy

result_dst=message[0]+(message[1]<<8)+(message[2]<<16)+(message[3]<<24);

将接收到的8字节数组数据转换为double型

利用memcpy

我们可以看到通过使用mempy既可以将基本数据转换为字节数组,亦可以将字节数组转换为基本数据类型,唯一需要注意的是位数问题

附注:(当出现大小端问题,解决思路) 在C/C++中,直接进行内存拷贝就可以了:

BYTE s[8]; memcpy(s,money,sizeof(double)); int intMoney = (int)(money*10); memmove(s,intMoney,sizeof(int)); 需要注意的是根据使用逻辑,如果需要字节逆序(这个很奇怪,因为通常是int类型需要)还是要做之后那个循环。另外就是数据类型了,double是8字节的格式存储,int是4字节逆序存储。

#include <stdio.h>
#include <stdlib.h>
#include <string.h>
int main(int argc, char *argv[])
{   
    
    int i;
    int result_src=1246;
    unsigned char message[4];
    int result_dst;
    double money_src=200.00;
    unsigned char s[8];
    double money_dst;
    //={0XDe,0X04,0,0};
       printf("unsigned char:%d  int:%d  double:%d\n",sizeof(unsigned char),sizeof(int),sizeof(double));
       printf("\n正变换---将int型数据转换为4字节数组:\n");
    memcpy(message,&result_src,sizeof(int));
        for(i=0;i<4;i++)
        {
         printf("%x ",message[i]);
        } 
         printf("\n逆变换---将4字节数组转换为int型数据:\n");  
        result_dst=message[0]+(message[1]<<8)+(message[2]<<16)+(message[3]<<24);
       // memcpy(&result_dst,message,sizeof(int)); 
        printf("%d ",result_dst);
  
    printf("\n------------------------");
      
      printf("\n正变换---将double型数据转换为8字节数组:\n");
      memcpy(s,&money_src,sizeof(double));
      //显示 
       for(i=0;i<8;i++)
        {
         printf("%x ",s[i]);
        } 
     printf("\n逆变换---将8字节数组转换为double型数据:\n");  
     memcpy(&money_dst,s,sizeof(double)); 
     //显示 
     printf("%f \n",money_dst);
    system("pause");
    return 0;
}
comments powered by Disqus