2007-11-23
多线程的socket对象传输(DTO)示例
刚温习了一下DTO,自己做的一个多线程的socket数据传输示例!
AtomsServer.java
ServerHandle.java
AtomsClient.java
AtomsData.java
AtomsServer.java
package exam.lingling;
import java.io.IOException;
import java.net.ServerSocket;
import java.net.Socket;
import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;
public class AtomsServer
{
private int port = 8833;
private ServerSocket serverSocket;
private ExecutorService executorService;
private final int POOL_SIZE = 10;
public AtomsServer()
{
try
{
serverSocket = new ServerSocket(port);
executorService = Executors.newFixedThreadPool(Runtime.getRuntime().availableProcessors() * POOL_SIZE);
System.out.println("The server has started!");
} catch (IOException e)
{
System.out.println(e.getMessage());
}
}
public void serviceStart()
{
while (true)
{
Socket socket = null;
try
{
socket = serverSocket.accept();
executorService.execute(new ServerHandle(socket));
} catch (Exception e)
{
e.printStackTrace();
}
}
}
public static void main(String[] args)
{
new AtomsServer().serviceStart();
}
}
ServerHandle.java
package exam.lingling;
import java.io.IOException;
import java.io.ObjectInputStream;
import java.net.Socket;
public class ServerHandle implements Runnable
{
private Socket socket;
public ServerHandle(Socket socket)
{
this.socket = socket;
}
private ObjectInputStream getAtomsReceive(Socket socket) throws IOException
{
return new ObjectInputStream(socket.getInputStream());
}
public void run()
{
try
{
ObjectInputStream ois = this.getAtomsReceive(socket);
Object o = ois.readObject();
while (o != null)
{
AtomsData atomsdata = (AtomsData) o;
System.out.println("The version of operation is " + atomsdata.getVersion() + " .");
}
} catch (IOException e)
{
e.printStackTrace();
System.out.println(e.getMessage());
} catch (ClassNotFoundException e)
{
e.printStackTrace();
} finally
{
try
{
if (socket != null)
socket.close();
} catch (Exception e)
{
e.printStackTrace();
}
}
}
}
AtomsClient.java
package exam.lingling;
import java.io.IOException;
import java.io.ObjectOutputStream;
import java.net.Socket;
import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;
public class AtomsClient
{
public static void main(String args[]) throws InterruptedException
{
ExecutorService exec = Executors.newFixedThreadPool(2);
for (int index = 0; index < 10; index++)
{
Runnable run = new Runnable()
{
private Socket socket = null;
private int port = 8833;
AtomsData atomsdata;
ObjectOutputStream oos = null;
public void run()
{
while (true)
{
try
{
socket = new Socket("localhost", port);
atomsdata = new AtomsData();
atomsdata.setVersion((new Double((long) (Math.random() * 1000))).toString());
oos = new ObjectOutputStream(socket.getOutputStream());
oos.writeObject(atomsdata);
} catch (IOException e)
{
e.printStackTrace();
} finally
{
try
{
oos.close();
} catch (Exception e)
{
e.printStackTrace();
}
}
}
}
};
exec.execute(run);
}
exec.shutdown();
}
}
AtomsData.java
package exam.lingling;
import java.io.Serializable;
public class AtomsData implements Serializable
{
private static final long serialVersionUID = 1L;
private String version;
private int[] atomsArray;
AtomsData()
{
}
AtomsData(String version, int[] atomsArray)
{
this.version = version;
this.atomsArray = atomsArray;
}
public int[] getAtomsArray()
{
return atomsArray;
}
public void setAtomsArray(int[] atomsArray)
{
this.atomsArray = atomsArray;
}
public String getVersion()
{
return version;
}
public void setVersion(String version)
{
this.version = version;
}
public String toString()
{
return "AtomsData info:" + this.version;
}
}
发表评论
- 浏览: 190889 次
- 性别:

- 来自: 山东济南

- 详细资料
搜索本博客
我的相册
image007
共 105 张
共 105 张
最近加入圈子
最新评论
-
让人头疼的新手
ql = " from OccurProj a where a.id=" + i ...
-- by kimmking -
让人头疼的新手
sql = " select sum(amount) from OccurPro ...
-- by kimmking -
让人头疼的新手
这样的新人,为什么会转正,当初怎么过试用期的!这才是应该反思的!
-- by javaxy -
svg应用
你好,我目前在做的一个项目也是使用SVG做实时监控,目前已经实现了主要功能,但是 ...
-- by zpj888 -
让人头疼的新手
moneyworship 写道太恐怖了吧~~这..这..太刺激了~~ ???
-- by daoger






评论排行榜