質問1:以下の関数で、値を返す前にメソッドを呼び出し たいと思い。この場合のように私がそれを行う方法は、アプリケーションがクラッシュする可能性があります。ReleaseStringUTFChars
String JNIXMLDOMDocument::GetXML() const
{
String strXML;
jmethodID method = m_JavaEnv->GetMethodID(m_XMLDomDocClass, "GetXML", "(Lorg/w3c/dom/Document;)Ljava/lang/String;");
if(method == NULL) {
return NULL;
}
jstring jstrXML = (jstring)m_JavaEnv->CallObjectMethod(m_XMLDomDocClassObject, method, m_XMLDomDocument);
if (jstrXML == NULL) {
return strXML;
}
strXML = m_JavaEnv->GetStringUTFChars(jstrXML, 0);
/* Question 1: **/
m_JavaEnv->ReleaseStringUTFChars(jstrXML, strXML.c_str());
return strXML;
} /* String GetXML() const **/
質問2:アプリケーションでマルチスレッドを使用している場合、コンストラクターでスレッドをアタッチしてすべての関数で使用し、デストラクタでデタッチするのは正しいですか?
JNIXMLDOMDocument::JNIXMLDOMDocument()
{
/* Check If the current thread is attached to the virtual machine. **/
int needToDetach;
/* Question 2: **/
m_JavaEnv = AttachCurrentThread(&needToDetach);
if (m_JavaEnv != NULL)
{
/* Try to find JAVA 'XMLDOMDocument' class. **/
m_XMLDomDocClass = m_JavaEnv->FindClass("com/fido/android/framework/service/XMLDOMDocument");
if (m_XMLDomDocClass != NULL) {
jmethodID constructor = m_JavaEnv->GetMethodID(m_XMLDomDocClass, "<init>", "()V");
if (constructor != NULL) {
m_XMLDomDocClassObject = m_JavaEnv->NewObject(m_XMLDomDocClass, constructor);
}
else DBG_ERROR(DBG_CTX, ("Can't create object of 'XMLDOMDocument' class!\n"));
}
else DBG_ERROR(DBG_CTX, ("Can't find 'XMLDOMDocument' class!\n"));
/* Try to find 'XMLDOMNode' class. **/
jclass localXMLDomNodeClass = m_JavaEnv->FindClass("com/fido/android/framework/service/XMLDOMNode");
if (localXMLDomNodeClass != NULL) {
jmethodID constructor = m_JavaEnv->GetMethodID(localXMLDomNodeClass, "<init>", "()V");
if (constructor != NULL) {
m_XMLDomNodeClassObject = m_JavaEnv->NewObject(localXMLDomNodeClass, constructor);
}
else DBG_ERROR(DBG_CTX, ("Can't create object of 'XMLDOMNode' class!\n"));
}
else DBG_ERROR(DBG_CTX, ("Can't find 'XMLDOMNode' class!\n"));
}
} /* JNIXMLDOMDocument() **/