في Go، عند التعامل مع واجهات متعددة بنفس توقيع الطريقة ولكن تم تعريفها في حزم منفصلة، قد تنشأ مواقف حيث النوع الذي ينفذ كلتا الواجهتين يؤدي إلى سلوك غير متوقع.
ضع في اعتبارك هاتين الواجهتين (الفاعل) والوظائف (FuncA و FuncB) المحددة في حزم مختلفة:
// Package A
type Doer interface { Do() string }
func FuncA(doer Doer)
// Package B
type Doer interface { Do() string }
func FuncB(doer Doer)
إذا كان النوع C ينفذ الفاعل من كلتا الحزمتين ويختلف التنفيذ:
// Package main
type C int
func (c C) Do() string { return "A-specific implementation" }
func main() {
cA := C(0); A.FuncA(cA)
cB := C(0); B.FuncB(cB) // Behavior differs due to varying `Do()` implementations
}
لمعالجة هذه المشكلة، يؤكد نظام الكتابة الخاص بـ Go على المطابقة حسب الاسم والاتساق في الأنواع. على الرغم من أنها تسمح للكائن بتلبية واجهات متعددة، إلا أن تنفيذ الطريقة المشتركة يجب أن يلتزم بجميع عقود الواجهة المعمول بها.
في السيناريو أعلاه، يتضمن الحل البديل تنفيذ أنواع الغلاف:
// Package main
type DoerA struct { C C }
func (d DoerA) Do() string { return "A-specific implementation" }
type DoerB struct { C C }
func (d DoerB) Do() string { return "B-specific implementation" }
func main() {
cA := DoerA{C(0)}; A.FuncA(cA)
cB := DoerB{C(0)}; B.FuncB(cB) // Correct behavior with separate implementations
}
من خلال إنشاء هذه الأغلفة، يمكنك التحكم في تنفيذ Do() بناءً على استخدام الواجهة المقصودة، مما يضمن الاتساق داخل سياقات الحزمة المعنية.
تنصل: جميع الموارد المقدمة هي جزئيًا من الإنترنت. إذا كان هناك أي انتهاك لحقوق الطبع والنشر الخاصة بك أو الحقوق والمصالح الأخرى، فيرجى توضيح الأسباب التفصيلية وتقديم دليل على حقوق الطبع والنشر أو الحقوق والمصالح ثم إرسالها إلى البريد الإلكتروني: [email protected]. سوف نتعامل مع الأمر لك في أقرب وقت ممكن.
Copyright© 2022 湘ICP备2022001581号-3