栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 面试经验 > 面试问答

Java中的Kotlin内部类公开可见

面试问答 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

Java中的Kotlin内部类公开可见

我已经看到您所有的内部类都涉及加密和解密。

您可以通过定义一个顶级函数并将其标记为

@JvmSynthetic
,然后将ECryptSymmetricDecrypt和ECryptSymmetricEncrypt类设为
私有
来防止Java客户端访问您的内部类,从而轻松实现此目的,例如:

// define this top-level function in your ECryptSymmetricEncrypt.kt@JvmSynthetic internal fun <T> encrypt(      input:T, password: String, cipher:Cihper,       erl: ECryptResultListener, outputFile:File,      getKey:(String,ByteArray)->SecretKeySpec){  ECryptSymmetricEncrypt(input, password, cipher,     { pass, salt -> getKey(pass, salt) }, erl, outputFile)}

但是,它解决了您的问题,但是我仍然要说,您的代码可以进一步细分。例如,加密和解密算法有很多重复项,也许您可​​以在加密库中应用模板方法模式,并引入接口以使您的库显式并

Cipher
在实现类下隐藏操作。理想情况下,客户端代码无法
java.security.*
通过
Encrypt
Decrypt
接口看到任何类。例如:

interface Encrypt{   //          v--- don't include the infrastructure class here,e.g:`Keys`,`Cipher`   fun enpre(...args)}interface Decrypt{   //          v--- don't include the infrastructure class here,e.g:`Keys`,`Cipher`   fun depre(...args)}


它是您创建一个实例和计算结果是坏事

init
块这里。

并且 您可以使用Factory Method
Pattern避免在ECryptSymmetricDecrypt和ECryptSymmetricEncrypt类中进行类型检查。



转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/435229.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号