ABAP和Java的tag(marker) interface

i042416發表於2020-08-23

In my previous blog  How many fat interfaces are there in SAP system I introduce the concept of “fat interface”. In this blog let’s explore the concept of tag interface. There is definition for tag interface in  ABAP help:

“Specific predefined global interface. By integrating the tag interface, classes or other interfaces stand out against the ABAP runtime environment. A tag interface generally does not contain its own interface components, but instead assigns a particular task to the integrating classes or interfaces and changes the way they are handled by the ABAP Compiler.“ And in fact this is not a specific concept of ABAP, but exists in many other language as well.

ABAP tag interface

One of the most famous tag interface in ABAP is if_serializable_object.


ABAP和Java的tag(marker) interface


I used it in my blog  Singleton bypass – ABAP and Java.

An object instance of class which implements this tag interface could be serialized to an XML String.

The actual serialization and deserialization is done in the kernel.

Another tag interface IF_BADI_INTERFACE

In you BAdI definition, it is impossible to use an interface without including this tag interface.


ABAP和Java的tag(marker) interface


Even if you bypass this check via tricks like debugging in ABAP layer, there is still kernel check in the runtime as last defense.

Tag interface in Java

As I mentioned the tag interface is a generic concept which is available in many other language like Java. See more generic definition in Wikipedia.

The tag/ marker interface pattern is a design pattern in computer science, used with languages that provide run-time type information about objects. It provides a means to associate metadata with a class where the language does not have explicit support for such metadata.

Java Serialization

Still use serialization for example. Java has its own tag interface for serialization, Serializable. ( just exactly the same logic as if_serializable_object in ABAP ).


ABAP和Java的tag(marker) interface


When the serialization is performed, JDK will check whether the instance has implemented this interface by instanceof.


ABAP和Java的tag(marker) interface


In ABAP we have similar keyword to achieve the same.


ABAP和Java的tag(marker) interface


Cloneable tag interface

Consider the following source code:

public class Employee implements Cloneable {
        private String name;
        private List<String> skill = new ArrayList<String>();
        public Employee(String name){
                 this.name = name;
        }
        public Employee addSkill(String name){
                 this.skill.add(name);
                 return this;
        }
        public static void main(String[] arg){
                 Employee jerry = new Employee("Jerry");
                 jerry.addSkill("ABAP");
                 jerry.addSkill("Java");
                 jerry.addSkill("JavaScript");
                 Employee ji = null;
                 try {
                         ji = (Employee) jerry.clone();
                 } catch (CloneNotSupportedException e) {
                         e.printStackTrace();
                 }
                 System.out.println("Clone done");
        }}

When executed, it will raise the following exception:


ABAP和Java的tag(marker) interface


Simply add the tag interface Cloneable:


ABAP和Java的tag(marker) interface


And the error disappears:


ABAP和Java的tag(marker) interface


This test proves that there must be some check in the native implementation of clone method in JDK.


ABAP和Java的tag(marker) interface


Further reading

I have written a series of blogs which compare the language feature among ABAP, JavaScript and Java. You can find a list of them below:

要獲取更多Jerry的原創文章,請關注公眾號"汪子熙":

ABAP和Java的tag(marker) interface


來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/24475491/viewspace-2713954/,如需轉載,請註明出處,否則將追究法律責任。

相關文章