微波EDA网,见证研发工程师的成长!
首页 > 硬件设计 > 嵌入式设计 > J2ME中多线程网络连接编程的分析

J2ME中多线程网络连接编程的分析

时间:05-04 来源:互联网 点击:

//创建新线程

newThread(newConnectPipe()).start();

}

elseif(c==backCommand){

……

}

}

修改之后程序能够较为顺利的运行,当处理网络连接的时候,启动一个线程后主线程会立刻返回,两个线程并行,不会引发在此地堵塞。其工作原理可用图3的工作原理图b来表示。

图3工作原理图b

详细分析图3,又发现尽管程序可以正常工作,但是每次用户按下按钮的时候都会有新的线程产生,这样显然不够高效,同时,异步的行为又有可能使两个线程间产生死锁。幸好java中提供了wait()和notify()/notifyAll()来进行线程间的通讯,协调同步问题。那么对应本程序中的线程同步问题,设计思想如下:启动线程后,让其进入等待的状态,当用户激活Command事件的时候唤醒线程,才让其继续运行。代码类似如下:

publicsynchronizedvoidrun(){

while(dealing){

try{wait();}//线程等待

catch(InterruptedExceptionie){}

if(dealing)requestConnect();

}

}

publicsynchronizedvoiddeal(){

notify();//唤醒线程

}

其中dealing变量用于定义一个锁,当其为true时,当前线程等待,直到用户激活Command事件之后,调用deal()方法中的notify()唤醒当前线程继续运行。这样程序就显得相当的高效,也在很大程度上避免了线程间的死锁问题。其工作原理可用图4的工作原理图c来表示。

图4工作原理图c

2.2利用系统类Timer和TimerTask

系统类Timer类是一个计时器,和TimerTask类结合可以来实现在MIDlet中定时执行特定任务。需要说明的是每一个Timer对象实际上都是一个后台运行的独立的线程。这是因为调度一次的任务都是由TimerTask类的实现对象负责,TimerTask类是一个抽象类,它的主要特点是实现了Runnable接口,因此扩展了必须实现的publicvoidrun()方法。

所以,在J2ME的网络编程中,我们可以利用Timer类和TimerTask类来建立线程,完成网络连接等工作。设计思想如下:创建一个Timer类计时器,一个完成网络连接功能的TimerTask类,在系统空闲时,反复调度任务要求连接,直到连接成功,再调用TimerTask类的cancel()可以停止一个具体的调度任务。核心代码类似如下:

classConnectTimerimplementTimerTask{

ConnectTimer(){

m_Timer=newTimer();//定义Timer

m_Timer.schedule(this,500,5000);//调度任务

}

……

publicsynchronizedvoidrun(){

requestConnect();//连接方法

cancel();//取消任务

}

}

publicvoidcommandAction(Commandc,Displayables){

if(c==sendCommand){

newConnectTimer;}

elseif(c==backCommand){

……

}

}

3、结束语

综上所述,在J2ME的应用开发中网络程序的设计具有重要的地位,而编程的关键又在于编写高效友好的J2ME网络连接程序。通过Java语言内置的多线程处理机制,利用线程进行同步并行处理,解决了网络连接时的阻塞问题,达到了程序高效运行的目的

Copyright © 2017-2020 微波EDA网 版权所有

网站地图

Top