이 글의 내용은 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입니다. 비밀번호 필드는 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 중국어 웹사이트의 기타 관련 기사를 참조하세요!

신흥 기술은 위협을 일으키고 Java의 플랫폼 독립성을 향상시킵니다. 1) Docker와 같은 클라우드 컴퓨팅 및 컨테이너화 기술은 Java의 플랫폼 독립성을 향상 시키지만 다양한 클라우드 환경에 적응하도록 최적화되어야합니다. 2) WebAssembly는 Graalvm을 통해 Java 코드를 컴파일하여 플랫폼 독립성을 확장하지만 성능을 위해 다른 언어와 경쟁해야합니다.

다른 JVM 구현은 플랫폼 독립성을 제공 할 수 있지만 성능은 약간 다릅니다. 1. OracleHotspot 및 OpenJDKJVM 플랫폼 독립성에서 유사하게 수행되지만 OpenJDK에는 추가 구성이 필요할 수 있습니다. 2. IBMJ9JVM은 특정 운영 체제에서 최적화를 수행합니다. 3. Graalvm은 여러 언어를 지원하며 추가 구성이 필요합니다. 4. AzulzingJVM에는 특정 플랫폼 조정이 필요합니다.

플랫폼 독립성은 여러 운영 체제에서 동일한 코드 세트를 실행하여 개발 비용을 줄이고 개발 시간을 단축시킵니다. 구체적으로, 그것은 다음과 같이 나타납니다. 1. 개발 시간을 줄이면 하나의 코드 세트 만 필요합니다. 2. 유지 보수 비용을 줄이고 테스트 프로세스를 통합합니다. 3. 배포 프로세스를 단순화하기위한 빠른 반복 및 팀 협업.

Java'SplatformIndenceFacilitatesCodereScoderEByWatHeAveringByTeCodetOrunonAnyPlatformwitHajvm.1) DevelopersCanwriteCodeOnceforConsentEStentBehaviorAcRossPlatforms.2) MAINTENDUCEDSCODEDOES.3) LIBRRIESASHSCORAREDERSCRAPERAREDERSPROJ

Java 응용 프로그램의 플랫폼 별 문제를 해결하려면 다음 단계를 수행 할 수 있습니다. 1. Java의 시스템 클래스를 사용하여 시스템 속성을보고 실행중인 환경을 이해합니다. 2. 파일 클래스 또는 java.nio.file 패키지를 사용하여 파일 경로를 처리하십시오. 3. 운영 체제 조건에 따라 로컬 라이브러리를로드하십시오. 4. visualVM 또는 JProfiler를 사용하여 크로스 플랫폼 성능을 최적화하십시오. 5. 테스트 환경이 Docker Containerization을 통해 생산 환경과 일치하는지 확인하십시오. 6. githubactions를 사용하여 여러 플랫폼에서 자동 테스트를 수행하십시오. 이러한 방법은 Java 응용 프로그램에서 플랫폼 별 문제를 효과적으로 해결하는 데 도움이됩니다.

클래스 로더는 통합 클래스 파일 형식, 동적로드, 부모 위임 모델 및 플랫폼 독립적 인 바이트 코드를 통해 다른 플랫폼에서 Java 프로그램의 일관성과 호환성을 보장하고 플랫폼 독립성을 달성합니다.

Java 컴파일러가 생성 한 코드는 플랫폼 독립적이지만 궁극적으로 실행되는 코드는 플랫폼 별입니다. 1. Java 소스 코드는 플랫폼 독립적 인 바이트 코드로 컴파일됩니다. 2. JVM은 바이트 코드를 특정 플랫폼의 기계 코드로 변환하여 크로스 플랫폼 작동을 보장하지만 성능이 다를 수 있습니다.

멀티 스레딩은 프로그램 대응 성과 리소스 활용을 향상시키고 복잡한 동시 작업을 처리 할 수 있기 때문에 현대 프로그래밍에서 중요합니다. JVM은 스레드 매핑, 스케줄링 메커니즘 및 동기화 잠금 메커니즘을 통해 다양한 운영 체제에서 멀티 스레드의 일관성과 효율성을 보장합니다.


핫 AI 도구

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

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

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

Clothoff.io
AI 옷 제거제

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

인기 기사

뜨거운 도구

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

맨티스BT
Mantis는 제품 결함 추적을 돕기 위해 설계된 배포하기 쉬운 웹 기반 결함 추적 도구입니다. PHP, MySQL 및 웹 서버가 필요합니다. 데모 및 호스팅 서비스를 확인해 보세요.

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

VSCode Windows 64비트 다운로드
Microsoft에서 출시한 강력한 무료 IDE 편집기

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