Get<PrimitiveType>ArrayRegion Routines - GetCharArrayRegion
void Get<PrimitiveType>ArrayRegion
(JNIEnv *env, ArrayType array,
jsize start, jsize len, NativeType *buf);
A family of functions that copies a region of a primitive array into a buffer.
The following table describes the specific primitive array element accessors. You should do the following substitutions:(GetCharArrayRegion)
- Replace Get<PrimitiveType>ArrayRegion with one of the actual primitive element accessor routine names from Table 4-12.
- Replace ArrayType with the corresponding array type.
- Replace NativeType with the corresponding native type for that routine.
Table 4-12a Get<PrimitiveType>ArrayRegion Family of Array Accessor Routines
LINKAGE of GetCharArrayRegion
Indices in the JNIEnv interface function table.
Table 4-12b Get<PrimitiveType>ArrayRegion Family of Array Accessor Routines
PARAMETERS of GetCharArrayRegion
env: the JNI interface pointer.array: a Java array.start: the starting index.len: the number of elements to be copied.buf: the destination buffer.THROWS:
ArrayIndexOutOfBoundsException: if one of the indexes in the region is not valid.
Example of GetCharArrayRegion
case 'C': {
m_cmdParser->reply.WriteByte(JDWP_TAG_CHAR);
m_cmdParser->reply.WriteInt(length);
if ( length == 0 ) {
return;
}
jchar* bufferArray = reinterpret_cast<jchar*>(AgentBase::GetMemoryManager()
.Allocate(sizeof(jchar)*length JDWP_FILE_LINE));
AgentAutoFree scavenger(bufferArray JDWP_FILE_LINE);
jni->GetCharArrayRegion(static_cast<jcharArray>(arrayObject), firstIndex, length, bufferArray);
classManager.CheckOnException(jni);
for (int i = 0; i < length; i++) {
value.c = bufferArray[i];
JDWP_TRACE_DATA("GetValues: send: index=" << i
<< ", value=(char)" << value.c);
m_cmdParser->reply.WriteUntaggedValue(jni, JDWP_TAG_CHAR, value);
}
return;