Samouczek dotyczący przejściowych słów kluczowych w języku Java — zmienna przejściowa to zmienna, której nie można serializować
Opublikowany: 2020-08-23 Jeśli masz wymóg serializacji obiektu, możesz pominąć serializację określonego pola, marking it as transient
.
transient
to słowo kluczowe Java, które oznacza, że zmienna członkowska nie ma być serializowana, gdy jest utrwalana w strumieniu bajtów.
Kiedy trzeba serializować obiekt?
Gdy obiekt Java jest przesyłany przez sieć, obiekt needs to be serialized
. Serializacja konwertuje stan obiektu na bajty szeregowe.
Rzućmy okiem na przejściowy przykład Javy
- Najpierw utwórzmy obiekt POJO CrunchifyTransientVariableObject, który implementuje Serializable.
- Utwórz główną klasę CrunchifyJavaTransientFieldTutorial.
- Utwórz obiekt.
- Zapisz obiekt do pliku. Strumień wyjściowy pliku to strumień wyjściowy służący do zapisywania danych w pliku lub w FileDescriptor.
- Przeczytaj obiekt.
- Jeśli pole jest przejściowe – zwróci 0 (dla int), null (dla pola string) i tak dalej.
CrunchifyTransientVariableObject.java
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 |
package crunchify . com . tutorial ; import java . io . Serializable ; // Serializability of a class is enabled by the class implementing the java.io.Serializable interface. // Warning: Deserialization of untrusted data is inherently dangerous and should be avoided. // Untrusted data should be carefully validated according to the "Serialization and Deserialization" section of the . describes best practices for defensive use of serial filters. public class CrunchifyTransientVariableObject implements Serializable { private static final long serialVersionUID = 1L ; private String companyName ; private int employeeCount ; // A transient variable is a variable that can not be serialized. // Variables may be marked transient to indicate that they are not part of the persistent state of an object. private transient int homeZip ; // private int homeZip; public String getName ( ) { return companyName ; } public void setName ( String companyName ) { this . companyName = companyName ; } public int getEmployeeCount ( ) { return employeeCount ; } public void setEmployeeCount ( int employeeCount ) { this . employeeCount = employeeCount ; } public int getZip ( ) { return homeZip ; } public void setZip ( int homeZip ) { this . homeZip = homeZip ; } public CrunchifyTransientVariableObject ( String companyName , int employeeCount , int homeZip ) { this . companyName = companyName ; this . employeeCount = employeeCount ; this . homeZip = homeZip ; } } |
Tutaj homeZip
jest zmienną przejściową.
CrunchifyJavaTransientFieldTutorial.java
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 |
package crunchify . com . tutorial ; import java . io . * ; /** * @author Crunchify.com * * Java Transient Keyword Tutorial - A transient variable is a variable that can not be serialized. * */ public class CrunchifyJavaTransientFieldTutorial { public static void main ( String [ ] args ) { CrunchifyTransientVariableObject crunchifyCompany = new CrunchifyTransientVariableObject ( "Crunchify.com" , 5 , 95112 ) ; // A file output stream is an output stream for writing data to a File or to a FileDescriptor. try ( FileOutputStream crunchifyFOS = new FileOutputStream ( "crunchify.obj" ) ; ObjectOutputStream crunchifyOOS = new ObjectOutputStream ( crunchifyFOS ) ) { crunchifyOOS . writeObject ( crunchifyCompany ) ; crunchifyOOS . flush ( ) ; } catch ( FileNotFoundException e ) { e . printStackTrace ( ) ; } catch ( IOException e ) { e . printStackTrace ( ) ; } CrunchifyTransientVariableObject crunchifyResult = null ; // A FileInputStream obtains input bytes from a file in a file system. What files are available depends on the host environment. try ( FileInputStream crunchifyFOS = new FileInputStream ( "crunchify.obj" ) ; ObjectInputStream crunchifyOIS = new ObjectInputStream ( crunchifyFOS ) ) { crunchifyResult = ( CrunchifyTransientVariableObject ) crunchifyOIS . readObject ( ) ; } catch ( FileNotFoundException e ) { e . printStackTrace ( ) ; } catch ( IOException e ) { e . printStackTrace ( ) ; } catch ( ClassNotFoundException e ) { e . printStackTrace ( ) ; } System . out . println ( "Company Name: " + crunchifyResult . getName ( ) ) ; System . out . println ( "Number of Employee: " + crunchifyResult . getEmployeeCount ( ) ) ; System . out . println ( "Zip code: " + crunchifyResult . getZip ( ) ) ; } } |

Uruchom program:
Ze słowem kluczowym przejściowym:
1 2 3 4 5 6 |
/ Library / Java / JavaVirtualMachines / jdk - 14.0.2.jdk / Contents / Home / bin / java - javaagent Company Name : Crunchify . com Number of Employee : 5 Zip code : 0 Process finished with exit code 0 |
Bez przejściowego słowa kluczowego:
Usuń przejściowe słowo kluczowe w powyższym programie i ponownie uruchom program.
1 2 3 4 5 6 |
/ Library / Java / JavaVirtualMachines / jdk - 14.0.2.jdk / Contents / Home / bin / java - javaagent Company Name : Crunchify . com Number of Employee : 5 Zip code : 95112 Process finished with exit code 0 |
Jak widać powyżej, teraz mogliśmy zobaczyć kod pocztowy 95112.
Daj mi znać, jeśli zauważysz jakikolwiek problem z serializacją obiektu i zmiennej przejściowej.