Ошибка NoClassDefFound: Logcat читает $1, указывающую на ошибку во внутреннем классе, но у меня ее нет

Я настраиваю tcp-сервер в Android, и я могу заставить образец работать, но не внедрять образец в свое собственное приложение. Я продолжаю получать ошибку NoClassDefFound и пытаюсь удалить внутренние классы и создать отдельные классы, но, похоже, это не работает. Я включил свои файлы LogCats и java.

ЛогКэт

08-07 14:34:03.642: W/dalvikvm(332): threadid=1: thread exiting with uncaught exception (group=0x40015560)
08-07 14:34:03.642: E/AndroidRuntime(332): FATAL EXCEPTION: main
08-07 14:34:03.642: E/AndroidRuntime(332): java.lang.NoClassDefFoundError: com.example.com.proto1.AndroidNetCommunicationClientActivityInner$1
08-07 14:34:03.642: E/AndroidRuntime(332):  at com.example.com.proto1.AndroidNetCommunicationClientActivityInner.<init>(AndroidNetCommunicationClientActivityInner.java:103)
08-07 14:34:03.642: E/AndroidRuntime(332):  at java.lang.Class.newInstanceImpl(Native Method)
08-07 14:34:03.642: E/AndroidRuntime(332):  at java.lang.Class.newInstance(Class.java:1409)
08-07 14:34:03.642: E/AndroidRuntime(332):  at android.app.Instrumentation.newActivity(Instrumentation.java:1021)
08-07 14:34:03.642: E/AndroidRuntime(332):  at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:1561)
08-07 14:34:03.642: E/AndroidRuntime(332):  at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:1663)
08-07 14:34:03.642: E/AndroidRuntime(332):  at android.app.ActivityThread.access$1500(ActivityThread.java:117)
08-07 14:34:03.642: E/AndroidRuntime(332):  at android.app.ActivityThread$H.handleMessage(ActivityThread.java:931)
08-07 14:34:03.642: E/AndroidRuntime(332):  at android.os.Handler.dispatchMessage(Handler.java:99)
08-07 14:34:03.642: E/AndroidRuntime(332):  at android.os.Looper.loop(Looper.java:123)
08-07 14:34:03.642: E/AndroidRuntime(332):  at android.app.ActivityThread.main(ActivityThread.java:3683)
08-07 14:34:03.642: E/AndroidRuntime(332):  at java.lang.reflect.Method.invokeNative(Native Method)
08-07 14:34:03.642: E/AndroidRuntime(332):  at java.lang.reflect.Method.invoke(Method.java:507)
08-07 14:34:03.642: E/AndroidRuntime(332):  at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:839)
08-07 14:34:03.642: E/AndroidRuntime(332):  at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:597)
08-07 14:34:03.642: E/AndroidRuntime(332):  at dalvik.system.NativeStart.main(Native Method)

Основной tcp java

import net.client.MyRequest;
import net.client.MyResponse;
import net.client.R;
import eneter.messaging.diagnostic.EneterTrace;
import eneter.messaging.endpoints.typedmessages.*;
import eneter.messaging.messagingsystems.messagingsystembase.*;
import eneter.messaging.messagingsystems.tcpmessagingsystem.TcpMessagingSystemFactory;
import eneter.net.system.EventHandler;
import android.app.Activity;
import android.os.Bundle;
import android.os.Handler;
import android.view.View;
import android.view.View.OnClickListener;
import android.widget.*;

public class AndroidNetCommunicationClientActivityInner extends Activity {

    // UI controls
    private Handler myRefresh = new Handler();
    private EditText myMessageTextEditText;
    private EditText myResponseEditText;
    private Button mySendRequestBtn;

    // Sender sending MyRequest and as a response receiving MyResponse.
    private IDuplexTypedMessageSender<MyResponse, MyRequest> mySender;

    /** Called when the activity is first created. */
    @Override
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.main);

        // Get UI widgets.
        myMessageTextEditText = (EditText) findViewById(R.id.messageTextEditText);
        myResponseEditText = (EditText) findViewById(R.id.messageLengthEditText);
        mySendRequestBtn = (Button) findViewById(R.id.sendRequestBtn);

        // Subscribe to handle the button click.
        mySendRequestBtn.setOnClickListener(myOnSendRequestClickHandler);

        try {
            openConnection();
        } catch (Exception err) {
            EneterTrace.error("Open connection failed.", err);
        }
    }

    @Override
    public void onDestroy() {
        // Stop listening to response messages.
        mySender.detachDuplexOutputChannel();
    }

    private void openConnection() throws Exception {
        // Create sender sending MyRequest and as a response receiving
        // MyResponse
        IDuplexTypedMessagesFactory aSenderFactory = new DuplexTypedMessagesFactory();
        mySender = aSenderFactory.createDuplexTypedMessageSender(
                MyResponse.class, MyRequest.class);

        // Subscribe to receive response messages.
        mySender.responseReceived().subscribe(myOnResponseHandler);

        // Create TCP messaging for the communication.
        // Note: 10.0.2.2 is a special alias to the loopback (127.0.0.1)
        // on the development machine.
        IMessagingSystemFactory aMessaging = new TcpMessagingSystemFactory();
        IDuplexOutputChannel anOutputChannel = aMessaging
                .createDuplexOutputChannel("tcp://10.0.2.2:8060/");

        // Attach the output channel to the sender and be able to send
        // messages and receive responses.
        mySender.attachDuplexOutputChannel(anOutputChannel);
    }

    private void onSendRequest(View v) {
        // Create the request message.
        MyRequest aRequestMsg = new MyRequest();
        aRequestMsg.Text = myMessageTextEditText.getText().toString();

        // Send the request message.
        try {
            mySender.sendRequestMessage(aRequestMsg);
        } catch (Exception err) {
            EneterTrace.error("Sending the message failed.", err);
        }
    }

    private void onResponseReceived(Object sender,
            final TypedResponseReceivedEventArgs<MyResponse> e) {
        // Display the result - returned number of characters.
        // Note: Marshal displaying to the correct UI thread.
        myRefresh.post(new Runnable() {
            public void run() {
                myResponseEditText.setText(Integer.toString(e
                        .getResponseMessage().Length));
            }
        });
    }

    private EventHandler<TypedResponseReceivedEventArgs<MyResponse>> myOnResponseHandler = new EventHandler<TypedResponseReceivedEventArgs<MyResponse>>() {
        public void onEvent(Object sender,
                TypedResponseReceivedEventArgs<MyResponse> e) {
            onResponseReceived(sender, e);
        }
    };

    private OnClickListener myOnSendRequestClickHandler = new OnClickListener() {
        public void onClick(View v) {
            onSendRequest(v);
        }
    };
}

Класс, который раньше был внутренним

public class MyRequest {
    public String Text;
}

2-й класс, который раньше был внутренним

public class MyResponse {
    public int Length;
}

Манифест

<manifest xmlns:android="http://schemas.android.com/apk/res/android"
    package="com.example.com.proto1"
    android:versionCode="1"
    android:versionName="1.0" >

    <uses-permission android:name="android.permission.INTERNET" />

    <uses-sdk
        android:minSdkVersion="8"
        android:targetSdkVersion="15" />

    <application
        android:icon="@drawable/theeye"
        android:label="@string/app_name"
        android:theme="@style/AppTheme" >
        <activity
            android:name=".mainj"
            android:label="@string/title_activity_mainj" >
            <intent-filter>
                <action android:name="android.intent.action.MAIN" />

                <category android:name="android.intent.category.LAUNCHER" />
            </intent-filter>
        </activity>
        <activity
            android:name=".menu"
            android:label="@string/app_name" >
            <intent-filter>
                <action android:name="android.intent.action.MENU" />

                <category android:name="android.intent.category.DEFAULT" />
            </intent-filter>
        </activity>
        <activity
            android:name=".Infoactive"
            android:label="@string/app_name" >
            <intent-filter>
                <action android:name="android.intent.action.INFOSCREEN" />

                <category android:name="android.intent.category.DEFAULT" />
            </intent-filter>
        </activity>
        <activity
            android:name=".VoicePrompts"
            android:label="@string/app_name" >
            <intent-filter>
                <action android:name="android.intent.action.VOICEPROMPTS" />

                <category android:name="android.intent.category.DEFAULT" />
            </intent-filter>
        </activity>
        <activity
            android:name=".VPon"
            android:label="@string/app_name" >
            <intent-filter>
                <action android:name="android.intent.action.VPON" />

                <category android:name="android.intent.category.DEFAULT" />
            </intent-filter>
        </activity>
        <activity
            android:name=".VPoff"
            android:label="@string/app_name" >
            <intent-filter>
                <action android:name="android.intent.action.VPOFF" />

                <category android:name="android.intent.category.DEFAULT" />
            </intent-filter>
        </activity>
        <!-- android name must match the name of the java you want to use -->
        <activity
            android:name=".VoiceRecognition"
            android:label="@string/app_name" >
            <intent-filter>
                <action android:name="android.intent.action.RECOGNITIONMENU" />

                <category android:name="android.intent.category.DEFAULT" />
            </intent-filter>
        </activity>
        <activity
            android:name=".Recognition"
            android:label="@string/app_name" >
            <intent-filter>
                <action android:name="ACTION_RECOGNIZE_SPEECH" />

                <category android:name="android.intent.category.DEFAULT" />
            </intent-filter>
        </activity>
        <activity
            android:name=".SpeakingAndroid"
            android:label="tts" >
            <intent-filter>
                <action android:name="android.intent.action.SPEAK" />

                <category android:name="android.intent.category.LAUNCHER" />
            </intent-filter>
        </activity>
        <activity
            android:name=".AndroidNetCommunicationClientActivity"
            android:label="@string/app_name" >
            <intent-filter>
                <action android:name="ANDROID_NET" />

                <category android:name="android.intent.category.DEFAULT" />
            </intent-filter>
        </activity>
        <activity
            android:name=".AndroidNetCommunicationClientActivityInner"
            android:label="@string/app_name" >
            <intent-filter>
                <action android:name="ANDROID_NET2" />

                <category android:name="android.intent.category.DEFAULT" />
            </intent-filter>
        </activity>
    </application>

</manifest>

person Sam Bevins    schedule 07.08.2012    source источник
comment
Используете ли вы какие-либо внешние .jar файлы? Если да означает, попробуйте это Или вы объявили все действия в файле AndroidManifest.xml?   -  person Praveenkumar    schedule 07.08.2012
comment
Я добавляю манифест сейчас. Я использую внешнюю банку, но она правильно вставлена.   -  person Sam Bevins    schedule 07.08.2012
comment
@SamBevins Можете ли вы указать строку 103 в коде? Символ $ указывает на анонимный внутренний класс.   -  person code-jaff    schedule 07.08.2012
comment
103 — это первая строка приватного обработчика событий.   -  person Sam Bevins    schedule 07.08.2012
comment
@SamBevins, я почти уверен, что вы следовали этому eneter.blogspot.de/2012/03/, но в учебнике в качестве типа сообщения использовался статический внутренний класс.   -  person code-jaff    schedule 07.08.2012
comment
статические внутренние классы не работали должным образом. На моем образце мне пришлось их удалить и сделать отдельные нестатические классы   -  person Sam Bevins    schedule 07.08.2012
comment
@SamBevins попробуйте мой ответ, лучше поместить эти классы так, как они были раньше (статические вложенные классы).   -  person code-jaff    schedule 07.08.2012


Ответы (3)


Я не уверен в ошибке, но $1 относится к анонимному внутреннему классу (классу без имени), подобному тому, который вы используете здесь.

private void onResponseReceived(Object sender,
        final TypedResponseReceivedEventArgs<MyResponse> e) {
    // Display the result - returned number of characters.
    // Note: Marshal displaying to the correct UI thread.
    myRefresh.post(new Runnable() {
        public void run() {
            myResponseEditText.setText(Integer.toString(e
                    .getResponseMessage().Length));
        }
    });
}

Технически вы создаете подкласс Runnable, который называется $1 и является внутренним по отношению к этому классу. Не уверен, что это за ошибка, хотя я бы попробовал перекомпилировать все

person James    schedule 07.08.2012
comment
Странно то, что кодирование идентично имеющемуся у меня рабочему образцу, который не выдает никаких ошибок. Как перекомпилировать? - person Sam Bevins; 07.08.2012
comment
@SamBevins Затем попробуйте очистить проект и повторить попытку или перезапустить IDE. - person code-jaff; 07.08.2012
comment
Я делал это несколько раз, но у меня все еще есть та же ошибка, что и в моем вопросе. - person Sam Bevins; 07.08.2012

Вы не все перекомпилировали. Либо так, либо у вас есть своенравная запись в вашем пути к классам.

person Hot Licks    schedule 07.08.2012

Я думаю, что понял проблему,

В файле манифеста пакет объявлен для AndroidNetCommunicationClientActivityInner как

package="com.example.com.proto1"

Но на самом деле у вас нет этого класса в этом пакете, а в пакете по умолчанию, поскольку в указанном файле JAVA нет объявления пакета.

Но андроид ищет этот пакет для этого класса, поэтому выдает java.lang.NoClassDefFoundError.

person code-jaff    schedule 07.08.2012
comment
Хорошо, я заменил два класса, но у меня все еще та же проблема. - person Sam Bevins; 08.08.2012
comment
@SamBevins Проблема, скорее всего, связана с объявлениями пакетов, вы пытались в этом разобраться? - person code-jaff; 08.08.2012
comment
Я новичок в программировании, поэтому не могу понять в чем проблема. Я попытался понять это. Чего я не понимаю, так это того, как мой пример кода работает, но не работает при использовании в моем реальном приложении. Я проверил все коды, но они одинаковы - person Sam Bevins; 08.08.2012
comment
@SamBevins хорошо, у вас есть этот package com.example.com.proto1; в верхней части вашего AndroidNetCommunicationClientActivityInner java-файла? - person code-jaff; 08.08.2012