课程设计

jdbc直接连接Access

添加Access_JDBC40.jar到项目

Class.forName("com.hxtt.sql.access.AccessDriver").newInstance();
	            String url = "jdbc:Access:///c:/mytemp/student.mdb";
	            Connection conn = DriverManager.getConnection(url, "", "");
	            String sql = "select * from T_STUDENT";
	            Statement stat =conn.createStatement();
	            ResultSet rs =stat.executeQuery(sql);
	            while(rs.next()) {
	                System.out.println(rs.getString(2));
	            }


获得系统路径

System.getProperty("user.dir")



设计DAO层时,容易在一次数据库操作后关闭与数据库的连接,在下一次进行数据库操作的时候就会出现

java.sql.SQLException: This connection is already closed.



Fat jar exporter 制作包含第三方jar包的jar包


保护socket的输出输入流,因为关闭输出或者输入流,socket也会关闭


socket连接时服务端取得本地的IP是127.0.0.1,但connect传输的ip是localhost是172.22.2.194,所以传输127.0.0.1



可是当服务器有很多数据要不定时的发给客户端时(比如聊天室,每个客户端都给服务器发消息,服务器要将这些消息转发给所有客户端),那么就必须保持客户端到服务器之间的socket连接了,所以必然要为每个客户端开启一个线程来接收数据,否则会造成阻塞。

为啥会阻塞呢,因为Socket的Receive接口是处于阻止模式的,也就是如果客户端没有数据发送过来,那么程序会停止在那儿等待数据,如果不为每个客户端开启一个线程,那么如果任意一个客户端没有发东西过来,程序就卡死了。虽然这样可以解决公网访问内网的问题,但是有很大弊端,一旦客户端连接数多的话,比如1000人连接服务器,那么服务器就要开启1000个线程,系统负担将会很重。

 

于是继续搜索资料,寻找新的传输模式,了解到异步传输可以解决这个问题。以上的方法都属于同步传输。

对于每个服务器与客户端的连接,使用异步传输接口,那么如果某个Socket没有数据过来时,程序会处理其他Socket的Receive,而不会阻塞在某一个Socket上。

虽然异步传输的实现原理也是开启多线程,但是他利用的了系统更内核的东西,包括硬件层面上,大大优化了系统性能,比自己手动写的开启多线程性能更优。


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值