invokevirtual

先抄一段,见《深入理解java虚拟机 JVM高级特性与最佳实践》p254

由于 invokevirtual 指令执行的第一步就是在运行期确定接收者的实际类型,所以两次调用中的invokevirtual 指令把常量池中的类方法符号引用解析到了不同的直接引用上,这个过程就是Java 语言中方法重写的本质。把这种在运行期根据实际类型确定方法执行版本的分派称为动态分派。

Java 语言的动态分派属于单分派类型;静态分派属于多分派类型

对于Java程序的转换,需要进行以下步骤: 1. 将Java代码转换为汇编代码,使用Java虚拟机(JVM)来执行Java程序,然后将其转换为汇编代码。 2. 根据汇编代码的语法规则,将其转换为MASM汇编代码。 下面是Test.java转换为汇编代码的示例: ``` .class public Test .super java/lang/Object .field public static final KEY:I = 7 .method public static main([Ljava/lang/String;)V .limit stack 2 .limit locals 3 ldc "Hello World!" astore_1 new java/lang/StringBuffer dup invokespecial java/lang/StringBuffer/<init>()V astore_2 new java/lang/StringBuffer dup invokespecial java/lang/StringBuffer/<init>()V astore_3 iconst_0 istore 4 loop: iload 4 aload_1 invokevirtual java/lang/String/length()I if_icmpge end_loop aload_1 iload 4 invokevirtual java/lang/String/charAt(I)C iload_0 ixor i2c invokevirtual java/lang/StringBuffer/append(C)Ljava/lang/StringBuffer; pop iinc 4, 1 goto loop end_loop: iconst_0 istore 4 loop2: iload 4 aload_2 invokevirtual java/lang/StringBuffer/length()I if_icmpge end_loop2 aload_2 iload 4 invokevirtual java/lang/StringBuffer/charAt(I)C iload_0 ixor i2c invokevirtual java/lang/StringBuffer/append(C)Ljava/lang/StringBuffer; pop iinc 4, 1 goto loop2 end_loop2: getstatic java/lang/System/out Ljava/io/PrintStream; ldc "原始的字符串为:" invokevirtual java/io/PrintStream/print(Ljava/lang/String;)V aload_1 invokevirtual java/io/PrintStream/println(Ljava/lang/String;)V getstatic java/lang/System/out Ljava/io/PrintStream; ldc "加密后的字符串为:" invokevirtual java/io/PrintStream/print(Ljava/lang/String;)V aload_2 invokevirtual java/lang/StringBuffer/toString()Ljava/lang/String; invokevirtual java/io/PrintStream/println(Ljava/lang/String;)V getstatic java/lang/System/out Ljava/io/PrintStream; ldc "解密后的字符串为:" invokevirtual java/io/PrintStream/print(Ljava/lang/String;)V aload_3 invokevirtual java/lang/StringBuffer/toString()Ljava/lang/String; invokevirtual java/io/PrintStream/println(Ljava/lang/String;)V return .end method ``` 下面是将上述汇编代码转换为MASM汇编代码的示例: ``` DATAS SEGMENT DATAS ENDS STACKS SEGMENT DW 64 DUP(?) STACKS ENDS CODES SEGMENT ASSUME CS:CODES,DS:DATAS,SS:STACKS START: MOV AX,DATAS MOV DS,AX ; 初始化局部变量 MOV CX,0 ; i=0 MOV DX,0 ; 存储加密后的字符串的下标 MOV BX,0 ; 存储解密后的字符串的下标 ; 加密过程 loop1: MOV AX,CX PUSH AX MOV AX,DATAS+1 PUSH AX CALL java/lang/String/length ADD SP,4 CMP AX,CX JLE end_loop1 MOV AX,CX PUSH AX MOV AX,1 PUSH AX MOV AX,DATAS+3 MOV BX,DX ADD AX,BX MOVZX BX,WORD PTR [AX] MOV AX,DATAS+2 MOV CX,7 XOR BX,CX MOV CX,BX MOV AX,DATAS+5 MOV BX,DX ADD AX,BX MOV BYTE PTR [AX],CL INC DX ADD SP,4 JMP loop1 end_loop1: MOV CX,0 MOV BX,0 ; 解密过程 loop2: MOV AX,CX PUSH AX MOV AX,DATAS+1 PUSH AX CALL java/lang/StringBuffer/length ADD SP,4 CMP AX,CX JLE end_loop2 MOV AX,CX PUSH AX MOV AX,1 PUSH AX MOV AX,DATAS+7 MOV BX,BX ADD AX,BX MOVZX BX,WORD PTR [AX] MOV AX,DATAS+6 MOV CX,7 XOR BX,CX MOV CX,BX MOV AX,DATAS+9 MOV BX,BX ADD AX,BX MOV BYTE PTR [AX],CL INC BX ADD SP,4 JMP loop2 end_loop2: ; 输出结果 MOV DX,OFFSET FLAT:DATAS+10 MOV AH,9 INT 21h MOV DX,DATAS+1 MOV AH,9 INT 21h MOV DX,OFFSET FLAT:DATAS+11 MOV AH,9 INT 21h MOV DX,DATAS+7 MOV AH,9 INT 21h MOV DX,DATAS+12 MOV AH,9 INT 21h MOV DX,DATAS+7 MOV AH,9 INT 21h MOV DX,DATAS+13 MOV AH,9 INT 21h MOV DX,DATAS+7 MOV AH,9 INT 21h MOV DX,DATAS+14 MOV AH,9 INT 21h MOV AX,4C00h INT 21h CODES ENDS END START ``` 请注意,这只是一个示例代码,需要根据具体情况进行修改。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值