我刚刚得到一个快速的问题。 我试图通过发送TCP包来与应用程序进行通信,然后服务器将TCP包发送回其他设备。 但是我怎么能做一个服务,当它通知的设备上收到TCP包时?android发送和接收TCP包
我试过了;
extends Service {
Thread henk;
private static final String TAG = "Service";
@Override
public IBinder onBind(Intent intent) {
// TODO Auto-generated method stub
return null;
}
@Override
public void onCreate() {
Toast.makeText(this, "My Service Created", Toast.LENGTH_LONG).show();
Log.d(TAG, "onCreate");
henk = new Thread(new Runnable(){
public void run() {
// TODO Auto-generated method stub
try {
Boolean end = false;
ServerSocket ss = new ServerSocket(1337);
while(!end){
//Server is waiting for client here, if needed
Socket s = ss.accept();
BufferedReader input = new BufferedReader(new InputStreamReader(s.getInputStream()));
String st = input.readLine();
Log.d("Tcp Example", "From client: "+st);
s.close();
}
ss.close();
} catch (UnknownHostException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
});
}
@Override
public void onDestroy() {
Toast.makeText(this, "My Service Stopped", Toast.LENGTH_LONG).show();
Log.d(TAG, "onDestroy");
}
@Override
public void onStart(Intent intent, int startid) {
Toast.makeText(this, "My Service Started", Toast.LENGTH_LONG).show();
Log.d(TAG, "onStart");
henk.run();
}
但是,这只是崩溃我的应用程序。 请帮忙吗?
堆栈跟踪:
E/ActivityManager( 240): ANR in tictactoe.elqauto
E/ActivityManager( 240): Reason: Executing service tictactoe.elqauto/.servicere
cieve
E/ActivityManager( 240): Load: 7.09/7.29/7.5
E/ActivityManager( 240): CPU usage from 9411ms to 3791ms ago:
E/ActivityManager( 240): 1.2% 3857/de.devmil.minimaltext: 1.1% user + 0.1% ke
rnel/faults: 191 minor
E/ActivityManager( 240): 2.5% 240/system_server: 1.9% user + 0.5% kernel/fa
ults: 20 minor
E/ActivityManager( 240): 0.1% 4797/tiwlan_wq: 0% user + 0.1% kernel
E/ActivityManager( 240): 0% 16322/org.adwfreak.launcher: 0% user + 0% kernel
/faults: 226 minor 1 major
E/ActivityManager( 240): 0% 19108/com.aricent.mtp: 0% user + 0% kernel/faul
ts: 16 minor
E/ActivityManager( 240): 0% 30600/com.google.process.gapps: 0% user + 0% kern
el/faults: 20 minor 5 major
E/ActivityManager( 240): 11% TOTAL: 8% user + 3% kernel + 0.1% iowait
E/ActivityManager( 240): CPU usage from 368ms to 884ms later:
E/ActivityManager( 240): 5.6% 240/system_server: 1.8% user + 3.7% kernel/fa
ults: 15 minor
E/ActivityManager( 240): 5.6% 266/ActivityManager: 1.8% user + 3.7% kernel
E/ActivityManager( 240): 44% TOTAL: 1.9% user + 1.9% kernel + 40% iowait
摘要:
所以我想要做的就是发送一个TCP包一个名称服务器的服务器将获得与所属的IP从数据库中找到该名称,并用一些信息发送一个TCP包到它。由于我没有找到解决方案,我尝试了套接字,但现在我被卡在接收部分。
我已经这样做 –
你用过logcat吗?如果可以的话,当应用程序崩溃时,从logcat发布堆栈跟踪:'adb logcat -s *:E'应该在命令行中执行。我的猜测是尝试从UI线程更新UI,但崩溃输出肯定会告诉你。 – jarvisteve
@jarvisteve写栈跟踪到'/data/anr/traces.txt'但我找不到那个文件? –