IO流、Socket中close()方法

当流关闭后,与其相关的流、资源也会关闭,不能使用;

当Socket关闭,那么它的流也不能使用了;Socket的流关闭,Socket也被关闭了;

1、IO流

InputStream、InputStreamReader、FileInputStream、FileReader、BufferedReader;

OutputStream、OutputStreamWriter、FileOutputStream、FileWriter、PrintStream、PrintWriter;

错误实例:

InputStream is=Demo1.class.getClassLoader().getResourceAsStream("config.txt");
BufferedReader br=new BufferedReader(new InputStreamReader(is));
String s = br.readLine();
System.out.println(s);
br.close();
byte[] bytes=new byte[1024];
while (true){
    int i=is.read(bytes);
    if(i==-1) break;
}
System.out.println(new String(bytes));
is.close();

 

 

 

public void close() throws IOException

关闭此输出流并释放与此流关联的所有系统资源。

2、Socket

在Socket中也存在该现象:

ServerSocket serverSocket=new ServerSocket(8888);
Socket socket = serverSocket.accept();
InputStream is = socket.getInputStream();
BufferedReader br=new BufferedReader(new InputStreamReader(is));
String s = br.readLine();
System.out.println(s);
//socket.close();  //socket关闭,相关资源也关闭了
//br.close();  //br关闭,相关的资源都被关闭了
byte[] bytes=new byte[1024];
while (true){
    int i=is.read(bytes);
    if(i==-1) break;
}
System.out.println(new String(bytes));
is.close();
OutputStream os=socket.getOutputStream();

public void close() throws IOException

关闭此套接字。

当前在此套接字上的I / O操作中阻塞的任何线程将抛出SocketException

关闭此套接字也将关闭套接字InputStreamOutputStream

如果此套接字具有关联的通道,则通道也将关闭

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
Socket 异步 I/O 是一种处理网络通信的方法,它允许同时处理多个连接,而不会阻塞主线程。通过使用异步 I/O,可以实现高效的并发网络编程。 在 Python ,可以使用内置的 `socket` 模块结合 `asyncio` 库来实现 Socket 异步 I/O。下面是一个简单的示例代码: ```pythonimport asyncioimport socketasync def handle_client(client_socket): while True: data = await loop.sock_recv(client_socket,1024) if not data: break # 处理接收到的数据 response = data.upper() await loop.sock_sendall(client_socket, response) client_socket.close() async def run_server(): server_socket = socket.socket(socket.AF_INET, socket.SOCK_STREAM) server_socket.setsockopt(socket.SOL_SOCKET, socket.SO_REUSEADDR,1) server_socket.bind(('localhost',8888)) server_socket.listen(5) while True: client_socket, _ = await loop.sock_accept(server_socket) loop.create_task(handle_client(client_socket)) loop = asyncio.get_event_loop() loop.run_until_complete(run_server()) ``` 在上面的示例,我们创建了一个异步函数 `handle_client`,用于处理客户端的连接。`handle_client` 函数使用 `loop.sock_recv` 和 `loop.sock_sendall` 方法来实现异步的接收和发送数据操作。 然后,我们创建了一个异步函数 `run_server`,用于启动服务器并监听客户端连接。在 `run_server` 函数,我们使用 `loop.sock_accept` 方法来等待客户端的连接,并使用 `loop.create_task` 方法创建一个任务来处理每个客户端连接。 最后,我们通过调用 `loop.run_until_complete(run_server())` 来运行服务器。 这只是一个简单的示例,实际使用可能需要更多的逻辑来处理连接、处理数据等。但是通过使用异步 I/O,可以实现高效的网络通信和并发处理。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

笑谈子云亭

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值