আমি ভেবেছিলাম আমি মার্তিজানের উত্তর এবং সাইক এর উত্তরের তুলনা করব ...
নিম্নলিখিত প্রোগ্রামটি নিম্নলিখিত ফলাফলগুলি প্রদান করে:
Testing with exception: 2430985 ticks
Testing with reflection: 155570 ticks
void Main()
{
var random = new Random(Environment.TickCount);
dynamic test = new Test();
var sw = new Stopwatch();
sw.Start();
for (int i = 0; i < 100000; i++)
{
TestWithException(test, FlipCoin(random));
}
sw.Stop();
Console.WriteLine("Testing with exception: " + sw.ElapsedTicks.ToString() + " ticks");
sw.Restart();
for (int i = 0; i < 100000; i++)
{
TestWithReflection(test, FlipCoin(random));
}
sw.Stop();
Console.WriteLine("Testing with reflection: " + sw.ElapsedTicks.ToString() + " ticks");
}
class Test
{
public bool Exists { get { return true; } }
}
bool FlipCoin(Random random)
{
return random.Next(2) == 0;
}
bool TestWithException(dynamic d, bool useExisting)
{
try
{
bool result = useExisting ? d.Exists : d.DoesntExist;
return true;
}
catch (Exception)
{
return false;
}
}
bool TestWithReflection(dynamic d, bool useExisting)
{
Type type = d.GetType();
return type.GetProperties().Any(p => p.Name.Equals(useExisting ? "Exists" : "DoesntExist"));
}
ফলস্বরূপ আমি প্রতিবিম্বটি ব্যবহার করার পরামর্শ দেব। নিচে দেখ.
বেল্যান্ডের মন্তব্যের প্রতিক্রিয়া:
অনুপাতগুলি reflection:exception
100000 পুনরাবৃত্তির জন্য টিক্স:
Fails 1/1: - 1:43 ticks
Fails 1/2: - 1:22 ticks
Fails 1/3: - 1:14 ticks
Fails 1/5: - 1:9 ticks
Fails 1/7: - 1:7 ticks
Fails 1/13: - 1:4 ticks
Fails 1/17: - 1:3 ticks
Fails 1/23: - 1:2 ticks
...
Fails 1/43: - 1:2 ticks
Fails 1/47: - 1:1 ticks
... যথেষ্ট ন্যায্য - যদি আপনি এটির সম্ভাব্যতা ~ 1/47 এর চেয়ে কম ব্যর্থ হওয়ার প্রত্যাশা করেন তবে ব্যতিক্রম হিসাবে যান।
উপরেরগুলি ধরে নিয়েছে যে আপনি GetProperties()
প্রতিবারের মতো চালাচ্ছেন । আপনি GetProperties()
কোনও অভিধানে বা অনুরূপ প্রতিটি ধরণের ফলাফলের ক্যাচ করে প্রক্রিয়াটি দ্রুত করতে সক্ষম হতে পারেন । আপনি যদি একই ধরণের বার বার পরীক্ষা করে দেখেন তবে এটি সহায়তা করতে পারে।