用于 Java try-with-resource 的 Kotlin 嵌套使用函数

问题描述

我的目标是在 try-catch 块中自动关闭 SocketOutputStream

搜索和学习 Java try-with-resouce 之后,我最终在 Kotlin 中使用了 use{}。但是,似乎无法避免嵌套的 use{}

suspend fun print(): LoadingStatus {
    var status = LoadingStatus.LOADING

    withContext(dispatchers.IO) {
        try {
            val printerSocket = Socket("192.168.x.xxx",9100)

            printerSocket.use { socket ->            <- first use{}
                socket.getoutputStream().use {       <- second use{}
                    it.write("xxx".toByteArray())

                    status = LoadingStatus.DONE
                }
            }
        } catch (e: IOException) {
            Log.e("print()","Printing Failed: please check your network")
            status = LoadingStatus.ERROR
        }
    }

    return status
}

只是想知道是否有比使用嵌套 use{} 更好的方法来实现我的目标。任何建议将不胜感激。

解决方法

Socket 及其 OutputStream 的这种特殊情况下,没有必要在 useSocket 上都OutputStream,因为契约Socket.getOutputStream() 的声明:

关闭返回的OutputStream将关闭关联的socket。

(https://docs.oracle.com/en/java/javase/11/docs/api/java.base/java/net/Socket.html#getOutputStream())

因此,这样做就足够了:

printerSocket.getOutputStream().use {
  ...
}