ICE常见问题的解决(一)

问:error C3861: “TryEnterCriticalSection”: 即使使用参数相关的查找,也未找到标识符
答:增加预处理定义:_WIN32_WINNT=0X500
问:ICE::Long类型变量不能正常输出
答:ICE::Long类型占8个字节,使用%I64d格式输出
问:JAVA客户端调用c++服务端,无论提交还是服务返回为乱码
答:编码格式不正确,在服务端增加编码处理,重新实现StringConverter,
// StringConverterI.h
#ifndef STRING_CONVERTER_I_H
#define  STRING_CONVERTER_I_H

#include 
< Ice / StringConverter.h >

namespace  test
{

//
// UTF-8 converter for LATIN-1
//
class StringConverterI : public Ice::StringConverter
{
public:

    StringConverterI();
    
~StringConverterI();

    
virtual Ice::Byte* toUTF8(const char*const char*, Ice::UTF8Buffer&const;
    
virtual void fromUTF8(const Ice::Byte*const Ice::Byte*, std::string&const;
}
;

}


#endif

// StringConverterI.cpp
#include  " StringConverterI.h "
#include 
< Ice / LocalException.h >

using   namespace  std;

test::StringConverterI::StringConverterI()
{
}


test::StringConverterI::
~ StringConverterI()
{
}


Ice::Byte
*
test::StringConverterI::toUTF8(
const   char *  sourceStart,  const   char *  sourceEnd, Ice::UTF8Buffer &  buffer)  const
{
    size_t inputSize 
= static_cast<size_t>(sourceEnd - sourceStart);
    size_t chunkSize 
= std::max<size_t>(inputSize, 6);
    size_t outputBytesLeft 
= chunkSize;
    
    Ice::Byte
* targetStart = buffer.getMoreBytes(chunkSize, 0);
    size_t offset 
= 0;

    
for(unsigned int i = 0; i < inputSize; ++i)
    
{
        unsigned 
char byte = sourceStart[i];
        
if(byte <= 0x7F)
    
{
        
if(outputBytesLeft == 0)
        
{
            targetStart 
= buffer.getMoreBytes(chunkSize, targetStart + chunkSize);
        offset 
= 0;
        }


        targetStart[offset] 
= byte;

        
++offset;
        
--outputBytesLeft;
    }

    
else
    
{
        
if(outputBytesLeft <= 1)
        
{
            targetStart 
= buffer.getMoreBytes(chunkSize, targetStart + chunkSize - outputBytesLeft);
        offset 
= 0;
        }


        targetStart[offset] 
= 0xC0 | ((byte & 0xC0>> 6); 
        targetStart[offset 
+ 1= 0x80 | (byte & 0x3F);

        offset 
+= 2;
        outputBytesLeft 
-= 2;
    }

    }


    
return targetStart + offset;
}


void
test::StringConverterI::fromUTF8(
const  Ice::Byte *  sourceStart,  const  Ice::Byte *  sourceEnd, 
                 
string &  target)  const
{
    size_t inSize 
= static_cast<size_t>(sourceEnd - sourceStart);
    target.resize(inSize);

    unsigned 
int targetIndex = 0;
    unsigned 
int i = 0;
    
while(i < inSize)
    
{
        
if((sourceStart[i] & 0xC0== 0xC0)
    
{
        
if(i + 1 >= inSize)
        
{
            
throw Ice::StringConversionException(__FILE__, __LINE__, "UTF-8 string source exhausted");
        }

        target[targetIndex] 
= (sourceStart[i] & 0x03<< 6;
        target[targetIndex] 
= target[targetIndex] | (sourceStart[i + 1& 0x3F);
        i 
+= 2;
    }

    
else
    
{
        target[targetIndex] 
= sourceStart[i];
        
++i;
    }

    
++targetIndex;
    }


    target.resize(targetIndex);
}
在初始化的时候,将初始化数据设置为:
Ice::InitializationData initData;
initData.stringConverter 
=   new  test::StringConverterI;
然后在java端,将得到的数据做如下处理:
TAHolder ta  =   new  TAHolder();
  t.DoWork(ta);

  
byte  [] b;
   b 
=  ta.value.s.getBytes( " ISO-8859-1 " );  // 中间用ISO-8859-1过渡
   String name1  =   new  String(b,  " GB2312 " );
向服务端传送的时候,按相反的方向转换就可以了
ICE-3.7.4 最新安装文件msi文件,windows版 ICE常见报错 Exception in thread Ice.ConnectionRefusedException error = 0 at IceInternal.Network.doFinishConnect(Network.java:417) at IceInternal.TcpTransceiver.initialize(TcpTransceiver.java:33) at Ice.ConnectionI.initialize(ConnectionI.java:1536) at Ice.ConnectionI.socketReady(ConnectionI.java:1116) at Ice.ConnectionI$SocketReadyCallback.socketReady(ConnectionI.java:2299) at IceInternal.SelectorThread.run(SelectorThread.java:203) at IceInternal.SelectorThread$HelperThread.run(SelectorThread.java:273) Caused by: java.net.ConnectException: Connection refused at sun.nio.ch.SocketChannelImpl.checkConnect(Native Method) at sun.nio.ch.SocketChannelImpl.finishConnect(SocketChannelImpl.java:574) at IceInternal.Network.doFinishConnect(Network.java:393) ... 6 more 这种报错是ICE服务端没有起来,telnet服务端ICE的端口不通,无法建立socke 原帖地址:http://blog.youkuaiyun.com/zhenjing/archive/2009/09/10/4538705.aspx ICE常见编译和运行(异常)错误 收藏 在编译和Ice应用相关的文件中,经常因为ice相关的文件包含关系而导致编译无法通过,此时的错误般提示和handle.h相关。然而想要解决这样的错误,般只需要把在无法编译成.o文件的.cpp文件中和ice文件相关的头文件放在该.cpp文件的起始行即可。也就是说,根据提示,把.cpp文件中最早提示导致出错的.h文件放在起始行。 ICE的常见运行错误(异常): 1 使用的地址错误,IP并非本地IP: 发生在初始化服务器时,没办法初始化adapter. 错误信息: (IP错误) ./test: Network.cpp:475: Ice::SocketException: socket exception: Cannot assign requestedaddress 另外: 已经启动服务器后又重新启动: 发生在初始化服务器时,没办法初始化adapter. 错误信息: (port已经被使用) ./server: Network.cpp:475:Ice::SocketException: socket exception: Address already in use ///stringtoProxy对于任何string都是有效的,均可以生成相应代理,但是该代理是否有效是无法保证的. 如果代理无效,也就是说根本就没有这样的adapter或者对象,那么使用Checkcast或直接用该代理调用相应对象接口均会抛异常. 下面对每种情况加于分析. 2 使用的代理IP错误: 发生在使用代理调用接口的时候 原因: 根本就没有相应的通讯器存在. 错误信息: (使用的代理IP错误) 抛出异常: Ice::ConnectFailedException(需要几秒, 需要进行搜索) 3 使用的代理端口错误,两边不致 : 发生在使用代理调用接口的时候 原因: 存在通讯器,但是不存在相应的对象适配器. 错误信息: 抛出异常: Ice::ConnectionRefusedException(很快, 端口没有被启用引起的,无人监听该端口) 4 使用的对象名字不正确: 发生在使用代理调用接口的时候 原因: 能够找到相应的对象适配器,但是该对象适配器中无法找到相应的对象 错误信息: 抛出异常: Ice::ObjectNotExistException(
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值