java.lang.ClassCastException: android.os.BinderProxy ne peut pas être lancé à LocalBinder
J'ai un Service
que je suis en train d'essayer de se lier à mon principal Activity
, mais je reçois un
java.lang.ClassCastException: android.os.BinderProxy ne peut pas être lancé pour com.walintukai.rubix.ConnectionService$LocalBinder.
J'ai déclaré le service dans mon manifeste. Pourquoi est-ce arrivé?
Manifeste Déclaration
<service android:name=".ConnectionService" />
Service (simplifié code)
public class ConnectionService extends Service {
static final String TAG = ConnectionService.class.getName();
private BluetoothAdapter mBtAdapter = null;
public BluetoothGatt mBluetoothGatt = null;
private ConnectionServiceEventListener mIRedBearServiceEventListener;
HashMap<String, BluetoothDevice> mDevices = null;
private BluetoothGattCharacteristic txCharc = null;
private final IBinder mBinder = new LocalBinder();
@Override
public IBinder onBind(Intent intent) {
return mBinder;
}
public class LocalBinder extends Binder {
public ConnectionService getService() {
return ConnectionService.this;
}
}
@Override
public void onCreate() {
super.onCreate();
final BluetoothManager bluetoothManager = (BluetoothManager) getSystemService(Context.BLUETOOTH_SERVICE);
mBtAdapter = bluetoothManager.getAdapter();
if (mBtAdapter == null)
return;
if (mDevices == null)
mDevices = new HashMap<String, BluetoothDevice>();
}
@Override
public void onDestroy() {
if (mBluetoothGatt == null)
return;
mBluetoothGatt.close();
mBluetoothGatt = null;
super.onDestroy();
}
}
Activité Principale
public class MainActivity extends ActionBarActivity {
private ConnectionService service;
ServiceConnection connection = new ServiceConnection() {
@Override
public void onServiceDisconnected(ComponentName name) {
Log.i("ConnectionService", "Disconnected");
service = null;
}
@Override
public void onServiceConnected(ComponentName name, IBinder service) {
LocalBinder binder = (LocalBinder) service;
service = (IBinder) binder.getService();
if (service != null) {
Log.i("RedBearService", "Connected");
}
}
};
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
if (savedInstanceState == null) {
getSupportFragmentManager().beginTransaction().add(R.id.container, ViewPagerFragment.newInstance()).commit();
}
}
@Override
public void onStart() {
super.onStart();
startService();
}
@Override
public void onStop() {
super.onStop();
stopService();
}
private void startService() {
Intent service = new Intent(this, ConnectionService.class);
bindService(service, connection, Context.BIND_AUTO_CREATE);
}
private void stopService() {
unbindService(connection);
}
}
Stacktrace
07-30 17:19:39.065: E/AndroidRuntime(20891): java.lang.ClassCastException: android.os.BinderProxy cannot be cast to com.walintukai.rubix.ConnectionService$LocalBinder
07-30 17:19:39.065: E/AndroidRuntime(20891): at com.walintukai.rubix.MainActivity$1.onServiceConnected(MainActivity.java:58)
07-30 17:19:39.065: E/AndroidRuntime(20891): at android.app.LoadedApk$ServiceDispatcher.doConnected(LoadedApk.java:1110)
07-30 17:19:39.065: E/AndroidRuntime(20891): at android.app.LoadedApk$ServiceDispatcher$RunConnection.run(LoadedApk.java:1127)
07-30 17:19:39.065: E/AndroidRuntime(20891): at android.os.Handler.handleCallback(Handler.java:733)
07-30 17:19:39.065: E/AndroidRuntime(20891): at android.os.Handler.dispatchMessage(Handler.java:95)
07-30 17:19:39.065: E/AndroidRuntime(20891): at android.os.Looper.loop(Looper.java:136)
07-30 17:19:39.065: E/AndroidRuntime(20891): at android.app.ActivityThread.main(ActivityThread.java:5050)
07-30 17:19:39.065: E/AndroidRuntime(20891): at java.lang.reflect.Method.invokeNative(Native Method)
07-30 17:19:39.065: E/AndroidRuntime(20891): at java.lang.reflect.Method.invoke(Method.java:515)
07-30 17:19:39.065: E/AndroidRuntime(20891): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:789)
07-30 17:19:39.065: E/AndroidRuntime(20891): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:605)
07-30 17:19:39.065: E/AndroidRuntime(20891): at dalvik.system.NativeStart.main(Native Method)
Ne vous lancez le service sur le même processus que celui de l'application?
Devrait être. Comment puis-je vérifier? Je suis en train de créer et de liaison du service à la
S'il vous plaît montrer comment vous déclarez le service dans le fichier de manifeste.
Pouvez-vous fournir votre activité principale code?
Modifié pour inclure l'activité principale et le manifeste de la déclaration.
Devrait être. Comment puis-je vérifier? Je suis en train de créer et de liaison du service à la
onStart
appel de mon Activité principale.S'il vous plaît montrer comment vous déclarez le service dans le fichier de manifeste.
Pouvez-vous fournir votre activité principale code?
Modifié pour inclure l'activité principale et le manifeste de la déclaration.
OriginalL'auteur The Nomad | 2014-07-31
Vous devez vous connecter pour publier un commentaire.
Vous avez renversé:
devrait être:
OriginalL'auteur dcow
Cette question est une question de quelques années et l'on a accepté la réponse n'a pas fonctionné pour moi. Peut-être que quelque chose a changé dans l'environnement Android depuis que la question a été posée et répondue.
Mais je suis tombé sur une solution simple qui a fonctionné. J'ai vu une autre question ALORS, c'était d'essayer de démarrer 2 services, et ils ont eu une erreur similaire (Prise en java.lang.ClassCastException: android.os.BinderProxy à chaque fois que je déclarer et d'exécuter des deux services). L'une des réponses (@Coeffect) a mentionné que les 2 services ne sont pas nécessairement dans le même processus.
Je suis arrivé à penser qu'il est possible (probable?) que dans mon cas, l'activité et le service ont été faites dans les différents processus. J'ai donc ajouté le
android:process
élément à la fois de mon activité et de mon serveur, et qu'il fixe.Voici un exemple AndroidManifest.xml. Il est à noter que la
<activity>
et<service>
tags incluentandroid:process=":location"
:OriginalL'auteur ByteSlinger