给你一个转换类public class CharsetProcess {  public CharsetProcess() {
  }
  public static void main(String[] args) {
    CharsetProcess charsetProcess1 = new CharsetProcess();
  }    public static String U2C(String s)
    {
      String str = s;
     try
        {
          if ( str == null ) return str;
          byte[] u = str.getBytes("iso-8859-1");
          return new String(u,"GB2312");
        }
        catch(java.io.UnsupportedEncodingException e)
        {
          e.printStackTrace();
          return str;
     }    }}

解决方案 »

  1.   

    不要使用String传递进去,转换成byte[],然后就很好处理了。
      

  2.   

    这种方法是可行的!明天结帐!
    可以说一说原因,或是还有其他方法吗?我在自制的文本框中滚动时,每次光标必须动两格,否则又乱了
    我的中文平台是zhcon
      

  3.   

    不用转成Byte的
    直接传,用两个辅助函数就行了
    /*
     * 关于下面两个辅助函数:以前我是直接使用JNI的API函数env->GetStringUTF()(好像是这个名字,我有点忘了)
    和env->NewStringUTF()的。但是这两个函数对本地的GB2312(GBK)编码有问题,也就是
    说中文会有问题。
    因为Java是采用Unicode作为字符串编码的。
    在JNI中只有四个函数GetStringUTF,NewStringUTF,GetStringChars,NewString,
    前两个使用UTF8(可变字节),后两个是使用Unicode字符(16位双字节),
    而本地的C程序时使用GB2312或者GBK编码的,这样就会产生编码错误,导致乱码。
    所以采用WideCharToMultiByte和MultiByteToWideChar这两个函数把本地的
    GB2312和GBK码换成Unicode16编码,再使用Jni函数来转化成Java String.
     *////////////////////////////////////////////////////////////////////////////////
    //辅助函数:char* jstringToWindows(JNIEnv* env,jstring jstr);
    //功能:将Java的Unicode字符串转化成本地字符数组;
    ///////////////////////////////////////////////////////////////////////////////
    char* jstringToWindows(JNIEnv* env,jstring jstr )
    {
      AFX_MANAGE_STATE(AfxGetStaticModuleState());
      int length = env->GetStringLength(jstr );
      const jchar* jcstr = env->GetStringChars(jstr, 0 );
      char* rtn = (char*)malloc( length*2+1 );
      int size = 0;
      size = WideCharToMultiByte( CP_ACP, 0, (LPCWSTR)jcstr, length, rtn,
                               (length*2+1), NULL, NULL );
      if( size <= 0 )
        return NULL;
      env->ReleaseStringChars(jstr, jcstr );
      rtn[size] = 0;
      return rtn;
    }///////////////////////////////////////////////////////////////////////////////
    //辅助函数:jstring windowsToJstring( JNIEnv* env, char* str )
    //功能:将本地字符数组转化成Java的Unicode字符串;
    ///////////////////////////////////////////////////////////////////////////////
    jstring windowsToJstring( JNIEnv* env, char* str )
    {
      AFX_MANAGE_STATE(AfxGetStaticModuleState());
      jstring rtn = 0;
      int slen = strlen(str);
      wchar_t* buffer = 0;
      if( slen == 0 )
        rtn = env->NewStringUTF(str); //UTF ok since empty string
      else
      {
        int length = MultiByteToWideChar( CP_ACP, 0, (LPCSTR)str, slen, NULL, 0 );
        buffer = (wchar_t*)malloc( length*2 + 1 );
        if( MultiByteToWideChar( CP_ACP, 0, (LPCSTR)str, slen, (LPWSTR)buffer, length ) >0 )
          rtn = env->NewString( (jchar*)buffer, length );
      }
      if( buffer )
       free( buffer );
      return rtn;
    }
      

  4.   

    那两个函数是在windows下用VC写的
    如果在linux下,只要将其中的
    unicode16->gb2312
    和gb2312->unicode16的函数用linux的替换的就好了
    这个问题主要是因为java native interface的API中
    只提供了将java.String转成UTF8和Unicode16的方法
    而UTF8编码一般是没有方法直接转成Gb2312的
    所以都是将java.String -> U16 -> GB2312
    如果还有什么不明白的,可以通过[email protected]
    和我联系,如果你对这些编码的问题不了解,可以到
    IBM developer Work去看,那里有很多的介绍
      

  5.   

    简单,给你一个真正跨平台的函数:#define CURRENT_ENCODE "GBK"jstring CharTojstring(JNIEnv* env, char* str)
    {
            jstring rtn = 0;
            jsize len = strlen(str);        jclass clsstring = env->FindClass("java/lang/String");        //new encode string default "GBK"
            jstring strencode = env->NewStringUTF(CURRENT_ENCODE);
            jmethodID mid = env->GetMethodID(clsstring, "<init>", "([BLjava/lang/String;)V");
            jbyteArray barr = env->NewByteArray(len);        env->SetByteArrayRegion(barr,0,len,(jbyte*)str);        //call new String(byte[] b,String encode)
            rtn = (jstring)env->NewObject(clsstring,mid,barr,strencode);        return rtn;
    }char* jstringToChar(JNIEnv* env, jstring jstr)
    {
            char* rtn = NULL;
            jclass clsstring = env->FindClass("java/lang/String");        //new encode string default "GBK"
            jstring strencode = env->NewStringUTF(CURRENT_ENCODE);
            jmethodID mid = env->GetMethodID(clsstring, "getBytes", "(Ljava/lang/String;)[B");        //call String.getBytes method to avoid incompatible migrating into solaris
            jbyteArray barr= (jbyteArray)env->CallObjectMethod(jstr,mid,strencode);        jsize alen = env->GetArrayLength(barr);
            jbyte* ba = env->GetByteArrayElements(barr,JNI_FALSE);        if(alen > 0)
            {
                    rtn = (char*)malloc(alen+1);    //new char[alen+1];
                    memcpy(rtn,ba,alen);
                    rtn[alen]=0;
            }
            env->ReleaseByteArrayElements(barr,ba,0);        return rtn;
    }