错误:NDK CDT JNI 'class'未知类型名称



我正在使用Eclipse ADT:CDT。随着NDK与JNI的接口,到c/c ++,通过Eclipse编译Cygwin的c/c ++。一切都应该运行最新版本,因为这只是在过去两周内设置的。

构建时,我得到以下内容。

jni/testSocketClass.hpp:33:1: error: unknown type name 'class'
jni/testSocketClass.hpp:33:17: error: expected '=', ',', ';', 'asm' or '__attribute__' before '{' token
jni/ndkfoo.c:13:1: error: unknown type name 'mYNewClass'

JNI C 文件

#include <string.h>
#include <jni.h>
#include "testSocketClassWrapper.hpp"
void *m_GBLpmyCSocket;
ndkfoo.c
jstring Java_com_example_hydrobedcontrol1_MainActivity_inintNativeClass(JNIEnv * env, jobject object){
  m_GBLpmyCSocket = MyClass_create();
  MyClass_sendCommandToSerialDevice(m_GBLpmyCSocket, 0, 0, 0);
 return (*env)->NewStringUTF(env, "started");
}

类包装器 .hpp

 //file testSocketClassWrapper.hpp
#ifndef _MY_SOCKETCLASS_WRAPPER_H
#define _MY_SOCKETCLASS_WRAPPER_H
#include"testSocketClass.hpp"//<<<<<<<<<<<<<<<<<<<<<Wrong inclusion

#ifdef __cplusplus
extern "C" void* MyClass_create() {
return new mYNewClass;
}
extern "C" void MyClass_release(void* myclass) {
delete static_cast<mYNewClass*>(myclass);
}
extern "C" void MyClass_sendCommandToSerialDevice(void* myclass, int cmd, int params,  int id) {
static_cast<mYNewClass*>(myclass)->sendCommandToSerialDevice(cmd,params,id);
}
#endif
#endif /* _MY_SOCKETCLASS_WRAPPER_H_INCLUDED */

类包装器.cpp

//file testSocketClassWrapper.cpp
#include "testSocketClassWrapper.hpp"

.h 类

// file testSocketClass.hpp
class mYNewClass{///////////////////////ERROR HERE////////////////////////////////
//public:
void sendCommandToSerialDevice(int Command, int Parameters, int DeviceID);
//int sockfd;
 };

类.cpp

// file testSocketClass.cpp
#include "testSocketClass.hpp"
void mYNewClass::sendCommandToSerialDevice(int Command, int Parameters, int DeviceID){
char testc[100];
sprintf(testc, "%d, %d, %d", Command, Parameters, DeviceID);
}

我已经阅读了无数关于这个主题的问题,并且在使用 Eclipse 配置时也遇到了很多问题。但是从我从关于这个主题的其他问题中得出的结论来看,我已经碰壁了,不知道在这一点上如何进行。建议?

在下面编辑 - 回答

在与同事审查后(有时第二双眼睛有助于解决问题),我们找到了我的错误。请参阅类包装器 .hpp 中标记为不正确包含的行。该标头应在类包装器中重新定位,如下所示.cpp注意:也移动到.cpp和 .hpp 的函数现在为空。

//file testSocketClassWrapper.cpp
#include "testSocketClassWrapper.hpp"
#include "testSocketClass.hpp"
extern "C" void* MyClass_create() {
  return new mYNewClass;
}
extern "C" void MyClass_release(void* myclass) {
  delete static_cast<mYNewClass*>(myclass);
}
extern "C" void MyClass_sendCommandToSerialDevice(void* myclass, int cmd, int params, int id) {
  static_cast<mYNewClass*>(myclass)->sendCommandToSerialDevice(cmd,params,id);
}

同样为了完整起见,因为这不是在公园里散步,是MK文件。

Android.mk
LOCAL_PATH := $(call my-dir)
include $(CLEAR_VARS)
# Here we give our module name and source file(s)
LOCAL_MODULE    := ndkfoo
LOCAL_SRC_FILES := ndkfoo.c testSocketClassWrapper.cpp testSocketClass.cpp
include $(BUILD_SHARED_LIBRARY)    

Application.mk
APP_STL:=stlport_static

感谢您的及时回复。还有另一种方法可以做到这一点。会牢记这一点。

testSockedClass.hpp 包含在 .c 文件中,因此它使用 C 编译器进行编译。 class C 中不存在,将 ndkfoo.c 更改为.cpp文件。

您必须在C++中以稍微不同的格式设置内容:

extern "C"
{
    jstring Java_com_example_hydrobedcontrol1_MainActivity_inintNativeClass(JNIEnv * env, jobject object);
}
jstring Java_com_example_hydrobedcontrol1_MainActivity_inintNativeClass(JNIEnv * env, jobject object){
    m_GBLpmyCSocket = MyClass_create();
    MyClass_sendCommandToSerialDevice(m_GBLpmyCSocket, 0, 0, 0);
    return env->NewStringUTF("started");
}

请注意 C++ 与 C 中NewStringUTF调用的形式。

最新更新