Thư Viện Câu Hỏi Phỏng Vấn
Tổng hợp các câu hỏi tuyển dụng thực tế theo nhiều cấp độ từ Entry đến Expert để bạn tự tin chinh phục nhà tuyển dụng.
Virtual Threads (Project Loom) trong Java 21 là gì và khác gì so với Platform Threads truyền thống?
Virtual Threads là các luồng ảo siêu nhẹ được giới thiệu chính thức từ Java 21. Khác biệt cốt lõi:
- Platform Threads: Được bọc trực tiếp quanh luồng của hệ điều hành (OS Thread), tốn khoảng 1MB bộ nhớ stack và tốn tài nguyên context switch. Số lượng bị giới hạn bởi hệ điều hành (thường vài nghìn).
- Virtual Threads: Được quản lý bởi JVM, chạy trên nền của các Platform Threads (Carrier Threads). Khi một Virtual Thread gặp tác vụ blocking I/O, JVM sẽ tạm dừng nó và nhường Carrier Thread cho tác vụ khác. Nó chỉ tốn vài trăm byte bộ nhớ, cho phép chạy hàng triệu Virtual Threads đồng thời trên cùng một phần cứng mà không lo quá tải.
Cơ chế Garbage Collection trong JavaScript hoạt động như thế nào? Giải thích thuật toán Mark-and-Sweep?
JavaScript tự động quản lý bộ nhớ thông qua cơ chế Garbage Collection. Thuật toán chính được sử dụng hiện nay là Mark-and-Sweep (Đánh dấu và Dọn dẹp):
- Mark (Đánh dấu): Garbage Collector sẽ xác định một tập hợp các đối tượng gốc (gọi là GC Roots, ví dụ: biến toàn cục, luồng thực thi hiện tại). Sau đó, nó sẽ duyệt đệ quy cây tham chiếu từ Roots để đánh dấu (mark) tất cả các đối tượng có thể tiếp cận được (reachable).
- Sweep (Dọn dẹp): GC quét qua toàn bộ vùng nhớ Heap, những đối tượng nào không được đánh dấu (unreachable) sẽ bị giải phóng bộ nhớ (sweep) và thu hồi không gian.
Laravel Service Container là gì?
Service Container của Laravel là một công cụ mạnh mẽ dùng để quản lý các class dependencies và thực hiện dependency injection (DI).
Nó hoạt động như một kho chứa tập trung, nơi đăng ký cách khởi tạo các dịch vụ (Services). Khi một Controller hoặc Service khác yêu cầu một dependency, Laravel sẽ tự động phân tích và tiêm (inject) dependency đó thông qua Type Hinting.
Làm thế nào để phát hiện và tối ưu hóa lỗi truy vấn N+1 (N+1 query problem) trong Eloquent ORM của Laravel?
Lỗi N+1 xảy ra khi bạn truy vấn danh sách bản ghi và với mỗi bản ghi, bạn lại thực hiện thêm một truy vấn con để lấy quan hệ liên kết.
- Phát hiện: Sử dụng các công cụ như Laravel Debugbar hoặc Telescope để theo dõi số lượng câu lệnh SQL được thực thi.
- Khắc phục: Sử dụng phương pháp Eager Loading bằng cách gọi phương thức
with('relation')khi truy vấn. Ví dụ:Book::with('author')->get(). Điều này sẽ gộp truy vấn con lại thành một câu lệnh SQL duy nhất sử dụngIN (...), giảm số lượng truy vấn từ N+1 xuống còn đúng 2 truy vấn.
Sự khác biệt giữa Repository Pattern và Service Layer trong kiến trúc dự án Laravel?
Làm thế nào để xử lý các tác vụ nặng (như gửi email hàng loạt, xử lý video) bất đồng bộ trong Laravel?
Sử dụng hệ thống Queues & Job Workers của Laravel:
- Cấu hình Queue Connection: Thiết lập driver (như Redis, Database, SQS) trong file
.env(khuyên dùngredischo môi trường production). - Tạo Job Class: Sử dụng lệnh
php artisan make:job ProcessPodcast. Trong phương thứchandle(), viết logic xử lý nặng. - Dispatch Job: Gọi
ProcessPodcast::dispatch($data)từ Controller để đẩy tác vụ vào hàng đợi và phản hồi ngay lập tức cho client. - Chạy Worker: Chạy lệnh
php artisan queue:worktrên server (thường quản lý bởi Supervisor) để liên tục lấy các jobs ra khỏi hàng đợi và xử lý bất đồng bộ.
Cơ chế Route Caching và Config Caching trong Laravel hoạt động như thế nào và tại sao cần lưu ý khi deploy?
route:cache): Biên dịch tất cả các khai báo route trong file routes/*.php thành một mảng phẳng duy nhất được lưu trong bộ nhớ đệm của framework, giúp tăng tốc độ điều hướng đáng kể.config:cache): Gộp toàn bộ các file cấu hình trong thư mục config/*.php thành một file duy nhất.env() sẽ luôn trả về null bên ngoài các file config. Do đó, Best Practice là chỉ gọi env() trong các file ở thư mục config, còn trong Controller/Service bắt buộc phải gọi thông qua config('key').React Server Components (RSC) là gì và khác gì so với Server-Side Rendering (SSR) truyền thống?
State Management: So sánh Redux Toolkit và Zustand? Khi nào nên chọn cái nào?
Sự khác biệt giữa Worker Threads và Cluster Module trong Node.js? Khi nào dùng cái nào?
Cơ chế hoạt động của Stream API trong Node.js? Tại sao nó giúp tối ưu hóa bộ nhớ RAM?
Stream là cơ chế đọc/ghi dữ liệu theo từng phần nhỏ (chunks) liên tục, thay vì tải toàn bộ file vào RAM một lần duy nhất.
- Ví dụ: Khi đọc một file dung lượng 4GB trên server có RAM 2GB, nếu đọc bình thường bằng
fs.readFile, server sẽ bị crash do tràn RAM (Out of Memory). Nhưng nếu dùngfs.createReadStream, dữ liệu được chia nhỏ thành các buffer chunk khoảng vài chục KB và truyền đi liên tục (pipe) sang writable stream, giúp lượng RAM tiêu thụ luôn ở mức rất thấp và ổn định.
Làm thế nào để phát hiện và xử lý hiện tượng rò rỉ bộ nhớ (Memory Leak) trong ứng dụng Node.js chạy production?
v8 hoặc cắm --inspect để dùng Chrome DevTools so sánh sự khác biệt (đặc biệt tìm các đối tượng tăng đột biến không bị giải phóng).removeListener.Spring Boot Starter là gì và cơ chế Auto-Configuration hoạt động như thế nào?
spring-boot-starter-web bao gồm cả Spring MVC, Tomcat, Jackson...).@EnableAutoConfiguration (nằm trong @SpringBootApplication). Lúc khởi động, Spring Boot sẽ quét classpath, nếu phát hiện sự hiện diện của một thư viện nhất định (ví dụ H2 Database), nó sẽ tự động cấu hình các Beans mặc định cho thư viện đó mà không cần viết cấu hình thủ công, trừ khi lập trình viên tự ghi đè cấu hình.Làm thế nào để xử lý các giao dịch (Transactions) đồng thời trong Spring Boot bằng @Transactional?
Chú thích @Transactional của Spring được dùng để tự động hóa việc quản lý transaction (commit nếu thành công, rollback nếu có runtime exception):
- Cơ chế: Spring sử dụng AOP (Aspect-Oriented Programming) tạo ra một proxy bao quanh class/method đó để mở và đóng kết nối transaction.
- Lưu ý quan trọng: Lời gọi tự thân (Self-invocation - gọi phương thức
@Transactionaltừ một phương thức khác bên trong cùng một class) sẽ không kích hoạt transaction vì proxy bị bỏ qua. Để khắc phục, cần tách phương thức đó sang một bean khác hoặc inject chính bean đó thông qua Spring Context.
Tại sao Lambda Expressions syntax lại đóng vai trò quan trọng khi phát triển ứng dụng LINQ chịu tải cao?
Trong phát triển dự án với LINQ, việc tối ưu hóa và quản lý tốt Lambda Expressions syntax là vô cùng quan trọng để đảm bảo tính ổn định và hiệu năng của hệ thống. Dưới đây là các khía cạnh kỹ thuật cốt lõi:
- Cơ chế hoạt động: Nắm vững vòng đời và cách thức hoạt động của
Lambda Expressions syntaxdưới runtime để tránh các lỗi logic phổ biến. - Best Practices: Áp dụng các mẫu thiết kế chuẩn, hạn chế tối đa tài nguyên dư thừa và sử dụng các thư viện hỗ trợ tối ưu.
- Khắc phục lỗi: Sử dụng công cụ giám sát (APM, Profiling, Logs) để theo dõi hành vi, phát hiện kịp thời các hiện tượng như rò rỉ bộ nhớ hoặc nghẽn luồng.
- Tối ưu hóa: Cấu hình các tham số hệ thống phù hợp với quy mô tải thực tế của ứng dụng.



.png)
.png)