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;