diff --git a/src/main/java/com/claudecode/tui/ClaudeCodeComponent.java b/src/main/java/com/claudecode/tui/ClaudeCodeComponent.java index b4d5943..c379041 100644 --- a/src/main/java/com/claudecode/tui/ClaudeCodeComponent.java +++ b/src/main/java/com/claudecode/tui/ClaudeCodeComponent.java @@ -604,7 +604,9 @@ public class ClaudeCodeComponent extends Component Consumer cb = permissionCallback; permissionCallback = null; setState(new TuiState("", s.messages, 0, false, "")); - if (cb != null) cb.accept(answer); + if (cb != null) { + Thread.startVirtualThread(() -> cb.accept(answer)); + } } else if (key.backspace() && !s.inputText.isEmpty()) { setState(new TuiState(s.inputText.substring(0, s.inputText.length() - 1), s.messages, s.scrollOffset, false, "")); @@ -669,7 +671,7 @@ public class ClaudeCodeComponent extends Component } } - /** 确认 AskUser 选择并回调 */ + /** 确认 AskUser 选择并回调(调用方已持有 stateLock) */ private void confirmAskUser(String answer) { Consumer cb = permissionCallback; permissionCallback = null; @@ -677,11 +679,12 @@ public class ClaudeCodeComponent extends Component askQuestion = null; askInputMode = false; askSelectedIndex = 0; - synchronized (stateLock) { - TuiState s = getState(); - setState(new TuiState("", s.messages, 0, false, "")); + TuiState s = getState(); + setState(new TuiState("", s.messages, 0, false, "")); + // 回调在锁外执行(cb.accept 可能阻塞或触发其他状态变更) + if (cb != null) { + Thread.startVirtualThread(() -> cb.accept(answer)); } - if (cb != null) cb.accept(answer); } /** 处理滚动输入 */