


Cara terbaik untuk mengendalikan penyahgandingan dalam Go ialah menggunakan dua pakej berbeza dengan struktur yang serupa tetapi kanak-kanak berbeza. Pendekatan ini memisahkan kod secara berkesan, meningkatkan kebolehselenggaraan dan modulariti. Walau bagaimanapun, pendekatan penyahgandingan ini boleh menjadi sukar apabila sub-item dalam struktur menjadi kompleks. Dalam kes ini, pertimbangkan untuk menggunakan konsep antara muka dan polimorfisme untuk menyelesaikan masalah. Dengan mentakrifkan jenis antara muka biasa, jenis struktur yang berbeza boleh diproses secara seragam, dengan itu mencapai kaedah penyahgandingan yang lebih fleksibel. Pendekatan ini digunakan secara meluas dalam Go untuk menjadikan kod lebih boleh dikembangkan dan boleh digunakan semula.
Kandungan soalan
Saya agak baru dalam hal ini dan telah melakukan penulisan semula secara besar-besaran cuba mengurangkan graf pergantungan saya sebanyak mungkin. Saya sangat gembira dengan mana saya mendapatnya, tetapi ada satu bahagian yang saya tidak tahu cara terbaik untuk mengendalikannya. Jika jawapannya ialah "akan ada pergantungan ini antara kedua-duanya" itu juga tidak mengapa, saya hanya mencari pendekatan yang baik daripada mengharapkan keajaiban.
Jadi di bawah saya ada dua pakej, a
和 b
, dan kedua-duanya mempunyai struktur yang sama. Biasanya anda boleh menukar satu kepada yang lain dalam main , tetapi masing-masing mempunyai anak yang juga merupakan struct, yang menghalang go daripada membenarkannya, walaupun jika kanak-kanak mempunyai tandatangan yang sama.
Salah satu cara adalah dengan merujuk a.tzconfig dalam struktur b dan biarkan ia mempunyai kebergantungan, tetapi itulah yang saya ingin singkirkan.
Saya rasa cara lain ialah mencipta antara muka dan kemudian mendapatkan nilai loc melalui kaedah, saya rasa ini akan berfungsi tetapi saya belum mencubanya kerana ini bermakna mencipta kaedah untuk sesuatu yang hanya struktur data (the struktur sebenar mempunyai banyak item, yang telah saya kurangkan di sini kepada yang penting demi kesederhanaan), yang nampaknya agak berlebihan.
Saya boleh mengalihkan tzconfig ke modul ketiga supaya kedua-duanya merujuk modul itu dan bukannya merujuk yang lain, itulah yang saya hasilkan.
Jadi soalan saya ialah, daripada seseorang yang berpengalaman sebenar, apakah cara terbaik untuk menangani situasi ini semasa dalam perjalanan?
Saya harus menyebut bahawa sebab mereka menduplikasi struct adalah hanya kerana saya cuba memecahkan pergantungan antara mereka, kod asal hanya mempunyai struct dalam satu pakej dan pakej lain merujuknya.
package a type cfg struct { addr string loc tzconfig } type tzconfig struct { string string tz *time.location `validate:"nodescent"` } func getcfg() cfg { t, _ := time.loadlocation(`mst`) return cfg{ addr: "abc", host: "a.bc.d", loc: config.tzconfig{ string: "mst", tz: t, }, } }
package b type cfg struct { addr string loc tzconfig } type tzconfig struct { string string tz *time.location `validate:"nodescent"` } func dosomethingwithconfig(c cfg) { fmt.println(c) }
package main main() { c := a.GetCfg() d := b.DoSomethingWithConfig(b.Cg(c)) fmt.Println(d) }
Solution
IMHO nasihat yang diberikan oleh @burakserdar sangat bagus dan sangat sesuai untuk senario anda. Saya menulis semula kod dengan cara ini.
package common
package common import "time" type cfg struct { addr string loc tzconfig } type tzconfig struct { string string tz *time.location `validate:"nodescent"` }
Struktur, fungsi, kaedah dan lain-lain yang biasa digunakan hendaklah diletakkan di sini.
package a
package a import ( "dependencies/common" "time" ) type cfg struct { common.cfg host string } func getcfg() cfg { t, _ := time.loadlocation(`mst`) return cfg{ cfg: common.cfg{ addr: "abc", loc: common.tzconfig{ string: "mst", tz: t, }, }, host: "a.bc.d", } }
Di sini ditunjukkan dengan bahagian a
包相关的特定代码,它继承了 common
包的共享代码,如 import
.
Sila ambil perhatian bahawa saya menggunakan ciri pembenaman struktur untuk mendapatkan medan kongsi yang ditakrifkan dalam pakej common
.
package b
package b import ( "dependencies/common" "fmt" ) func dosomethingwithconfig(c common.cfg) string { return fmt.sprint(c) }
Tiada apa-apa yang patut disebut di sini.
package main
package main import ( "dependencies/a" "dependencies/b" "fmt" ) func main() { c := a.GetCfg() d := b.DoSomethingWithConfig(c.Cfg) fmt.Println(d) }
Di sini, kodnya mestilah sangat mudah. Saya mengimport pakej a
和 b
untuk memanfaatkan fungsinya.
Saya ingin menjelaskan sekali lagi bahawa ini adalah topik subjektif jadi tiada penyelesaian peluru ajaib. Bagi saya, ia kelihatan kemas dan jelas. Saya pasti akan memilih pendekatan ini. Tolong beritahu saya dan terima kasih!
Atas ialah kandungan terperinci Cara terbaik untuk mengendalikan penyahgandingan dalam Go ialah menggunakan struktur yang serupa dalam dua pakej berbeza, tetapi kanak-kanak dalam struktur menyukarkannya?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Goisidealforbuildingscalablesystemsduetoitssimplicity, ecurciency, dan barangan-inconcurrencysupport.1) go'ScleansyntaxandminimalisticdesignenhanceProductivityandreduceerrors.2)

InitFunctionsingorunautomaticallybeforemain () andareuseforforsettingupenvironmentsandinitializingvariables.usethemforsimpletasks, mengelakkansidefefects, andbecautiouswithtestingandloggingtomaintaincodeclarityAndestability.

GoinitializespackagesintheordertheyareImported, thenexecutesinitfunctionswithinapackageintheirdefinitionorder, danfilenamesdeterminetheorderacrossmultiplefiles

CustomInterfacesingoarecrucialForWritingFlexible, diselenggara, danTestableCode.theYenabledEveloperStofocusonbehavioroverImplementation, enhancingmodularityandrobustness.bydefiningmethodsignaturesthattypesmustimplement, interfacesallowforcorcodforcodforcodforcodforcodforcodforcodforcodeShorcodeShorcodforcodforcodeShorcodeShorcodeShorcodeShorcodeShorcodeAdeShorcodeShorcodeSoUsVorcoShorcodeS

Alasan untuk menggunakan antara muka untuk simulasi dan ujian adalah bahawa antara muka membolehkan definisi kontrak tanpa menentukan pelaksanaan, menjadikan ujian lebih terpencil dan mudah dikekalkan. 1) Pelaksanaan antara muka yang tersirat menjadikannya mudah untuk membuat objek mengejek, yang dapat menggantikan pelaksanaan sebenar dalam ujian. 2) Menggunakan antara muka dengan mudah boleh menggantikan pelaksanaan sebenar perkhidmatan dalam ujian unit, mengurangkan kerumitan ujian dan masa. 3) Fleksibiliti yang disediakan oleh antara muka membolehkan perubahan dalam tingkah laku simulasi untuk kes ujian yang berbeza. 4) Antara muka membantu reka bentuk kod yang boleh diuji dari awal, meningkatkan modulariti dan mengekalkan kod.

Di GO, fungsi INIT digunakan untuk permulaan pakej. 1) Fungsi init secara automatik dipanggil apabila permulaan pakej, dan sesuai untuk memulakan pembolehubah global, menetapkan sambungan dan memuatkan fail konfigurasi. 2) Terdapat pelbagai fungsi init yang boleh dilaksanakan dalam urutan fail. 3) Apabila menggunakannya, perintah pelaksanaan, kesukaran ujian dan kesan prestasi harus dipertimbangkan. 4) Adalah disyorkan untuk mengurangkan kesan sampingan, menggunakan suntikan ketergantungan dan penangguhan permulaan untuk mengoptimumkan penggunaan fungsi INIT.

Go'sSelectStatementStreamLinesConcurrentProgrammingByMultiPlexingOperations.1) itAllowSwaitingonMultiPlechannoPerations,

ContextandWaitGroupSarecrucialingingoformanagingGoroutinesfectively.1) ContextAllowsSignalingCancellationandDeadlinesacrosapiboundaries, memastikangoroutinescanbestplygracely.2) WaitgroupSsynchronizegoroutine, Mempersembahkan CreationAllcebeBefefeSproprophering, Preveation


Alat AI Hot

Undresser.AI Undress
Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover
Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool
Gambar buka pakaian secara percuma

Clothoff.io
Penyingkiran pakaian AI

Video Face Swap
Tukar muka dalam mana-mana video dengan mudah menggunakan alat tukar muka AI percuma kami!

Artikel Panas

Alat panas

PhpStorm versi Mac
Alat pembangunan bersepadu PHP profesional terkini (2018.2.1).

Muat turun versi mac editor Atom
Editor sumber terbuka yang paling popular

Versi Mac WebStorm
Alat pembangunan JavaScript yang berguna

SecLists
SecLists ialah rakan penguji keselamatan muktamad. Ia ialah koleksi pelbagai jenis senarai yang kerap digunakan semasa penilaian keselamatan, semuanya di satu tempat. SecLists membantu menjadikan ujian keselamatan lebih cekap dan produktif dengan menyediakan semua senarai yang mungkin diperlukan oleh penguji keselamatan dengan mudah. Jenis senarai termasuk nama pengguna, kata laluan, URL, muatan kabur, corak data sensitif, cangkerang web dan banyak lagi. Penguji hanya boleh menarik repositori ini ke mesin ujian baharu dan dia akan mempunyai akses kepada setiap jenis senarai yang dia perlukan.

EditPlus versi Cina retak
Saiz kecil, penyerlahan sintaks, tidak menyokong fungsi gesaan kod
