zoukankan      html  css  js  c++  java
  • Java字符串转C字符串的工具方法


    char*   Jstring2CStr(JNIEnv*   env,   jstring   jstr)
    {
         char*   rtn   =   NULL;
         jclass   clsstring   =   (*env)->FindClass(env,"java/lang/String");
         jstring   strencode   =   (*env)->NewStringUTF(env,"GB2312");
         jmethodID   mid   =   (*env)->GetMethodID(env,clsstring,   "getBytes",   "(Ljava/lang/String;)[B");
         jbyteArray   barr=   (jbyteArray)(*env)->CallObjectMethod(env,jstr,mid,strencode); // String .getByte("GB2312");
         jsize   alen   =   (*env)->GetArrayLength(env,barr);
         jbyte*   ba   =   (*env)->GetByteArrayElements(env,barr,JNI_FALSE);
         if(alen   >   0)
         {
          rtn   =   (char*)malloc(alen + 1);         //""
          memcpy(rtn,ba,alen);
          rtn[alen]=0;
         }
         (*env)->ReleaseByteArrayElements(env,barr,ba,0);  //
         return rtn;
    }


    jstr:需要转换的java字符串
    rtn:字符指针,也就是C的字符串
    clsstring:java的String类的字节码
    strencode:java字符串,值是GB2312
    mid:String类里的getBytes方法,参数是String
    jbyteArray:调用jstr的getBytes方法,得到字节数组
    alen:字节数组的长度
    ba:字节数组的首地址
    rtn   =   (char*)malloc(alen + 1);:申请一个堆内存,存放字节数组的所有数据,最后还要加一个结束符
    memcpy(rtn,ba,alen);:把字节数组的所有元素拷贝到rtn指向的堆内存中

  • 相关阅读:
    226. Invert Binary Tree
    404. Sum of Left Leaves
    112. Path Sum (判断路径和是否等于某值)
    5 用两个栈实现队列
    111. Minimum Depth of Binary Tree
    110. Balanced Binary Tree
    4 重建二叉树
    108. Convert Sorted Array to Binary Search Tree
    235. Lowest Common Ancestor of a Binary Search Tree(LCA最低公共祖先)
    3 从尾到头打印链表
  • 原文地址:https://www.cnblogs.com/superWolf/p/4646916.html
Copyright © 2011-2022 走看看