1

我将 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

感谢您及时回复 krsteeve。还有另一种方法来做到这一点。会记住的。

4

1 回答 1

0

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");
}

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

于 2013-10-30T19:16:34.623 回答