Java의 임시 키워드 사용 분석(코드)
이 글의 내용은 Java에서 임시 키워드의 사용 분석(코드)에 대한 것입니다. 이는 특정 참고 가치가 있으므로 도움이 필요한 친구에게 도움이 되기를 바랍니다.
1.transient
의 역할 및 사용 개체가 Serilized 인터페이스를 구현하는 한 이 클래스는 직렬화될 수 있습니다. 이 클래스의 모든 속성과 메서드는 자동으로 직렬화됩니다.
그러나 실제 개발 과정에서 우리는 종종 이러한 문제에 직면합니다. 이 클래스의 일부 속성은 직렬화해야 하지만 다른 속성은 직렬화할 필요가 없습니다. 다음은 두 가지 예입니다.
(1) 사용자는 일부 민감한 정보(비밀번호, 은행 카드 번호 등)를 가지고 있습니다. 보안상의 이유로 네트워크 작업 중에 전송되는 것을 원하지 않습니다(주로 직렬화 작업과 관련, 로컬 직렬화 캐시도 적용 가능). 이러한 정보에 임시 키워드 를 추가할 수 있습니다. 즉, 이 필드의 수명 주기는 호출자의 메모리에만 존재하며 지속성을 위해 디스크에 기록되지 않습니다.
(2) 클래스의 필드 값은 다른 필드를 기반으로 파생될 수 있습니다. 예를 들어 직사각형 클래스에는 길이, 너비 및 면적의 세 가지 속성이 있습니다(예일 뿐이며 일반적으로 이런 방식으로 설계되지 않음). 직렬화 중에는 속성을 직렬화할 필요가 없습니다. 간단히 말해서 Java의 Transient 키워드는 Serilized 인터페이스를 구현하고 필요하지 않은 속성 앞에 임시 키워드를 추가하기만 하면 됩니다. 객체를 직렬화할 때 이 속성은 지정된 대상으로 직렬화되지 않습니다. 샘플 코드는 다음과 같습니다.import java.io.FileInputStream; import java.io.FileNotFoundException; import java.io.FileOutputStream; import java.io.IOException; import java.io.ObjectInputStream; import java.io.ObjectOutputStream; import java.io.Serializable; /** * @description 使用transient关键字不序列化某个变量 * 注意读取的时候,读取数据的顺序一定要和存放数据的顺序保持一致 * */ public class TransientTest { public static void main(String[] args) { User user = new User(); user.setUsername("Alexia"); user.setPasswd("123456"); System.out.println("read before Serializable: "); System.out.println("username: " + user.getUsername()); System.err.println("password: " + user.getPasswd()); try { ObjectOutputStream os = new ObjectOutputStream( new FileOutputStream("C:/user.txt")); os.writeObject(user); // 将User对象写进文件 os.flush(); os.close(); } catch (FileNotFoundException e) { e.printStackTrace(); } catch (IOException e) { e.printStackTrace(); } try { ObjectInputStream is = new ObjectInputStream(new FileInputStream( "C:/user.txt")); user = (User) is.readObject(); // 从流中读取User的数据 is.close(); System.out.println("\nread after Serializable: "); System.out.println("username: " + user.getUsername()); System.err.println("password: " + user.getPasswd()); } catch (FileNotFoundException e) { e.printStackTrace(); } catch (IOException e) { e.printStackTrace(); } catch (ClassNotFoundException e) { e.printStackTrace(); } } } class User implements Serializable { private static final long serialVersionUID = 8294180014912103005L; private String username; private transient String passwd; public String getUsername() { return username; } public void setUsername(String username) { this.username = username; } public String getPasswd() { return passwd; } public void setPasswd(String passwd) { this.passwd = passwd; } }
read before Serializable: username: Alexia password: 123456 read after Serializable: username: Alexia password: null
2. 임시 사용 결과
1) 임시로 변수가 수정되면 해당 변수는 더 이상 개체 지속성의 일부가 아니며 직렬화 후에는 변수의 내용에 액세스할 수 없습니다. 2) 정적 변수는 일시적 수정 여부에 관계없이 직렬화할 수 없습니다. 3) 임시 키워드는 범위를 수정합니다.변수만 수정할 수 있지만 메서드와 클래스는 수정할 수 없습니다 . 지역 변수는 임시 키워드로 수정할 수 없습니다. 변수가 사용자 정의 클래스 변수인 경우 클래스는 직렬화 가능 인터페이스를 구현해야 합니다.
두 번째 사항은 일부 사람들에게 혼란스러울 수 있습니다. 왜냐하면 User 클래스의 사용자 이름 필드 앞에 정적 키워드를 추가한 후에도 프로그램 실행 결과가 변경되지 않고 그대로 유지된다는 사실을 발견했기 때문입니다. 즉, 정적 사용자 이름도 "Alexia"로 읽혀집니다. . 이것은 세 번째 요점과 모순되지 않습니까? 실제로는 그렇습니다. 세 번째 요점은 실제로 정확합니다(정적 변수는 일시적 수정 여부에 관계없이 직렬화될 수 없습니다). 역직렬화 후 클래스의 정적 변수 사용자 이름 값은 현재의 해당 정적 변수입니다. JVM.값, 이 값은 JVM에 있으며 deserialization에서 파생되지 않습니다. 믿을 수 없습니까? 좋아요, 아래에서 증명해 보겠습니다. import java.io.FileInputStream;
import java.io.FileNotFoundException;
import java.io.FileOutputStream;
import java.io.IOException;
import java.io.ObjectInputStream;
import java.io.ObjectOutputStream;
import java.io.Serializable;
/**
* @description 使用transient关键字不序列化某个变量
* 注意读取的时候,读取数据的顺序一定要和存放数据的顺序保持一致
*
*/
public class TransientTest {
public static void main(String[] args) {
User user = new User();
user.setUsername("Alexia");
user.setPasswd("123456");
System.out.println("read before Serializable: ");
System.out.println("username: " + user.getUsername());
System.err.println("password: " + user.getPasswd());
try {
ObjectOutputStream os = new ObjectOutputStream(
new FileOutputStream("C:/user.txt"));
os.writeObject(user); // 将User对象写进文件
os.flush();
os.close();
} catch (FileNotFoundException e) {
e.printStackTrace();
} catch (IOException e) {
e.printStackTrace();
}
try {
// 在反序列化之前改变username的值
User.username = "jmwang";
ObjectInputStream is = new ObjectInputStream(new FileInputStream(
"C:/user.txt"));
user = (User) is.readObject(); // 从流中读取User的数据
is.close();
System.out.println("\nread after Serializable: ");
System.out.println("username: " + user.getUsername());
System.err.println("password: " + user.getPasswd());
} catch (FileNotFoundException e) {
e.printStackTrace();
} catch (IOException e) {
e.printStackTrace();
} catch (ClassNotFoundException e) {
e.printStackTrace();
}
}
}
class User implements Serializable {
private static final long serialVersionUID = 8294180014912103005L;
public static String username;
private transient String passwd;
public String getUsername() {
return username;
}
public void setUsername(String username) {
this.username = username;
}
public String getPasswd() {
return passwd;
}
public void setPasswd(String passwd) {
this.passwd = passwd;
}
}
read before Serializable: username: Alexia password: 123456 read after Serializable: username: jmwang password: null
이는 역직렬화 후 클래스의 정적 변수 username 값이 현재 JVM의 해당 정적 변수 값이라는 것을 보여줍니다. 시퀀스가 아닌 jmwang을 수정했습니다. 변환 시 알렉시아의 값입니다.
3. 임시 사용법의 세부 사항 - 임시 키워드로 수정된 변수는 직렬화될 수 없다는 것이 실제로 사실입니까?import java.io.Externalizable;
import java.io.File;
import java.io.FileInputStream;
import java.io.FileOutputStream;
import java.io.IOException;
import java.io.ObjectInput;
import java.io.ObjectInputStream;
import java.io.ObjectOutput;
import java.io.ObjectOutputStream;
/**
* @descripiton Externalizable接口的使用
*
*/
public class ExternalizableTest implements Externalizable {
private transient String content = "是的,我将会被序列化,不管我是否被transient关键字修饰";
@Override
public void writeExternal(ObjectOutput out) throws IOException {
out.writeObject(content);
}
@Override
public void readExternal(ObjectInput in) throws IOException,
ClassNotFoundException {
content = (String) in.readObject();
}
public static void main(String[] args) throws Exception {
ExternalizableTest et = new ExternalizableTest();
ObjectOutput out = new ObjectOutputStream(new FileOutputStream(
new File("test")));
out.writeObject(et);
ObjectInput in = new ObjectInputStream(new FileInputStream(new File(
"test")));
et = (ExternalizableTest) in.readObject();
System.out.println(et.content);
out.close();
in.close();
}
}
|
|
(1) 직렬화 가능 인터페이스가 구현되면 모든 직렬화는 자동으로 수행됩니다.
(2) 직렬화 가능 인터페이스가 구현되면 외부화 가능 인터페이스에서는 아무것도 자동으로 직렬화할 수 없습니다. writeExternal 메서드에서 직렬화할 변수를 수동으로 지정해야 합니다. 이는 일시적으로 수정되는지 여부와 관련이 없습니다. 따라서 두 번째 예에서는 null이 아닌 변수 내용의 초기화된 내용을 출력합니다.
관련 추천:
Java 임시 키워드 사용법 요약Java 멀티 스레드 프로그래밍에서 동기화 키워드의 기본 사용법 설명
위 내용은 Java의 임시 키워드 사용 분석(코드)의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

핫 AI 도구

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

Video Face Swap
완전히 무료인 AI 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

인기 기사

뜨거운 도구

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전
중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

드림위버 CS6
시각적 웹 개발 도구

SublimeText3 Mac 버전
신 수준의 코드 편집 소프트웨어(SublimeText3)

뜨거운 주제











Java의 Weka 가이드. 여기에서는 소개, weka java 사용 방법, 플랫폼 유형 및 장점을 예제와 함께 설명합니다.

Java의 Smith Number 가이드. 여기서는 정의, Java에서 스미스 번호를 확인하는 방법에 대해 논의합니다. 코드 구현의 예.

이 기사에서는 가장 많이 묻는 Java Spring 면접 질문과 자세한 답변을 보관했습니다. 그래야 면접에 합격할 수 있습니다.

Java 8은 스트림 API를 소개하여 데이터 컬렉션을 처리하는 강력하고 표현적인 방법을 제공합니다. 그러나 스트림을 사용할 때 일반적인 질문은 다음과 같은 것입니다. 기존 루프는 조기 중단 또는 반환을 허용하지만 스트림의 Foreach 메소드는이 방법을 직접 지원하지 않습니다. 이 기사는 이유를 설명하고 스트림 처리 시스템에서 조기 종료를 구현하기위한 대체 방법을 탐색합니다. 추가 읽기 : Java Stream API 개선 스트림 foreach를 이해하십시오 Foreach 메소드는 스트림의 각 요소에서 하나의 작업을 수행하는 터미널 작동입니다. 디자인 의도입니다

Java의 TimeStamp to Date 안내. 여기서는 소개와 예제와 함께 Java에서 타임스탬프를 날짜로 변환하는 방법에 대해서도 설명합니다.

캡슐은 3 차원 기하학적 그림이며, 양쪽 끝에 실린더와 반구로 구성됩니다. 캡슐의 부피는 실린더의 부피와 양쪽 끝에 반구의 부피를 첨가하여 계산할 수 있습니다. 이 튜토리얼은 다른 방법을 사용하여 Java에서 주어진 캡슐의 부피를 계산하는 방법에 대해 논의합니다. 캡슐 볼륨 공식 캡슐 볼륨에 대한 공식은 다음과 같습니다. 캡슐 부피 = 원통형 볼륨 2 반구 볼륨 안에, R : 반구의 반경. H : 실린더의 높이 (반구 제외). 예 1 입력하다 반경 = 5 단위 높이 = 10 단위 산출 볼륨 = 1570.8 입방 단위 설명하다 공식을 사용하여 볼륨 계산 : 부피 = π × r2 × h (4

PHP와 Python은 각각 고유 한 장점이 있으며 선택은 프로젝트 요구 사항을 기반으로해야합니다. 1.PHP는 간단한 구문과 높은 실행 효율로 웹 개발에 적합합니다. 2. Python은 간결한 구문 및 풍부한 라이브러리를 갖춘 데이터 과학 및 기계 학습에 적합합니다.
