부모글 보이기/감추기 AD BLOCK 해제 요청 이 글에는 광고가 많이 들어가 있지 않습니다. adblock을 해제하셔도 글을 읽는데 그다지 부담이 없으니 해제를 부탁드립니다. (연관된 글이 1개 있습니다.) "Anonymous types"를 설명하기 전에, 예전에 RubyCLR을 소개해 드렸을 때 첨부했던 이미지를 한번 보겠습니다. 위의 구문 비교를 보고 있노라면 왠지, C# 사용자로서 오기가 발동합니다. 음... 아마도 이런 생각을 저만 한 것이 아니었나 봅니다. C# 3.0에 새로 추가된 "Anonymous type"에서 위의 Ruby와 유사한 문법을 지원해주고 있는 것입니다. 사용예를 한번 볼까요? C# 3.0: var Person = new { name = "", birthday = DateTime.MinValue, children = 0 }; Ruby : Person = Struct.new(:name, :birthday, :children) 사실, Anonymous type은 Ruby가 그 이유인 것은 아닌듯 합니다. 왜냐하면, 실제로 Linq를 표현하기 위해서도 필요하기 때문입니다. SQL 테이블에서 특정 컬럼만을 선별하여 반환하는 구문이 빈번하게 쓰이는 것을 볼 수 있는데요. 바로 그런 면에서 anonymous type이 유용하게 사용되어지고 있습니다. Linq와의 연관성에 대해서는 다음의 토픽을 참조하시는 것이 도움이 될 수 있겠습니다. C# 3.0의 새로운 기능들!!! - 5. Anonymous types ; http://blogs.msdn.com/heejaechang/archive/2006/04/28/586568.aspx 그러니까... 정리해 보면, C# 3.0의 많은 기능들이, Linq를 위해서 탄생되었다고 해도 무방할 것 같습니다. 마치, CLR 2.0에서도 안정성을 위해 추가된 부분들이 SqlCLR을 위해서 탄생했던 것처럼. [이 토픽에 대해서 여러분들과 의견을 공유하고 싶습니다. 틀리거나 미흡한 부분 또는 의문 사항이 있으시면 언제든 댓글 남겨주십시오.] [다음 글] Windows: 17. 보안 데스크톱에서 활성화되지 않은 UAC 창이 안전할까?[이전 글] .NET Framework: 77. C# 3.0 - Lambda 표현식 [연관 글] C# 언어 ... 좋은데... 정말 좋은데... 뭐라 표현할 말이 없네... ^^ [최초 등록일: 1/24/2007] [최종 수정일: 6/28/2021] 이 저작물은 크리에이티브 커먼즈 코리아 저작자표시-비영리-변경금지 2.0 대한민국 라이센스에 따라 이용하실 수 있습니다. by SeongTae Jeong, mailto:techsharer at outlook.com 비밀번호 댓글 작성자 2007-05-15 09시01분 New "Orcas" Language Feature: Anonymous Types ; http://weblogs.asp.net/scottgu/archive/2007/05/15/new-orcas-language-feature-anonymous-types.aspx kevin25 ... 76 77 [78] 79 80 81 82 83 84 85 86 87 88 89 90 ... NoWriterDateCnt.TitleFile(s) 12101정성태1/5/202026903.NET Framework: 876. C# - PEB(Process Environment Block)를 통해 로드된 모듈 목록 열람12100정성태1/3/202023451.NET Framework: 875. .NET 3.5 이하에서 IntPtr.Add 사용12099정성태1/3/202027095디버깅 기술: 151. Windows 10 - Process Explorer로 확인한 Handle 정보를 windbg에서 조회 [1]12098정성태1/2/202026770.NET Framework: 874. C# - 커널 구조체의 Offset 값을 하드 코딩하지 않고 사용하는 방법 [3]12097정성태1/2/202024025디버깅 기술: 150. windbg - Wow64, x86, x64에서의 커널 구조체(예: TEB) 구조체 확인12096정성태12/30/201925378디버깅 기술: 149. C# - DbgEng.dll을 이용한 간단한 디버거 제작 [1]12095정성태12/27/201927434VC++: 135. C++ - string_view의 동작 방식12094정성태12/26/201927261.NET Framework: 873. C# - 코드를 통해 PDB 심벌 파일 다운로드 방법12093정성태12/26/201925769.NET Framework: 872. C# - 로딩된 Native DLL의 export 함수 목록 출력112092정성태12/25/201923662디버깅 기술: 148. cdb.exe를 이용해 (ntdll.dll 등에 정의된) 커널 구조체 출력하는 방법12091정성태12/25/201927591디버깅 기술: 147. pdb 파일을 다운로드하기 위한 symchk.exe 실행에 필요한 최소 파일 [1]12090정성태12/24/201926528.NET Framework: 871. .NET AnyCPU로 빌드된 PE 헤더의 로딩 전/후 차이점 [1]112089정성태12/23/201923617디버깅 기술: 146. gflags와 _CrtIsMemoryBlock을 이용한 Heap 메모리 손상 여부 체크12088정성태12/23/201924126Linux: 28. Linux - 윈도우의 "Run as different user" 기능을 shell에서 실행하는 방법12087정성태12/21/201923822디버깅 기술: 145. windbg/sos - Dictionary의 entries 배열 내용을 모두 덤프하는 방법 (do_hashtable.py) [1]12086정성태12/20/201927146디버깅 기술: 144. windbg - Marshal.FreeHGlobal에서 발생한 덤프 분석 사례12085정성태12/20/201925829오류 유형: 586. iisreset - The data is invalid. (2147942413, 8007000d) 오류 발생 - 두 번째 이야기 [1]12084정성태12/19/201925129디버깅 기술: 143. windbg/sos - Hashtable의 buckets 배열 내용을 모두 덤프하는 방법 (do_hashtable.py) [1]12083정성태12/17/201927760Linux: 27. linux - lldb를 이용한 .NET Core 응용 프로그램의 메모리 덤프 분석 방법 [2]12082정성태12/17/201926017오류 유형: 585. lsof: WARNING: can't stat() fuse.gvfsd-fuse file system12081정성태12/16/201929162개발 환경 구성: 465. 로컬 PC에서 개발 중인 ASP.NET Core 웹 응용 프로그램을 다른 PC에서도 접근하는 방법 [5]12080정성태12/16/201925759.NET Framework: 870. C# - 프로세스의 모든 핸들을 열람12079정성태12/13/201927701오류 유형: 584. 원격 데스크톱(rdp) 환경에서 다중 또는 고용량 파일 복사 시 "Unspecified error" 오류 발생12078정성태12/13/201928298Linux: 26. .NET Core 응용 프로그램을 위한 메모리 덤프 방법 [3]12077정성태12/13/201924846Linux: 25. 자주 실행할 명령어 또는 초기 환경을 "~/.bashrc" 파일에 등록12076정성태12/12/201925032디버깅 기술: 142. Linux - lldb 환경에서 sos 확장 명령어를 이용한 닷넷 프로세스 디버깅 - 배포 방법에 따른 차이 ... 76 77 [78] 79 80 81 82 83 84 85 86 87 88 89 90 ...