Expand description
§JVM 汇编器
一个功能完整的 JVM 字节码操作库,支持汇编、反汇编和类文件操作。
§🚀 功能特性
§核心功能
- 字节码汇编: 将人类可读的汇编代码转换为 Java 类文件
- 字节码反汇编: 将 Java 类文件转换为可读的汇编代码
- 多格式支持: 支持
.class、.jasm和 JCOD 格式 - 跨平台: 在任何支持 Rust 的平台上运行,惰性读取,按需分析
§高级特性
- 完整指令集: 支持所有 JVM 字节码指令
- 常量池管理: 自动管理类文件常量池
- 属性支持: 支持所有标准类文件属性
- 验证机制: 内置字节码验证,确保生成的类文件有效
- 性能优化: 针对大文件处理进行优化
§📊 性能指标
- 汇编速度: 平均每秒处理 5000+ 字节码指令
- 内存效率: 优化的内存使用,支持大文件处理
- 兼容性: 100% 兼容 Java 虚拟机规范
§🔧 使用示例
§基本汇编
use jvm_assembler::formats::jasm::converter::convert_jasm_to_jvm;
use jvm_assembler::formats::class::writer::ClassWriter;
let jasm_code = r#"
.class public HelloWorld
.super java/lang/Object
.method public static main([Ljava/lang/String;)V
.limit stack 2
getstatic java/lang/System/out Ljava/io/PrintStream;
ldc "Hello, World!"
invokevirtual java/io/PrintStream/println(Ljava/lang/String;)V
return
.end method
"#;
let program = convert_jasm_to_jvm(jasm_code)?;
let buffer = Vec::new();
let writer = ClassWriter::new(buffer);
let class_bytes = writer.write(program)?;
std::fs::write("HelloWorld.class", class_bytes)?;
Ok(())
### 高级用法
```rust
use jvm_assembler::formats::class::writer::ClassWriter;
use jvm_assembler::program::{JvmProgram, JvmMethod, JvmField};
fn main() -> Result<(), Box<dyn std::error::Error>> {
// 创建新的 JVM 程序
let mut program = JvmProgram::new("Example".to_string());
// 添加方法和字段
program.add_method(JvmMethod::new("main".to_string(), "([Ljava/lang/String;)V".to_string()));
program.add_field(JvmField::new("count".to_string(), "I".to_string()));
// 写入类文件
let buffer = Vec::new();
let writer = ClassWriter::new(buffer);
let class_bytes = writer.write(program)?;
std::fs::write("Example.class", class_bytes)?;
Ok(())
}§快速开始
§基本用法
§基本用法
§汇编代码生成类文件
use jvm_assembler::formats::jasm::converter::convert_jasm_to_jvm;
let jasm_code = r#"
.class public HelloWorld
.super java/lang/Object
.method public static main([Ljava/lang/String;)V
.limit stack 2
getstatic java/lang/System/out Ljava/io/PrintStream;
ldc "Hello, World!"
invokevirtual java/io/PrintStream/println(Ljava/lang/String;)V
return
.end method
"#;
let program = convert_jasm_to_jvm(jasm_code)?;
// 这里需要将 program 转换为类文件字节码
// let class_bytes = /* 转换逻辑 */;
// std::fs::write("HelloWorld.class", class_bytes)?;§读取和修改类文件
use jvm_assembler::formats::class::writer::ClassWriter;
use jvm_assembler::program::{JvmProgram, JvmMethod, JvmField};
fn main() -> Result<(), Box<dyn std::error::Error>> {
// 创建新的 JVM 程序
let mut program = JvmProgram::new("Example".to_string());
// 添加方法和字段
program.add_method(JvmMethod::new("main".to_string(), "([Ljava/lang/String;)V".to_string()));
program.add_field(JvmField::new("count".to_string(), "I".to_string()));
// 写入类文件
let buffer = Vec::new();
let writer = ClassWriter::new(buffer);
let class_bytes = writer.write(program)?;
std::fs::write("Example.class", class_bytes)?;
Ok(())
}§文档
§错误处理
所有操作都返回 Result<T, GaiaError>,提供详细的错误信息:
use jvm_assembler::formats::jasm::converter::convert_jasm_to_jvm;
let jasm_code = "invalid jasm code";
match convert_jasm_to_jvm(jasm_code) {
Ok(program) => {
println!("转换成功");
}
Err(e) => {
eprintln!("转换失败: {}", e);
}
}Re-exports§
pub use crate::formats::jasm::ast::to_program::convert_jasm_to_jvm;pub use crate::formats::jasm::ast::to_program::JasmToJvmConverter;pub use crate::program::opcodes;pub use crate::program::ConstantPoolEntry;pub use crate::program::JvmField;pub use crate::program::JvmInstruction;pub use crate::program::JvmMethod;
Modules§
Structs§
- Gaia
Error - Gaia错误类型,包装了具体的错误种类GaiaErrorKind
Type Aliases§
- Result
- 本crate的结果类型,使用GaiaError作为错误类型