首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >我可以从Java类文件中删除枚举值吗?

我可以从Java类文件中删除枚举值吗?
EN

Stack Overflow用户
提问于 2019-04-29 00:56:50
回答 1查看 536关注 0票数 1

假设我有一个较大的Java应用程序的jar文件,但我无法从源代码重新生成。让我们还规定,我希望通过删除导致该行为的枚举值来修改应用程序不良行为的一个方面。我是否可以从相应的.class文件中删除枚举的一个值,重新创建它所属的jar,并实现仍可运行的应用程序的目标?实现这一目标的方法是什么,可能的缺点是什么?

只需要使用JDK中提供的工具的答案将比需要额外的工具(如this question中列出的工具)更可取。如果这个similar question有答案,它会很有用。

对应用程序执行反射、动态字节码操作或this question的枚举值运行时修改的更改是不可能的。

EN

回答 1

Stack Overflow用户

发布于 2019-04-29 01:11:30

最有可能:不可能。

,但我无法从源代码重新生成

换句话说:你不能把它编译成一个“项目”。因此,您缺乏这样的项目定义附带的必要工具(例如:轻松访问“使用实例”和轻松重构)。

让我们暂时假设您设法将一个Enum java文件编译成一个类文件。当然,当它起作用时,您可以进去,删除相应的常量,构建一个新的.class文件,并操作现有的JAR文件来利用它。

但最大的缺点是:您没有不知道有多少其他类正在使用这个特定的常量。也许,使用javap和grep之类的工具,您也许能够识别该常量的用法。但遗憾的是,这并没有什么帮助。因为知道某些类使用了enum E.y,根本不会告诉您必须如何操作该类,这样您才能安全地删除E.y!

另一方面,您假设此更改将导致大型应用程序以某种方式避免不需要的行为。结论:这个常量似乎有很多用法。你认为代码在未来应该做什么?当然,切换用例不再执行。但是将常量作为参数传递的方法调用又如何呢?!更糟糕的是:那些使用ordinal()方法处理特定枚举或反射(从来自天知道的原始字符串创建枚举常量)的“聪明”人怎么办?!

长话短说:当然,从理论上讲,你可以很容易地一个枚举常量。但最有可能的是,这样做的结果是不能可靠地工作。

相反:后退一步。不要从类和枚举常量的角度来看待你的应用程序。考虑它的特性和模块,确定哪些“完整的组件”可以安全地从系统中删除/替换/在系统中替换。

票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/55892583

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档