在linux64位机器上编译时遇到的两个问题

在将程序从一处迁移到Linux64位机器并尝试编译时,遇到了精度丢失错误。具体表现为在函数'void* ListenLoop(void*)'中,从'void*'类型转换到'int'时出现错误。
摘要由CSDN通过智能技术生成

今天将一个程序移动到另外一台机器上进行编译,结果报了如下的错误

 

wxtSi_gw/wxtGw_receive.c: In function 'void* ListenLoop(void*)':

wxtSi_gw/wxtGw_receive.c:785: error: cast from 'void*' to 'int' loses precision

ListenLoop是一个线程函数,通过void*的参数,将一个整型值传进来,然后在函数内部做了强制转换
void* ListenLoop(void * args)
{
     int lfd = (int)args;
     。。。
}
在32位机器上,int,指针的长度都是4个字节,自然没有任何问题
但是在64位机器上,int是4个字节,指针是8个字节,将指针的值赋给int型就汇报错了,64位机器上long是8字节的,因此需要改为long型,
    long lfd = (long)args;
这样就不会报错了。
但是假如要在64位机器上需要链接32位的库,又会遇到新的问题了。我在程序中用到sybase数据库,需要调用CT-Library接口,编译时候提
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值