在 JNI 中使用错误的代码将 jbytearray 转换为 char*
Convert jbytearray to char* with wrong code in JNI
我尝试在Jni Layer将jbytearray转换为char*。但是,它的结果有一些错误的特征,如下所示:
07-23 10:22:43.701 26585-26646/com.zspirytus.androidlua D/ScriptPkgDataFetcher: getPkgData: 0028 at Kotlin
07-23 10:22:43.701 26585-26646/com.zspirytus.androidlua D/LuaEngine: getPkgData: 0028�ض
07-23 10:22:44.221 26585-26646/com.zspirytus.androidlua D/ScriptPkgDataFetcher: getPkgData: 0028 at Kotlin
07-23 10:22:44.221 26585-26646/com.zspirytus.androidlua D/LuaEngine: getPkgData: 0028�ض
07-23 10:22:44.721 26585-26646/com.zspirytus.androidlua D/ScriptPkgDataFetcher: getPkgData: 0028 at Kotlin
07-23 10:22:44.721 26585-26646/com.zspirytus.androidlua D/LuaEngine: getPkgData: 0028�ض
在 Kotlin 层,字符串类型的结果是 "0028"
;在 Jni 层,转换后的结果是 "0028�ض"
。以下是我在代码中所做的:
在 Kotlin 中,该函数返回一个字节数组:
fun getContentByEntryName(entryName: String): ByteArray {
// data is always a String with value "0028"
val data = ZipFileUtils.getFileContentFromZipFile(ZipFile(scriptPkg), entryName)
Log.d("ScriptPkgDataFetcher", "getPkgDatagetPkgData: $data at Kotlin")
return data.toByteArray()
}
在 Jni,我将 jbytearray 转换为 char*,如下所示:
jbyteArray jba = (jbyteArray) env->CallStaticObjectMethod(clazz, methodId, dataPath);
int len = env->GetArrayLength (jba);
char* buff = new char[len];
env->GetByteArrayRegion (jba, 0, len, reinterpret_cast<jbyte*>(buff));
Log_d(LOG_TAG, "getPkgData: %s", buff);
似乎它的工作不正确。我也尝试了这段代码,但它仍然没有 工作正确...
jbyteArray jba = (jbyteArray) env->CallStaticObjectMethod(clazz, methodId, dataPath);
const char *cStr = (char *) (env)->GetByteArrayElements(jba, NULL);
我的代码中是否存在任何错误?请帮我纠正它。谢谢!
如果要使用 new char[]
创建字符串数据,然后在需要 null 终止的函数中使用该数据,则必须显式添加 null 终止符。
此外,您可能没有为终止 null 分配足够的空间,因此需要分配 len + 1
个字节。
您可以这样做:
char* buff = new char[len + 1]();
用空字符填充缓冲区或:
char* buff = new char[len + 1];
buff[len] = ' ';
但是,我强烈建议您使用std::string
或std::vector<char>
而不是以这种方式做事。
由于 JNI 非常脆弱,如果引发异常,您可能会以这种方式使用原始指针获得内存泄漏。
下面是一个可用于从 Java 字节数组转换为向量的小例程:
#include <vector>
//...
jbyteArray jba = (jbyteArray) env->CallStaticObjectMethod(clazz, methodId, dataPath);
int len = env->GetArrayLength (jba);
std::vector<char> buff(len + 1, 0);
env->GetByteArrayRegion (jba, 0, len, reinterpret_cast<jbyte*>(buff.data()));
Log_d(LOG_TAG, "getPkgData: %s", buff.data());
如果抛出异常,这不会受到内存泄漏的影响,因为当矢量因任何原因超出范围时std::vector
会自动释放内存。
相关文章:
- 防止主数据类型C++的隐式转换
- 模板参数替换失败,并且未完成隐式转换
- 努力将整数转换为链表。不知道我在这里做错了什么
- HEX值到wchar_t字符(UTF-8)的转换
- lambda参数转换为constexpr技巧,然后获取带链接的数组
- 将 Qvector<uint8_t> 转换为 QString
- 如何在cuSparse中使用cusparseXcoo2csr从coo转换为csc
- 有关插入适配器的错误。[错误]请求从 'back_insert_iterator<vector<>>' 类型转换为非标量类型
- 在c++中使用nlohmann从类到json的转换
- 从"int*"强制转换为"unsigned int"会丢失精度错误
- 将Integer转换为4字节的unsined字符矢量(按大端字节顺序)
- 处理小于cpu数据总线的数据类型.(c++转换为机器代码)
- 如何使用OpenCV将RBG图像转换为HSV,并将H、S和V值保存为C++中的3个独立图像
- 复制列表初始化的隐式转换的等级是多少
- 正在将指针转换为范围
- 如何防止 c++ 在从浮点型转换为双精度型(不适用于 IO)时添加额外的小数?
- 将"打开的CV图像"中的"颜色"转换为整数格式
- 是否可以从int转换为enum类类型
- 了解 GLM- openGL 中的相机转换
- 在 JNI 中使用错误的代码将 jbytearray 转换为 char*