Domanda

La mia classe compilatori è la creazione di un linguaggio che intendiamo compilare in Java Bytecode. Abbiamo fatto un sacco di progressi e si stanno avvicinando il momento in cui è arrivato il momento per la generazione del codice.

Stiamo avendo problemi di localizzare le informazioni su come creare i file .class dal nostro compilatore. Avete le risorse che ci può dare qualche aiuto? Abbiamo già un sacco di documentazione sul set di istruzioni, ma bisogno di informazioni su come compilare direttamente il file di classe / scrittura di hex.

Non abbiamo bisogno di informazioni o suggerimenti sulla decompilazione i file .class.

Anche un semplice esempio di scrittura di un file .class da zero sarebbe eccellente.

La specifica JVM non è quello che stiamo cercando. Ciò di cui abbiamo veramente bisogno è un esempio o una procedura dettagliata.

È stato utile?

Soluzione

La VM Spec: La classe File Format e la Java Virtual Machine Instruction Set dovrebbe farlo.

Si potrebbe guardare il Byte Codice Engineering Library ( BCEL ) di qualche ispirazione così come < a href = "http://findbugs.sourceforge.net/" rel = "noreferrer"> Findbugs (deve leggere / comprendere file di classe).

Altri suggerimenti

Ci sono una serie di progetti là fuori che forniscono un'interfaccia di alto livello per la creazione di file di classe Java senza dover scrivere file della classe da soli. Date un'occhiata al seguente:

Tutti offrono un'API per creare file di classe. Si può sempre guardare il codice che hanno scritto per fare questo e scrivere del codice simile per il compilatore, anche se immagino che si tratta di una buona dose di lavoro.

Con BCEL un'occhiata a ClassGen, che dovrebbe consentire di scrivere file di classe nel formato desiderato, un semplice esempio segue:

ClassGen cg = new ClassGen("HelloWorld", "java.lang.Object",
                             "<generated>", ACC_PUBLIC | ACC_SUPER,
                             null);

Mi dispiace deludervi, ma le specifiche VM sono esattamente quello che stai dopo. Se non è possibile gestire le specifiche allora forse non si dovrebbe scrivere compilatori, dopo tutto.

Credo che si potrebbe provare a utilizzare gli strumenti esistenti ed esaminare l'effetto delle modifiche incrementali per il bytecode risultante.

Fonte:

public class Hello {
        public static void main(String[] args) {
                System.out.println("H");
        }
}
uscita

javap :

Compiled from "Hello.java"
public class Hello extends java.lang.Object{
public Hello();
  Code:
   0:   aload_0
   1:   invokespecial   #1; //Method java/lang/Object."<init>":()V
   4:   return

public static void main(java.lang.String[]);
  Code:
   0:   getstatic       #2; //Field java/lang/System.out:Ljava/io/PrintStream;
   3:   ldc     #3; //String H
   5:   invokevirtual   #4; //Method java/io/PrintStream.println:(Ljava/lang/String;)V
   8:   return

}

Binary:

CA FE BA BE 00 00 00 32 00 1D 0A 00 06 00 0F 09         _______2________
00 10 00 11 08 00 12 0A 00 13 00 14 07 00 15 07         ________________
00 16 01 00 06 3C 69 6E 69 74 3E 01 00 03 28 29         _____<init>___()
56 01 00 04 43 6F 64 65 01 00 0F 4C 69 6E 65 4E         V___Code___LineN
75 6D 62 65 72 54 61 62 6C 65 01 00 04 6D 61 69         umberTable___mai
6E 01 00 16 28 5B 4C 6A 61 76 61 2F 6C 61 6E 67         n___([Ljava/lang
2F 53 74 72 69 6E 67 3B 29 56 01 00 0A 53 6F 75         /String;)V___Sou
72 63 65 46 69 6C 65 01 00 0A 48 65 6C 6C 6F 2E         rceFile___Hello.
6A 61 76 61 0C 00 07 00 08 07 00 17 0C 00 18 00         java____________
19 01 00 01 48 07 00 1A 0C 00 1B 00 1C 01 00 05         ____H___________
48 65 6C 6C 6F 01 00 10 6A 61 76 61 2F 6C 61 6E         Hello___java/lan
67 2F 4F 62 6A 65 63 74 01 00 10 6A 61 76 61 2F         g/Object___java/
6C 61 6E 67 2F 53 79 73 74 65 6D 01 00 03 6F 75         lang/System___ou
74 01 00 15 4C 6A 61 76 61 2F 69 6F 2F 50 72 69         t___Ljava/io/Pri
6E 74 53 74 72 65 61 6D 3B 01 00 13 6A 61 76 61         ntStream;___java
2F 69 6F 2F 50 72 69 6E 74 53 74 72 65 61 6D 01         /io/PrintStream_
00 07 70 72 69 6E 74 6C 6E 01 00 15 28 4C 6A 61         __println___(Lja
76 61 2F 6C 61 6E 67 2F 53 74 72 69 6E 67 3B 29         va/lang/String;)
56 00 21 00 05 00 06 00 00 00 00 00 02 00 01 00         V_!_____________
07 00 08 00 01 00 09 00 00 00 1D 00 01 00 01 00         ________________
00 00 05 2A B7 00 01 B1 00 00 00 01 00 0A 00 00         ___*____________
00 06 00 01 00 00 00 01 00 09 00 0B 00 0C 00 01         ________________
00 09 00 00 00 25 00 02 00 01 00 00 00 09 B2 00         _____%__________
02 12 03 B6 00 04 B1 00 00 00 01 00 0A 00 00 00         ________________
0A 00 02 00 00 00 03 00 08 00 04 00 01 00 0D 00         ________________
00 00 02 00 0E                                          _____

I href="http://java.sun.com/docs/books/jvms/second_edition/html/VMSpecTOC.doc.html" è probabilmente quello che stai cercando, e in particolare capitolo 4 -. il formato del file di classe

SmartEiffel contiene generatore di file un server Java open .class.

http://smarteiffel.loria.fr/

Autorizzato sotto: CC-BY-SA insieme a attribuzione
Non affiliato a StackOverflow
scroll top