gpt4 book ai didi

java - 导致崩溃的setText

转载 作者:行者123 更新时间:2023-11-29 22:11:20 25 4
gpt4 key购买 nike

在过去一周的每一天的大部分时间里,我一直在从事这个通过电位器输入控制文本字段的项目,而我的 setText 命令总是使程序崩溃。我厌倦了修补和调试,但收效甚微,我急需一些帮助。

如果您需要查看所有项目文件,我也可以上传它们。

搜索“This line causes a crash”

package edu.uidaho.pong;

import java.io.IOException;

import android.content.Context;
import android.graphics.Canvas;
import android.graphics.Paint;
import android.os.Handler;
import android.os.Message;
import android.widget.Toast;
import android.app.Activity;

import android.view.SurfaceHolder;

public class GameThread extends Thread {


/** Handle to the surface manager object we interact with */
private SurfaceHolder _surfaceHolder;
private Paint _paint;
private GameState _state;
public PongActivity _pong;

public GameThread(SurfaceHolder surfaceHolder, Context context,
Handler handler) {
_surfaceHolder = surfaceHolder;
_paint = new Paint();
_state = new GameState();
_pong = new PongActivity();

}

// @Override
public void run() {
while (true) {
Canvas canvas = _surfaceHolder.lockCanvas();
_state.update(_pong);
_state.draw(canvas, _paint);
_surfaceHolder.unlockCanvasAndPost(canvas);


int ret = 0;
byte[] buffer = new byte[16384];
int i;

int tempdebug = 0;
//while (true) { // read data
while (tempdebug++ < 10){
// try {
// ret = _pong.mInputStream.read(buffer);
// } catch (IOException e) {
// break;
// }
ret = 5; // let's pretend there's a 5 every time since I can't test the usb

i = 0;
while (i < ret) {
int len = ret - i;
if (len >= 1) {
Message m = Message.obtain(_pong.mHandler);
int value = (int)buffer[i];
// 'f' is the flag, use for your own logic
// value is the value from the arduino
m.obj = new ValueMsg('f', value);
_pong.mHandler.sendMessage(m);
}
i += 1; // number of bytes sent from arduino
}
}
//_pong.mResponseField.setText("Reading: "); This line causes a crash

}
}

public GameState getGameState() {
return _state;
}
}

Logcat 输出 -

03-03 22:45:49.639: W/dalvikvm(381): threadid=9: thread exiting with uncaught exception (group=0x40015560)
03-03 22:45:49.639: E/AndroidRuntime(381): FATAL EXCEPTION: Thread-10
03-03 22:45:49.639: E/AndroidRuntime(381): java.lang.NullPointerException
03-03 22:45:49.639: E/AndroidRuntime(381): at edu.uidaho.pong.GameThread.run(GameThread.java:70)
03-03 22:45:50.189: E/global(381): Deprecated Thread methods are not supported.
03-03 22:45:50.189: E/global(381): java.lang.UnsupportedOperationException
03-03 22:45:50.189: E/global(381): at java.lang.VMThread.stop(VMThread.java:85)
03-03 22:45:50.189: E/global(381): at java.lang.Thread.stop(Thread.java:1280)
03-03 22:45:50.189: E/global(381): at java.lang.Thread.stop(Thread.java:1247)
03-03 22:45:50.189: E/global(381): at edu.uidaho.pong.GameView.surfaceDestroyed(GameView.java:46)
03-03 22:45:50.189: E/global(381): at android.view.SurfaceView.reportSurfaceDestroyed(SurfaceView.java:587)
03-03 22:45:50.189: E/global(381): at android.view.SurfaceView.updateWindow(SurfaceView.java:481)
03-03 22:45:50.189: E/global(381): at android.view.SurfaceView.onWindowVisibilityChanged(SurfaceView.java:213)
03-03 22:45:50.189: E/global(381): at android.view.View.dispatchWindowVisibilityChanged(View.java:4027)
03-03 22:45:50.189: E/global(381): at android.view.ViewGroup.dispatchWindowVisibilityChanged(ViewGroup.java:720)
03-03 22:45:50.189: E/global(381): at android.view.ViewGroup.dispatchWindowVisibilityChanged(ViewGroup.java:720)
03-03 22:45:50.189: E/global(381): at android.view.ViewGroup.dispatchWindowVisibilityChanged(ViewGroup.java:720)
03-03 22:45:50.189: E/global(381): at android.view.ViewGroup.dispatchWindowVisibilityChanged(ViewGroup.java:720)
03-03 22:45:50.189: E/global(381): at android.view.ViewRoot.performTraversals(ViewRoot.java:782)
03-03 22:45:50.189: E/global(381): at android.view.ViewRoot.handleMessage(ViewRoot.java:1859)
03-03 22:45:50.189: E/global(381): at android.os.Handler.dispatchMessage(Handler.java:99)
03-03 22:45:50.189: E/global(381): at android.os.Looper.loop(Looper.java:130)
03-03 22:45:50.189: E/global(381): at android.app.ActivityThread.main(ActivityThread.java:3683)
03-03 22:45:50.189: E/global(381): at java.lang.reflect.Method.invokeNative(Native Method)
03-03 22:45:50.189: E/global(381): at java.lang.reflect.Method.invoke(Method.java:507)
03-03 22:45:50.189: E/global(381): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:839)
03-03 22:45:50.189: E/global(381): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:597)
03-03 22:45:50.189: E/global(381): at dalvik.system.NativeStart.main(Native Method)

最佳答案

我不能准确地说,因为没有 logcat,但这可能是因为您试图从单独的线程更改 TextView,这在 Android 中是被禁止的。此问题的解决方案之一是在运行单独线程的类中放置对您的 Activity 的引用,并将任何 View 更改代码放置在 Activity 中。 runOnUiThread() 方法,它以 Runnable 作为参数。希望这会有所帮助。

编辑

_pong.runOnUiThread(new Runnable() {

@Override
public void run() {
_pong.mResponseField.setText("Reading: ");
}
});

关于java - 导致崩溃的setText,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/9552806/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com