집 >Java >Java인터뷰 질문들 >중급 및 고급 Java 면접 질문(답변 포함)
1. Redis를 로컬 데이터와 동기화하는 방법은 무엇입니까?
프로그램은 mysql 업데이트, 추가 및 삭제를 구현하고 redis를 동기적으로 작동합니다.
프로그램은 redis를 쿼리합니다. 존재하지 않으면 mysql을 쿼리하여 자동으로 redis를 저장합니다
2.
set, list, hash, string, zset
3. Java 메모리 오버플로는 어떻게 발생하나요?
OutOfMemoryError:
(1)PerGern Space 프로그램에 많은 수의 jar 또는 클래스가 사용되어 가상 머신에 로드할 클래스 공간이 부족합니다.
해결책: 매개변수 XX:PermSize 및 XX:MaxPermSize를 조정하고, jar 패키지를 줄이고, 클래스의 반복 로드를 줄입니다.
(2) Java Heap
Space Java 가상 머신이 너무 많은 개체를 생성합니다. 해결 방법: Xms(초기 힙 크기) 및 Xmx(최대 힙 크기) 매개변수를 조정하고 무한 루프 또는 중복 개체의 불필요한 생성을 확인하십시오.
(3) 새 기본 Thread를 생성할 수 없습니다
JVM은 메모리 공간을 너무 많이 차지하며 JVM에서 스레드를 생성하려면 운영 체제에서 스레드를 생성해야 합니다. 해결책: JVM에서 스레드 크기를 조정하십시오.
4. String s = “123”, 이 문으로 생성된 객체는 몇 개입니까?
문자열 풀에 "123"이 없으면 하나가 생성되고 "123"이 있으면 0이 생성됩니다.
5. 예제
( 1) 람다 식: 함수형 프로그래밍, 메서드 참조
(2) Stream API
(3) 인터페이스의 기본 메서드
(4) 날짜 및 시간 API 개선, 새로운 DateTimeFormatter 메서드
6. 솔루션 높은 동시성 및 높은 로드
(1) html을 최대한 정적으로 만들고, 정보 입력 및 릴리스 시스템 CMS를 사용하여 정보 입력을 위한 정적 페이지를 자동으로 생성하고, 자주 변경되지 않는 동적 데이터를 캐시에 저장합니다. 프런트 엔드.
(2) CDN 가속, CSS/JS 및 기타 리소스를 다른 서버에 배포
(3) 자주 변경되지 않는 캐시 데이터(Redis, memcache).
(4) 이미지 서버와 애플리케이션 서버가 분리되어 있습니다.
(5) Cluster
7. 생산자 모델과 소비자 모델의 역할은 무엇인가요?
(1) 생산 능력과 소비자 소비력의 균형을 통해 전체 시스템의 운영 효율성을 향상 (2) 디커플링
8, 마이바티스 1차 및 2차 캐시
(1) 1차 캐시 : PerpetualCache를 기반으로 하는 HashMap 로컬 캐시는 Session이 플러시되거나 닫힐 때 Session의 모든 캐시가 지워집니다.
(2) 두 번째 수준 캐시는 기본적으로 PerpetualCache 및 HashMap 저장소도 사용합니다. 차이점은 저장소 범위 Mapper에 있으며 저장소 소스를 사용자 지정할 수 있습니다. 두 번째 수준 캐시를 활성화해야 합니다. 게시부터 소비까지 서비스의 세부 프로세스를 설명하려면 SQL 매핑 파일에
9를 추가하세요먼저 zk 구성 정보를 가져온 다음 노출해야 하는 URL을 가져온 다음 레지스트리, 등록 메서드를 호출합니다. 사육사에 URL을 등록하려면
10. 로드 밸런싱을 구현하는 방법은 무엇입니까?Random, Round-Robin, Consistency-Hash 및 Master-Slave
11. Spring AOP를 구현하려면 어떻게 해야 할까요?AOP 기술의 구현은 주로 두 가지 범주로 나뉩니다. 하나는 동적 프록시 기술을 사용하고, 메시지를 가로채서 메시지를 장식하여 원래 개체 동작의 실행을 대체하는 방법입니다.
다른 하나는 정적을 사용하는 것입니다. weaving , "aspect"를 생성하기 위한 특정 구문을 도입하여 컴파일러가 "aspect"와 관련된 코드를 엮을 수 있도록 합니다.
12. 반복적인 페이지 제출을 방지하는 방법은 무엇입니까?클러스터 환경: 토큰과 redis 사용(redis는 단일 스레드이므로 처리가 대기열에 있어야 함)
처리 프로세스:
1 데이터를 제출하기 전에 서비스에서 토큰을 신청해야 하며 토큰은 다음과 같습니다. Redis 메모리에 배치됩니다. 토큰은
동안 유효합니다. 2. 제출 후 토큰이 백그라운드에서 확인되고 토큰이 삭제되며 새 토큰이 생성되어 반환됩니다.
13. 마이크로서비스란 무엇입니까?다양한 비즈니스 규칙에 따라 프로젝트를 마이크로서비스로 분할하고 다양한 시스템에 배포하세요. 서비스끼리 통화해요
14. 웹서비스란?(1) 웹 서비스는 웹을 통해 호출할 수 있는 API를 외부 세계에 노출하는 애플리케이션입니다.
(2) HTTP 프로토콜을 기반으로 데이터를 전송합니다. 추가로 전문화된 타사 소프트웨어 및 하드웨어가 데이터를 교환하거나 서로 통합할 수 있어야 합니다
15. 귀하의 프로젝트에 Struts2를 선택한 이유에 대해 알려주십시오.①Action은 POJO 클래스이며 Servlet API에 의존하지 않으며 우수한 테스트 가능성을 갖습니다. ②강력한 인터셉터는 개발의 복잡성을 단순화합니다.
③JSP, Freemarker 등 다양한 프리젠테이션 계층 기술을 지원합니다. ⑤국제화; I18N)은 ⑥선언적 예외 관리를 지원합니다.
7JSON 플러그인을 통해 Ajax를 단순화합니다. 8Spring 플러그인을 통해 Spring과 통합합니다.
16.인터셉터와 필터는 모두 교차 주의 기능을 구현하는 데 사용할 수 있습니다. 주요 차이점은 다음과 같습니다. ①인터셉터는 JAVA 반사 메커니즘을 기반으로 하는 반면 필터는 함수 콜백을 기반으로 합니다. ②필터는 서블릿 컨테이너에 의존하고 인터셉터는 그렇지 않습니다. 서블릿 컨테이너에 따라 다름 ③인터셉터는 Action 요청(Action의 메서드)에만 작동할 수 있지만 필터는 거의 모든 요청(CSS JSP JS)에 작동할 수 있습니다. 17, Spring에서 지원하는 트랜잭션 관리 유형? 프로그래밍 방식의 트랜잭션 관리: 프로그래밍 방식으로 관리, 높은 유연성, 유지 관리 어려움 선언적 트랜잭션 관리: 비즈니스 코드와 트랜잭션 관리를 분리할 수 있으며, 주석과 XML 구성만 사용하여 관리하면 됩니다. PHP 중국어 웹사이트, 수많은 무료 Java 입문 튜토리얼, 온라인 학습에 오신 것을 환영합니다!
위 내용은 중급 및 고급 Java 면접 질문(답변 포함)의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!