我有一個測試JNI庫的Android應用程序。該應用程序有一個onClick
處理程序的按鈕:Button onClick的NoSuchMethod異常
<RelativeLayout
...
<Button
...
android:id="@+id/btnGenerate"
android:text="@string/btn_generate"
android:textAppearance="?android:attr/textAppearanceLarge"
android:onClick="btnGenerate_onClick"/>
</RelativeLayout>
然後,在主要活動:
public class MainActivity extends Activity {
...
protected void btnGenerate_onClick(View view)
{
// Do some work...
String str = <some result>;
final TextView lblNumbers = (TextView)findViewById(R.id.lblNumbers);
if(lblNumbers != null)
{
lblNumbers.setText(str);
}
}
}
當我點擊按鈕,我收到一個NoSuchMethodException
。
我解除了Android Button setOnClickListener Design Help的解決方案,所以我不確定它爲什麼不工作。
爲什麼代碼會導致NoSuchMethod
異常?
09-05 07:20:57.417: W/dalvikvm(10563): threadid=1: thread exiting with uncaught exception (group=0x40aae228)
09-05 07:20:57.437: E/AndroidRuntime(10563): FATAL EXCEPTION: main
09-05 07:20:57.437: E/AndroidRuntime(10563): java.lang.IllegalStateException: Could not find a method btnGenerate_onClick(View) in the activity class com.cryptopp.prng.MainActivity for onClick handler on view class android.widget.Button with id 'btnGenerate'
09-05 07:20:57.437: E/AndroidRuntime(10563): at android.view.View$1.onClick(View.java:3069)
09-05 07:20:57.437: E/AndroidRuntime(10563): at android.view.View.performClick(View.java:3549)
09-05 07:20:57.437: E/AndroidRuntime(10563): at android.view.View$PerformClick.run(View.java:14393)
09-05 07:20:57.437: E/AndroidRuntime(10563): at android.os.Handler.handleCallback(Handler.java:605)
09-05 07:20:57.437: E/AndroidRuntime(10563): at android.os.Handler.dispatchMessage(Handler.java:92)
09-05 07:20:57.437: E/AndroidRuntime(10563): at android.os.Looper.loop(Looper.java:154)
09-05 07:20:57.437: E/AndroidRuntime(10563): at android.app.ActivityThread.main(ActivityThread.java:4945)
09-05 07:20:57.437: E/AndroidRuntime(10563): at java.lang.reflect.Method.invokeNative(Native Method)
09-05 07:20:57.437: E/AndroidRuntime(10563): at java.lang.reflect.Method.invoke(Method.java:511)
09-05 07:20:57.437: E/AndroidRuntime(10563): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:784)
09-05 07:20:57.437: E/AndroidRuntime(10563): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:551)
09-05 07:20:57.437: E/AndroidRuntime(10563): at dalvik.system.NativeStart.main(Native Method)
09-05 07:20:57.437: E/AndroidRuntime(10563): Caused by: java.lang.NoSuchMethodException: btnGenerate_onClick [class android.view.View]
09-05 07:20:57.437: E/AndroidRuntime(10563): at java.lang.Class.getConstructorOrMethod(Class.java:460)
09-05 07:20:57.437: E/AndroidRuntime(10563): at java.lang.Class.getMethod(Class.java:915)
09-05 07:20:57.437: E/AndroidRuntime(10563): at android.view.View$1.onClick(View.java:3062)
09-05 07:20:57.437: E/AndroidRuntime(10563): ... 11 more
make btnGenerate_onClick(查看查看)公開 – 2014-09-05 11:31:11