‫۱۱ سال و ۲ ماه قبل، چهارشنبه ۲۳ مرداد ۱۳۹۲، ساعت ۲۰:۲۵
من کد رو به صورت زیر تغییر دادم
 var ctx = new Entities();
            var Fields = ctx.ENTITIES_FEILDS.ToList();
            var assemblyBuilder = AppDomain.CurrentDomain.DefineDynamicAssembly(
                                    name: new AssemblyName("Demo"), access: AssemblyBuilderAccess.Run);

            var moduleBuilder = assemblyBuilder.DefineDynamicModule(name: "Module");

            var typeBuilder = moduleBuilder.DefineType(name: Fields.First(c => c.FEILD_ID == 1).ENTITIES.ENTITY_NAME, attr: TypeAttributes.Public);

            foreach (var item in Fields)
            {
                switch (item.FEILD_TYPE)
                {
                    case 0://int
                        {
                            var intField = typeBuilder.DefineField(fieldName: string.Format("_{0}", item.FEILD_NAME), type: typeof(string),
                                                  attributes: FieldAttributes.Private);

                            var intProperty = typeBuilder.DefineProperty(
                                                    name: item.FEILD_NAME,
                                                    attributes: PropertyAttributes.HasDefault,
                                                    returnType: typeof(string),
                                                    parameterTypes: null); // خاصیت پارامتر ورودی ندارد

                            //تعریف گت
                            var intpropertyGetMethod = typeBuilder.DefineMethod(
                                                                name: string.Format("get_{0}", item.FEILD_NAME),
                                                                attributes: MethodAttributes.Public |
                               MethodAttributes.SpecialName |
                                                                            MethodAttributes.HideBySig,
                                                                returnType: typeof(string),
                                                                parameterTypes: Type.EmptyTypes);

                            // اتصال گت متد به خاصیت عددی 
                            intProperty.SetGetMethod(intpropertyGetMethod);


                            //تعریف ست
                            var propertySetMethod =
                                typeBuilder.DefineMethod(name: string.Format("set_{0}", item.FEILD_NAME),
                                attributes: MethodAttributes.Public |
                               MethodAttributes.SpecialName |
                                                                            MethodAttributes.HideBySig,
                                                                  returnType: typeof(void),
                                                                parameterTypes: new[] { typeof(string) });
                            //اتصال ست متد 
                            intProperty.SetSetMethod(propertySetMethod);


                            // بدنه گت متد در اینجا تعریف خواهد شد
                            var propertyGetMethodIL = intpropertyGetMethod.GetILGenerator();
                            propertyGetMethodIL.Emit(OpCodes.Ldarg_0); // بارگذاری اشاره‌گری به وهله‌ای از کلاس جاری در پشته
                            propertyGetMethodIL.Emit(OpCodes.Ldfld, intField); // بارگذاری فیلد نام
                            propertyGetMethodIL.Emit(OpCodes.Ret);

                            //بدنه ست متد در اینجا تعریف شده است
                            var propertySetIL = propertySetMethod.GetILGenerator();
                            propertySetIL.Emit(OpCodes.Ldarg_0);
                            propertySetIL.Emit(OpCodes.Ldarg_1);
                            propertySetIL.Emit(OpCodes.Stfld, intField);
                            propertySetIL.Emit(OpCodes.Ret);

                        }

                        break;
                    case 1://string
                        {

                        } break;
                }

            }
            var t = typeBuilder.CreateType();



            var instance = Activator.CreateInstance(t);
           
            var type = instance.GetType();

            //تغییر مقدار یک خاصیت
            var setNameMethod = type.GetMethod("set_CoOrder");
            setNameMethod.Invoke(obj: instance, parameters: new[] {"1"});


            // دسترسی به خاصیت نام
            var nProperty = t.GetProperty("CoOrder");
            // و دریافت مقدار آن برای نمایش
            var result = nProperty.GetValue(instance, null);

            Console.WriteLine(result);


           
           
            Console.ReadKey();
تا اینجا درست کار می‌کنه حال می‌خواهم از کلاسی که برای من ایجاد می‌کند یک لیست ایجاد کنم و بتونم بهش مقدار بدم. ولی هر چی تلاش کردم نتونستم کلاس خودم رو ایجاد کنم. ممنون میشم راهنمایی کنید
‫۱۱ سال و ۲ ماه قبل، چهارشنبه ۲۳ مرداد ۱۳۹۲، ساعت ۱۹:۳۸
برای ساده سازی و همچنین کپسوله کردن این عملیات، مراجعه کنید به مطالب زیر. در اینجا یک ClassGenerator با استفاده از Reflection Emit تهیه کرده‌اند:
Power of Reflection Emit 
How to create a class with properties at run time  
‫۱۱ سال و ۲ ماه قبل، چهارشنبه ۲۳ مرداد ۱۳۹۲، ساعت ۱۹:۲۶
- در متن فوق جایی عنوان نشده که تنها اگر تعداد فیلدها از قبل مشخص بود، اینکار قابل انجام است. همچنین اگر به مثال بحث دقت کنید، پارامتر name رشته‌ای است. یعنی هر نام خاصیت دلخواهی قابل تعریف است. نوع آن نیز قابل مقدار دهی و تغییر است.
- در حلقه‌ای که نوشتید، کدهای «افزودن فیلد خصوصی» مثال بحث، «تعریف خاصیت رشته‌ای نام» ، «اتصال گت متد به خاصیت رشته‌ای نام» و «تعریف بدنه گت متد» باید به ازای هر خاصیت، تکرار شوند (پارامتر name را با نام خاصیت‌ها جایگزین کنید؛ نوع آن هم قابل تغییر است). اگر set هم دارد، علاوه بر متد گت، متد set_XYZ هم باید اضافه شود و روش کار یکی است.
‫۱۱ سال و ۲ ماه قبل، چهارشنبه ۲۳ مرداد ۱۳۹۲، ساعت ۱۹:۰۴
با سلام، من می‌خواهم در یکی از پروژه‌ها از این روش استفاده کنم و سناریویی که من روی اون کار می‌کنم به صورت زیر است:

درون دیتابیس، یک Table دارم که درون این Table نام تمام موجودیت‌های سیستم خودم رو نگه می‌دارم و در یک Table دیگر تمام فیلدهای موجودیت‌ها را همراه با نوع داده آنها ذخیره می‌کنم

برای یک سری شرایط خاص می‌خواهم کار زیر را انجام دهم:

یک فرم طراحی کردم که برای تمام موجودیت‌های تعریف شده درون جدول Entities کاربرد داره ، می‌خواهم زمانی که این فرم اجرا شده با توجه به اینکه این فرم برای کدام موجودیت فراخوانی شده است یک کلاس برای آن موجودیت ایجاد کنم و پس از آن یک لیست از کلاسی که ایجاد شده ، ایجاد بکنم و درون آن لیست مقادیری را قرار دهم (مقادیر را از دیتابیس خوانده می‌شود) و در آخر مقادیر لیست را در یک کنترل مثل gridview نمایش دهم

حال من برای انجام این کار به چند مشکل برخوردم . کدی که نوشتم به صورت زیر است
 var ctx = new Entities();
            var Fields = ctx.ENTITIES_FEILDS.ToList();
            var assemblyBuilder = AppDomain.CurrentDomain.DefineDynamicAssembly(
                                    name: new AssemblyName("Demo"), access: AssemblyBuilderAccess.Run);

            var moduleBuilder = assemblyBuilder.DefineDynamicModule(name: "Module");

            var typeBuilder = moduleBuilder.DefineType(name: Fields.First(c=>c.FEILD_ID==1).ENTITIES.ENTITY_NAME, attr: TypeAttributes.Public);

            foreach (var item in Fields)
            {
                   
            }
در اینجا یک کلاس همنام با نام موجودیت ایجاد کردم و تمام فیلدهای این موجودیت را واکشی کردم حال می‌خواهم به ازای هر فیلد، یک Property ایجاد کنم. با توجه به مطلبی که در بالا فرموید اگر ما تعداد فیلدهامون از قبل مشخص بود به راحتی می‌توانستیم این کار رو انجام بدیم ولی الان که مشخص نیست چگونه می‌توانیم Property  خودمان را اضافه کنم؟
‫۱۱ سال و ۲ ماه قبل، چهارشنبه ۲۳ مرداد ۱۳۹۲، ساعت ۱۶:۲۰
امکانش هست این قسمت را بیشتر توضیح بدید چون درست مفهومش رو متوجه نشدم
و نهایتا این متدی که قرار است به صورت پویا به برنامه اضافه شود، باید در کجا قرار گیرد. برای اینکار از Module خود کلاس Program برنامه استفاده شده است.
ممنون
‫۱۱ سال و ۲ ماه قبل، چهارشنبه ۲۳ مرداد ۱۳۹۲، ساعت ۱۶:۱۵
با سلام، من زمانی که می‌خواهم از روش دوم فراخوانی متد استفاده کنم با خطای زیر مواجه می‌شوم
 var myMethod = new DynamicMethod("MyDividerMethod", returnType: typeof(int), parameterTypes: new[] { typeof(int), typeof(int) }, m: typeof(Program).Module);
            var il = myMethod.GetILGenerator();
            il.Emit(opcode:OpCodes.Ldarg_0);
            il.Emit(opcode:OpCodes.Ldarg_1);
            il.Emit(opcode:OpCodes.Add);
            il.Emit(opcode:OpCodes.Ret);

            var result = myMethod.Invoke(obj: null,parameters: new object[] { 10, 2 });
            Console.WriteLine(result);
            Console.ReadKey();

            var method = (DividerDelegate)myMethod.CreateDelegate(delegateType: typeof(DividerDelegate));
            Console.WriteLine(method(10, 2));

خطا


‫۱۱ سال و ۲ ماه قبل، چهارشنبه ۲۳ مرداد ۱۳۹۲، ساعت ۰۰:۳۶
زمانیکه یک کلاس همراه با یه سری  property با استفاده از Reflection.Emit  ایجاد کنیم آیا امکانش هست که از این کلاس یک نمونه ایجاد کنیم و به property ‌های آن مقدار بدیم؟ ممنون میشم راهنمایی کنید