Microsoft MVP성태의 닷넷 이야기
.NET Framework: 253. Roslyn 맛보기 - C# Interactive (1) [링크 복사], [링크+제목 복사],
조회: 26211
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일
 
(연관된 글이 7개 있습니다.)

Roslyn 맛보기 - C# Interactive (1)


Roslyn 맛보기 (1) - C# 소스 코드를 스크립트 처럼 다루는 방법
Roslyn 맛보기 (2) - C# Interactive (1)
Roslyn 맛보기 (3) - C# Interactive (2)
Roslyn 맛보기 (4) - Roslyn Services APIs를 이용한 Code Issue 및 Code Action 기능 소개
Roslyn 맛보기 (5) - Syntax Analysis (Roslyn Syntax API)
Roslyn 맛보기 (6) - Roslyn Symbol / Binding API
Roslyn 맛보기 (7) - SyntaxTree 조작

F# 공부하시는 분들은... "F# Interactive" 윈도우를 한번쯤 사용해 보셨을 텐데요. Roslyn이 나오면서, Roslyn 자체의 실습(?) 대상으로 만들어져 제공되는 "C# Interactive"가 새롭게 추가되었습니다. (아니면, C# 용 "Immediate Window"가 하나 생겼다고 보셔도 됩니다. ^^)

Roslyn을 설치하면, Visual Studio에서 "View" / "Other Windows" / "C# Interactive Window" 메뉴가 생기는데, 실행하면 다음과 같은 창이 뜹니다.

csharp_interactive_1.png

여기에 입력할 수 있는 명령어는 크게 2가지 종류로 나뉩니다.

  • C# Interactive 명령어
  • C# 코드

"C# Interactive"의 자체적인 명령어는 prompt에서 "# (Sharp)" 글자로 시작해서 명령을 내리면 됩니다. 아래는 '#help'로 구한 명령어 목록입니다.

cls Clears the contents of the REPL editor window.
help Display help on specified command, or all available commands and key bindings if none specified.
load Executes the specified file within the current interactive session.
prompt Changes the current prompt settings.
reset Reset the execution environment to the initial state, keep REPL history.


그 외에 입력되는 모든 문자열은 "C# 코드"라고 보시면 됩니다. Interactive 창에서 수행되는 모든 C# 명령어는 하나의 문맥을 공유합니다. 지난번 글에서 살펴본 대로라면,

Roslyn 맛보기 - C# 소스 코드를 스크립트 처럼 다루는 방법
; https://www.sysnet.pe.kr/2/0/1153

단일 Session 값이 유지된다는 의미가 됩니다. 일련의 명령어들이 같은 Session 인스턴스를 공유하기 때문에 아래의 화면에서처럼 이전 명령어 실행 결과에 영향을 받는 실행 결과를 보여줍니다.

csharp_interactive_2.png




처음에는, C# Interactive 기능이 F#에 비해서 과연 많이 쓰일까 하는 의문이 들었는데, 경험상 나름 개발을 하는 동안 간단한 코드들에 대한 검증에서 유용하게 사용할 수 있었습니다. 예를 들어, "닷넷에서 지원되는 문자열 인코딩 이름 목록" 글에서 보여지는 간단한 코드들의 경우에 기존에는 일부러 테스트를 위해 콘솔 프로젝트를 별도로 만들어서 확인해야 했는데, 이제는 빠르게 C# Interactive 윈도우에서 그 결과를 확인할 수 있었습니다.

사용하다보니, 기왕이면 #help 명령어로 나오는 단축키를 익혀두는 것이 좋겠더군요. ^^ (아래의 목록에서 '빨간색' 항목은 제가 자주 사용하는 단축키입니다.)

> #help
Keyboard shortcuts:
  Enter                Evaluate the current input if it appears to be complete.
  Ctrl-Enter           If the caret is in current pending input submission, evaluate the entire submission.
                       If the caret is in a previous input block, copy that input text to the end of the buffer.
  Shift-Enter          If the caret is in the current pending input submission, insert a new line.
  Escape               If the caret is in the current pending input submission, delete the entire submission.
  Alt-UpArrow          Paste previous input at end of buffer, rotate through history.
  Alt-DownArrow        Paste next input at end of buffer, rotate through history.
  UpArrow              Normal editor buffer navigation.
  DownArrow            Normal editor buffer navigation.
  Ctrl-K, Ctrl-Enter   Paste the selection at the end of interactive buffer, leave caret at the end of input.
  Ctrl-E, Ctrl-Enter   Paste and execute the selection before any pending input in the interactive buffer.
  Ctrl-A               Alternatively select current input or whole buffer.

특히, Interactive 윈도우에서 직접 코드를 입력하기 보다는 C# 코드 윈도우 창에서 입력한 후 특정 영역을 선택하여 실행하는 "Ctrl-E, Ctrl-Enter"기능이 유용했습니다. (아쉽게도 F# Interactive에서 해당 기능의 단축키를 "Alt+Enter"로 선점하고 있어서 C#의 경우에 남은 단축키 영역이 부족해 어쩔 수 없이 복잡해진 것 같습니다. ^^)

참고로, 이번 글은 "C:\Program Files (x86)\Microsoft Codename Roslyn CTP\Documentation\Interactive - Executing Code in the Interactive Window.docx" 문서를 요약했다고 보시면 됩니다. ^^




[이 글에 대해서 여러분들과 의견을 공유하고 싶습니다. 틀리거나 미흡한 부분 또는 의문 사항이 있으시면 언제든 댓글 남겨주십시오.]

[연관 글]






[최초 등록일: ]
[최종 수정일: 6/27/2021]

Creative Commons License
이 저작물은 크리에이티브 커먼즈 코리아 저작자표시-비영리-변경금지 2.0 대한민국 라이센스에 따라 이용하실 수 있습니다.
by SeongTae Jeong, mailto:techsharer at outlook.com

비밀번호

댓글 작성자
 




1  2  [3]  4  5  6  7  8  9  10  11  12  13  14  15  ...
NoWriterDateCnt.TitleFile(s)
13561정성태2/20/20242048닷넷: 2218. C# - (예를 들어, Socket) 비동기 I/O에 대한 await 호출 시 CancellationToken을 이용한 취소파일 다운로드1
13560정성태2/19/20242083디버깅 기술: 195. windbg 분석 사례 - Semaphore 잠금으로 인한 Hang 현상 (닷넷)
13559정성태2/19/20242943오류 유형: 895. ASP.NET - System.Security.SecurityException: 'Requested registry access is not allowed.'
13558정성태2/18/20242169닷넷: 2217. C# - 최댓값이 1인 SemaphoreSlim 보다 Mutex 또는 lock(obj)를 선택하는 것이 나은 이유
13557정성태2/18/20241920Windows: 258. Task Scheduler의 Author 속성 값을 변경하는 방법
13556정성태2/17/20241964Windows: 257. Windows - Symbolic (hard/soft) Link 및 Junction 차이점
13555정성태2/15/20242116닷넷: 2216. C# - SemaphoreSlim 사용 시 주의점
13554정성태2/15/20241861VS.NET IDE: 189. Visual Studio - 닷넷 소스코드 디컴파일 찾기가 안 될 때
13553정성태2/14/20241943닷넷: 2215. windbg - thin/fat lock 없이 동작하는 Monitor.Wait + Pulse
13552정성태2/13/20241895닷넷: 2214. windbg - Monitor.Enter의 thin lock과 fat lock
13551정성태2/12/20242089닷넷: 2213. ASP.NET/Core 웹 응용 프로그램 - 2차 스레드의 예외로 인한 비정상 종료
13550정성태2/11/20242206Windows: 256. C# - Server socket이 닫히면 Accept 시켰던 자식 소켓이 닫힐까요?
13549정성태2/3/20242504개발 환경 구성: 706. C# - 컨테이너에서 실행하기 위한 (소켓) 콘솔 프로젝트 구성
13548정성태2/1/20242332개발 환경 구성: 705. "Docker Desktop for Windows" - ASP.NET Core 응용 프로그램의 소켓 주소 바인딩(IPv4/IPv6 loopback, Any)
13547정성태1/31/20242085개발 환경 구성: 704. Visual Studio - .NET 8 프로젝트부터 dockerfile에 추가된 "USER app" 설정
13546정성태1/30/20241944Windows: 255. (디버거의 영향 등으로) 대상 프로세스가 멈추면 Socket KeepAlive로 연결이 끊길까요?
13545정성태1/30/20241859닷넷: 2212. ASP.NET Core - 우선순위에 따른 HTTP/HTTPS 호스트:포트 바인딩 방법
13544정성태1/30/20241883오류 유형: 894. Microsoft.Data.SqlClient - Could not load file or assembly 'System.Security.Permissions, ...'
13543정성태1/30/20241881Windows: 254. Windows - 기본 사용 중인 5357 포트 비활성화는 방법
13542정성태1/30/20241913오류 유형: 893. Visual Studio - Web Application을 실행하지 못하는 IISExpress - 두 번째 이야기
13541정성태1/29/20241955VS.NET IDE: 188. launchSettings.json의 useSSL 옵션
13540정성태1/29/20242076Linux: 69. 리눅스 - "Docker Desktop for Windows" Container 환경에서 IPv6 Loopback Address 바인딩 오류
13539정성태1/26/20242365개발 환경 구성: 703. Visual Studio - launchSettings.json을 이용한 HTTP/HTTPS 포트 바인딩
13538정성태1/25/20242418닷넷: 2211. C# - NonGC(FOH) 영역에 .NET 개체를 생성파일 다운로드1
13537정성태1/24/20242504닷넷: 2210. C# - Native 메모리에 .NET 개체를 생성파일 다운로드1
13536정성태1/23/20242593닷넷: 2209. .NET 8 - NonGC Heap / FOH (Frozen Object Heap) [1]
1  2  [3]  4  5  6  7  8  9  10  11  12  13  14  15  ...