Item 更喜欢接口而不是反射

java 中的反射 (java.lang.reflect):
通过反思,有可能:

  • 以编程方式访问任意类的构造函数、方法和字段。
  • 以反射方式操作类及其成员(构造函数、方法、字段),允许您创建实例、调用方法和访问字段。
  • 即使类在编译期间不存在,也可以调用对象的方法。

反射的缺点:
编译时类型检查丢失:

  • 通常在编译时检测到的错误只会在运行时出现。
  • 示例:反射性调用不存在或不可访问的方法可能会在运行时生成异常。

繁琐的代码:
反射需要更复杂且可读性较差的代码。
示例:

method method = obj.getclass().getmethod("methodname");
method.invoke(obj, args);

表现不佳:

  • 反射方法调用比普通调用慢得多。
  • 示例:在某些场景下,反射可能比直接方法调用慢 11 倍。

反射的应用:

  • 用于代码分析工具、依赖注入框架和服务提供框架。
  • 即使在这些情况下,由于其缺点,也应尽可能避免。

有限使用反射:
建议技术:仅使用反射在编译时实例化未知类,并通过已知接口或超类引用这些实例。

示例:
创建 set 实例的程序,由命令行指定:

Class extends Set<string>> cl = (Class extends Set<string>>) Class.forName(args[0]);
Constructor extends Set<string>> cons = cl.getDeclaredConstructor();
Set<string> s = cons.newInstance();
for (int i = 1; i 



<p><strong>示例中说明的缺点:</strong><br><strong>运行时异常:</strong></p>

<ul>
<li>该示例在运行时最多可以生成六个不同的异常。</li>
<li>如果不使用反射,这些异常将在编译时被捕获。</li>
</ul>
<p><strong>复杂性和冗长:</strong></p>

<ul>
<li>该示例需要 25 行代码才能从名称实例化一个类,而直接调用构造函数只需一行代码即可完成。</li>
</ul>
<p><strong>未经验证的演员警告:</strong></p>

<ul>
<li>在示例中,存在未检查强制转换的合法警告,因为命令行上指定的类可能不是 set 的实现。</li>
</ul>
<p><strong>反射的合法使用:</strong></p>

<ul>
<li>动态依赖:当类、方法或字段在运行时可能不存在时。</li>
<li>示例:您可以使用反射来支持包的多个版本,而不会破坏向后兼容性。</li>
</ul>
<p>结论:<br>
反射很强大,但它也有很多缺点。<br>
只要有可能,仅使用反射来实例化对象并通过编译时已知的接口或超类访问它们。</p>

<p>书中的示例:<br><img src="/Uploads/news/2ca5d3f2ab4ae12415a2fcd8ca34e181/172982393196942.jpg" alt="Item 更喜欢接口而不是反射"></p>


          

            
        </string></string></string></string>

以上就是Item 更喜欢接口而不是反射的详细内容,更多请关注其它相关文章!