Android(java)学习笔记116:PC_Phone通信程序报错

1.首先我写的程序代码如下:

 1 package com.himi.udpsend;
 2
 3 import java.net.DatagramPacket;
 4 import java.net.DatagramSocket;
 5 import java.net.DatagramSocketImpl;
 6 import java.net.InetAddress;
 7 import java.net.SocketException;
 8 import java.net.UnknownHostException;
 9
10 import android.app.Activity;
11 import android.content.Context;
12 import android.net.wifi.WifiInfo;
13 import android.net.wifi.WifiManager;
14 import android.os.Bundle;
15 import android.util.Log;
16 import android.view.View;
17 import android.view.View.OnClickListener;
18 import android.widget.Button;
19 import android.widget.EditText;
20
21
22 public class MainActivity extends Activity implements OnClickListener {
23     private EditText edittext;
24     private Button  btnsend;
25     private WifiInfo wifiInfo;
26     @Override
27     protected void onCreate(Bundle savedInstanceState) {
28         super.onCreate(savedInstanceState);
29         setContentView(R.layout.activity_main);
30
31         edittext = (EditText)findViewById(R.id.edit);
32         btnsend = (Button)findViewById(R.id.btnsend);
33
34         btnsend.setOnClickListener(this);
35
36         WifiManager wman = (WifiManager) getSystemService(Context.WIFI_SERVICE);
37
38         if(! wman.isWifiEnabled()) {
39             wman.setWifiEnabled(true);
40         }
41         Log.e("ip", intToIp(wifiInfo.getIpAddress()));//获得本机ip
42
43     }
44
45
46     public String intToIp(int i) {
47         return (i & 0xff) +"."+
48           ((i>>8) & 0xff )+"."+
49           ((i>>16) & 0xff )+"."+
50           ((i>>24) & 0xff );
51
52     }
53
54
55
56
57     public void onClick(View v) {
58
59         try {
60             // 创建发送端socket对象
61             DatagramSocket ds = new DatagramSocket();
62
63             // 创建数据并打包
64             String edit_content = edittext.getText().toString();
65             byte[] bys = edit_content.getBytes();
66             int length = bys.length;
67
68             String ip = intToIp(wifiInfo.getIpAddress());
69             InetAddress hostip = InetAddress.getByName(ip);
70
71             int port = 10086;
72             DatagramPacket dp = new DatagramPacket(bys, length, hostip, port);
73
74             //发送数据包
75             ds.send(dp);
76             //关闭套接字,回收资源
77             ds.close();
78
79         } catch (Exception e) {
80             // TODO 自动生成的 catch 块
81             e.printStackTrace();
82         }
83
84
85     }
86
87
88
89
90 }

2.报错如下:

06-26 02:37:29.270: E/Trace(841): error opening trace file: No such file or directory (2)
06-26 02:37:30.400: D/AndroidRuntime(841): Shutting down VM
06-26 02:37:30.400: W/dalvikvm(841): threadid=1: thread exiting with uncaught exception (group=0x40a71930)
06-26 02:37:30.540: E/AndroidRuntime(841): FATAL EXCEPTION: main
06-26 02:37:30.540: E/AndroidRuntime(841): java.lang.RuntimeException: Unable to start activity ComponentInfo{com.himi.udpsend/com.himi.udpsend.MainActivity}: java.lang.NullPointerException
06-26 02:37:30.540: E/AndroidRuntime(841):     at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2180)
06-26 02:37:30.540: E/AndroidRuntime(841):     at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2230)
06-26 02:37:30.540: E/AndroidRuntime(841):     at android.app.ActivityThread.access$600(ActivityThread.java:141)
06-26 02:37:30.540: E/AndroidRuntime(841):     at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1234)
06-26 02:37:30.540: E/AndroidRuntime(841):     at android.os.Handler.dispatchMessage(Handler.java:99)
06-26 02:37:30.540: E/AndroidRuntime(841):     at android.os.Looper.loop(Looper.java:137)
06-26 02:37:30.540: E/AndroidRuntime(841):     at android.app.ActivityThread.main(ActivityThread.java:5041)
06-26 02:37:30.540: E/AndroidRuntime(841):     at java.lang.reflect.Method.invokeNative(Native Method)
06-26 02:37:30.540: E/AndroidRuntime(841):     at java.lang.reflect.Method.invoke(Method.java:511)
06-26 02:37:30.540: E/AndroidRuntime(841):     at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:793)
06-26 02:37:30.540: E/AndroidRuntime(841):     at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:560)
06-26 02:37:30.540: E/AndroidRuntime(841):     at dalvik.system.NativeStart.main(Native Method)
06-26 02:37:30.540: E/AndroidRuntime(841): Caused by: java.lang.NullPointerException
06-26 02:37:30.540: E/AndroidRuntime(841):     at com.himi.udpsend.MainActivity.onCreate(MainActivity.java:41)
06-26 02:37:30.540: E/AndroidRuntime(841):     at android.app.Activity.performCreate(Activity.java:5104)
06-26 02:37:30.540: E/AndroidRuntime(841):     at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1080)
06-26 02:37:30.540: E/AndroidRuntime(841):     at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2144)
06-26 02:37:30.540: E/AndroidRuntime(841):     ... 11 more
06-26 02:37:34.910: I/Process(841): Sending signal. PID: 841 SIG: 9

原因:空指针异常,这时就要查看自己的程序中是否存在空指针。

4.解决办法是:

 1 package com.himi.udpsend;
 2
 3 import java.net.DatagramPacket;
 4 import java.net.DatagramSocket;
 5 import java.net.DatagramSocketImpl;
 6 import java.net.InetAddress;
 7 import java.net.SocketException;
 8 import java.net.UnknownHostException;
 9
10 import android.app.Activity;
11 import android.content.Context;
12 import android.net.wifi.WifiInfo;
13 import android.net.wifi.WifiManager;
14 import android.os.Bundle;
15 import android.util.Log;
16 import android.view.View;
17 import android.view.View.OnClickListener;
18 import android.widget.Button;
19 import android.widget.EditText;
20
21
22 public class MainActivity extends Activity implements OnClickListener {
23     private EditText edittext;
24     private Button  btnsend;
25     private WifiInfo wifiInfo;
26     @Override
27     protected void onCreate(Bundle savedInstanceState) {
28         super.onCreate(savedInstanceState);
29         setContentView(R.layout.activity_main);
30
31         edittext = (EditText)findViewById(R.id.edit);
32         btnsend = (Button)findViewById(R.id.btnsend);
33
34         btnsend.setOnClickListener(this);
35
36         WifiManager wman = (WifiManager) getSystemService(Context.WIFI_SERVICE);
37
38         if(! wman.isWifiEnabled()) {
39             wman.setWifiEnabled(true);
40         }//没有正确使用Log()
41         //Log.e("ip", intToIp(wifiInfo.getIpAddress()));//获得本机ip
42
43     }
44
45
46     public String intToIp(int i) {
47         return (i & 0xff) +"."+
48           ((i>>8) & 0xff )+"."+
49           ((i>>16) & 0xff )+"."+
50           ((i>>24) & 0xff );
51
52     }
53
54
55
56
57     public void onClick(View v) {
58
59         try {
60             // 创建发送端socket对象
61             DatagramSocket ds = new DatagramSocket();
62
63             // 创建数据并打包
64             String edit_content = edittext.getText().toString();
65             byte[] bys = edit_content.getBytes();
66             int length = bys.length;
67
68             String ip = intToIp(wifiInfo.getIpAddress());
69             InetAddress hostip = InetAddress.getByName(ip);
70
71             int port = 10086;
72             DatagramPacket dp = new DatagramPacket(bys, length, hostip, port);
73
74             //发送数据包
75             ds.send(dp);
76             //关闭套接字,回收资源
77             ds.close();
78
79         } catch (Exception e) {
80             // TODO 自动生成的 catch 块
81             e.printStackTrace();
82         }
83
84
85     }
86
87
88
89
90 }
时间: 2024-10-07 00:33:25

Android(java)学习笔记116:PC_Phone通信程序报错的相关文章

Android开发学习笔记-实现联网检测程序版本

package com.frank.mobilesafe; import java.io.InputStream; import java.net.HttpURLConnection; import java.net.MalformedURLException; import java.net.URI; import java.net.URL; import javax.net.ssl.HttpsURLConnection; import org.apache.http.HttpClientCo

【学习笔记】MYSQL的floor报错原理分析总结

参考链接:http://mp.weixin.qq.com/s?__biz=MzA5NDY0OTQ0Mw==&mid=403404979&idx=1&sn=27d10b6da357d72304086311cefd573e&scene=1&srcid=04131X3lQlrDMYOCntCqWf6n#wechat_redirect 网上关于floor报错的文章很多,但都是利用语句,介绍原理的文章大多一笔带过,不过我终于找到一篇像样的原理文章,于是参考着来理解原理,参考的

java/android 设计模式学习笔记(14)---外观模式

这篇博客来介绍外观模式(Facade Pattern),外观模式也称为门面模式,它在开发过程中运用频率非常高,尤其是第三方 SDK 基本很大概率都会使用外观模式.通过一个外观类使得整个子系统只有一个统一的高层的接口,这样能够降低用户的使用成本,也对用户屏蔽了很多实现细节.当然,在我们的开发过程中,外观模式也是我们封装 API 的常用手段,例如网络模块.ImageLoader 模块等.其实我们在开发过程中可能已经使用过很多次外观模式,只是没有从理论层面去了解它. 转载请注明出处:http://bl

java/android 设计模式学习笔记(9)---代理模式

这篇博客我们来介绍一下代理模式(Proxy Pattern),代理模式也成为委托模式,是一个非常重要的设计模式,不少设计模式也都会有代理模式的影子.代理在我们日常生活中也很常见,比如上网时连接的代理服务器地址,更比如我们平时租房子,将找房子的过程代理给中介等等,都是代理模式在日常生活中的使用例子. 代理模式中的代理对象能够连接任何事物:一个网络连接,一个占用很多内存的大对象,一个文件,或者是一些复制起来代价很高甚至根本不可能复制的一些资源.总之,代理是一个由客户端调用去访问幕后真正服务的包装对象

java/android 设计模式学习笔记(2)---观察者模式

这篇来讲一下观察者模式,观察者模式在实际项目中使用的也是非常频繁的,它最常用的地方是GUI系统.订阅--发布系统等.因为这个模式的一个重要作用就是解耦,使得它们之间的依赖性更小,甚至做到毫无依赖.以GUI系统来说,应用的UI具有易变性,尤其是前期随着业务的改变或者产品的需求修改,应用界面也经常性变化,但是业务逻辑基本变化不大,此时,GUI系统需要一套机制来应对这种情况,使得UI层与具体的业务逻辑解耦,观察者模式此时就派上用场了. PS:对技术感兴趣的同鞋加群544645972一起交流. 设计模式

java/android 设计模式学习笔记(5)---对象池模式

这次要介绍一下对象池模式(Object Pool Pattern),这个模式为常见 23 种设计模式之外的设计模式,介绍的初衷主要是在平时的 android 开发中经常会看到,比如 ThreadPool 和 MessagePool 等. 在 java 中,所有对象的内存由虚拟机管理,所以在某些情况下,需要频繁创建一些生命周期很短使用完之后就可以立即销毁,但是数量很大的对象集合,那么此时 GC 的次数必然会增加,这时候为了减小系统 GC 的压力,对象池模式就很适用了.对象池模式也是创建型模式之一,

java/android 设计模式学习笔记(一)---单例模式

前段时间公司一些同事在讨论单例模式(我是最渣的一个,都插不上嘴 T__T ),这个模式使用的频率很高,也可能是很多人最熟悉的设计模式,当然单例模式也算是最简单的设计模式之一吧,简单归简单,但是在实际使用的时候也会有一些坑. PS:对技术感兴趣的同鞋加群544645972一起交流 设计模式总目录 java/android 设计模式学习笔记目录 特点 确保某一个类只有一个实例,而且自行实例化并向整个系统提供这个实例. 单例模式的使用很广泛,比如:线程池(threadpool).缓存(cache).对

java/android 设计模式学习笔记(7)---装饰者模式

这篇将会介绍装饰者模式(Decorator Pattern),装饰者模式也称为包装模式(Wrapper Pattern),结构型模式之一,其使用一种对客户端透明的方式来动态的扩展对象的功能,同时它也是继承关系的一种替代方案之一,但比继承更加灵活.在现实生活中也可以看到很多装饰者模式的例子,或者可以大胆的说装饰者模式无处不在,就拿一件东西来说,可以给它披上无数层不一样的外壳,但是这件东西还是这件东西,外壳不过是用来扩展这个东西的功能而已,这就是装饰者模式,装饰者的这个角色也许各不相同但是被装饰的对

java/android 设计模式学习笔记(13)---享元模式

这篇我们来介绍一下享元模式(Flyweight Pattern),Flyweight 代表轻量级的意思,享元模式是对象池的一种实现.享元模式用来尽可能减少内存使用量,它适合用于可能存在大量重复对象的场景,缓存可共享的对象,来达到对象共享和避免创建过多对象的效果,这样一来就可以提升性能,避免内存移除和频繁 GC 等. 享元模式的一个经典使用案例是文本系统中图形显示所用的数据结构,一个文本系统能够显示的字符种类就是那么几十上百个,那么就定义这么些基础字符对象,存储每个字符的显示外形和其他的格式化数据