부모글 보이기/감추기 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 ... 61 62 63 64 65 66 67 68 69 70 [71] 72 73 74 75 ... NoWriterDateCnt.TitleFile(s) 12162정성태2/26/202021904디버깅 기술: 166. C#에서 만든 COM 객체를 C/C++로 P/Invoke Interop 시 메모리 누수(Memory Leak) 발생 [6]212161정성태2/26/202017944오류 유형: 597. manifest - The value "x64" of attribute "processorArchitecture" in element "assemblyIdentity" is invalid.12160정성태2/26/202018299개발 환경 구성: 469. Reg-free COM 개체 사용을 위한 manifest 파일 생성 도구 - COMRegFreeManifest12159정성태2/26/202015374오류 유형: 596. Visual Studio - The project needs to include ATL support12158정성태2/25/202017965디버깅 기술: 165. C# - Marshal.GetIUnknownForObject/GetIDispatchForObject 사용 시 메모리 누수(Memory Leak) 발생112157정성태2/25/202017990디버깅 기술: 164. C# - Marshal.GetNativeVariantForObject 사용 시 메모리 누수(Memory Leak) 발생 및 해결 방법112156정성태2/25/202016566오류 유형: 595. LINK : warning LNK4098: defaultlib 'nafxcw.lib' conflicts with use of other libs; use /NODEFAULTLIB:library12155정성태2/25/202016017오류 유형: 594. Warning NU1701 - This package may not be fully compatible with your project12154정성태2/25/202015400오류 유형: 593. warning LNK4070: /OUT:... directive in .EXP differs from output filename12153정성태2/23/202019534.NET Framework: 898. Trampoline을 이용한 후킹의 한계112152정성태2/23/202018578.NET Framework: 897. 실행 시에 메서드 가로채기 - CLR Injection: Runtime Method Replacer 개선 - 세 번째 이야기(Trampoline 후킹)112151정성태2/22/202019388.NET Framework: 896. C# - Win32 API를 Trampoline 기법을 이용해 C# 메서드로 가로채는 방법 - 두 번째 이야기 (원본 함수 호출)112150정성태2/21/202019645.NET Framework: 895. C# - Win32 API를 Trampoline 기법을 이용해 C# 메서드로 가로채는 방법 [1]112149정성태2/20/202018422.NET Framework: 894. eBEST C# XingAPI 래퍼 - 연속 조회 처리 방법 [1]12148정성태2/19/202020962디버깅 기술: 163. x64 환경에서 구현하는 다양한 Trampoline 기법 [1]12147정성태2/19/202018630디버깅 기술: 162. x86/x64의 기계어 코드 최대 길이12146정성태2/18/202019394.NET Framework: 893. eBEST C# XingAPI 래퍼 - 로그인 처리112145정성태2/18/202019259.NET Framework: 892. eBEST C# XingAPI 래퍼 - Sqlite 지원 추가112144정성태2/13/202019481.NET Framework: 891. 실행 시에 메서드 가로채기 - CLR Injection: Runtime Method Replacer 개선 - 두 번째 이야기112143정성태2/13/202016012.NET Framework: 890. 상황별 GetFunctionPointer 반환값 정리 - x64112142정성태2/12/202018413.NET Framework: 889. C# 코드로 접근하는 MethodDesc, MethodTable112141정성태2/10/202017409.NET Framework: 888. C# - ASP.NET Core 웹 응용 프로그램의 출력 가로채기 [2]112140정성태2/10/202017981.NET Framework: 887. C# - ASP.NET 웹 응용 프로그램의 출력 가로채기112139정성태2/9/202019208.NET Framework: 886. C# - Console 응용 프로그램에서 UI 스레드 구현 방법12138정성태2/9/202023244.NET Framework: 885. C# - 닷넷 응용 프로그램에서 SQLite 사용 [6]112137정성태2/9/202016450오류 유형: 592. [AhnLab] 경고 - 디버거 실행을 탐지했습니다. ... 61 62 63 64 65 66 67 68 69 70 [71] 72 73 74 75 ...