مصفوفة ديناميكيةالمصفوفات الديناميكية أو المصفوفة الحيوية (بالإنجلزية: dynamic array) هي نوع خاص من البايانات في لغات البرمجة [1] ، تحتوي على عدد متغير من العناصر مرتبة بشكل أعمدة وحقول متعدد الأبعاد. كل العناصر لديها نفس النوع [2]، ويسمى «النوع الداخلي» للمجموعة، على عكس المصفوفة الثابتة التي يحدد حجمها ونوع العنصر في وقت البرمجة، المصفوفة الديناميكية يحدد نوع العنصر فقط، ويتم تغيير سعة الإستيعاب في وقت التنفيذ. لا يقصد بالمصفوفة الديناميكية حجم أو قيمة العنصر ولا عدد العناصر بل بالاستعاب الأقصى لعدد العناصر. في المصفوفة ديناميكية، الطول الأولي للمجموعة هو صفر. يجب تعيين طول الفعلي للمجموعة بستخدام وظيفة توفرها لغة البرمجة، والتي ستقوم بحجز الذاكرة اللازمة لتخزين عناصر المصفوفة. قد يتم الحجز في نفس المكان أو قد يتم نقل كل المصفوفة إلى منطقة جديدة في الذاكرة ونقل قيم العناصر فيها ويسمى «النسخ المتماثل» وهي عملية للحفاظ على قيمة ومكان كل عنصر من المجموعة داخل المصفوفة. طريقة العملالعملية يتحكم فيها عدة عوامل منها لغة البرمجة أو حجم العنصر في المصفوفة أو مكان التواجد في الذاكرة. يتم تخصيص ذاكرة ديناميكية بواسطة طلب كومة من الذاكرة، ذاكرة الكمبيوتر محدود ويمكن أن تستنفد. فلا توجد ضمانات بأن جميع طلبات تخصيص الذاكرة تمنح من قبل النظام. في الكثير من لغات البرمجة اسم المصفوفه هو مؤشر يشير إلى أول عنصر من عناصر المصفوفه[3] بمعنى أن الاسم هو مكان يحجز في الذاكرة يحتوى على عنوان أول عنصر فيها، ويمكن استخدام اسم المصفوفه كمؤشر تجرى عليه العمليات الخاصة بالمؤشرات. اما بالنسبة لخطوات تحجيم المصفوفة تكون كالتالي:
من الناحية الفنية هناك حالات يمكن أن تغير من الخطوات:
الأداء
للحصول على أداء سريع في البرامج، فإنه من المهم فهم الآثار المترتبة على خطوة ملئ المجموعة الجديدة بقيمة افتراضية وعملية نسخ العناصر. كلما قمت بتغيير حجم المصفوفة الديناميكية [4]، سيتم نسخ مجموعة، وهو ما يعني بالتكرار الحجز والتحرير في الذاكرة، سيأخذ هذا وقت يتناسب مع حجم [5] المصفوفة، فكلما زاد حجم المصفوفة زاد الوقت المطلوب لتغيير الحجم. المصفوفة الديناميكية تمتلك العديد من المزايا عن المصفوفة العادية، في استخدام ذاكرة التخزين المؤقت للبيانات، الاكتناز (استخدام ذاكرة منخفضة)، والوصول العشوائي.. هذا يجعل المصفوفات الحيوية أداة جذابة لبناء هياكل البيانات سهلة في ذاكرة التخزين المؤقت. ومع ذلك، في لغات مثل بايثون أو جافا[6] التي تفرض دلالات مرجعية، المصفوفة الديناميكية عموما لن تخزن البيانات فعليا، بل سيتم تخزين المؤشر إلى العنصر المتواجد في مناطق أخرى من الذاكرة. في هذه الحالة، سوف لن تترتب العناصر بشكل متجاور في الذاكرة، ويتم فقدان العديد من المزايا من تخص ذاكرة التخزين المؤقت. مراجع
|