


Generic function for setting fields of different structures used as mapped values
php editor Strawberry will introduce to you a very practical general function, which can be used to set fields of different structures to mapped values. This function can help us be more flexible and convenient when processing data, and is no longer limited by the structure of the field. Whether it is an array, object or other data type, this function can be used to implement field mapping operations, improving our development efficiency and code maintainability. If you often need to process fields of different structures, you might as well try this general function, I believe it will bring you a lot of help!
Question content
Having a structure with common fields...
type definition struct { id string ... } type requirement struct { id string ... } type campaign struct { id string ... }
...I have multiple functions like this:
func filldefinitionids(values *map[string]definition) { for key, value:=range *values { // repeated code value.id=key // repeated code (*values)[key]=value // repeated code } // repeated code } func fillrequirementids(values *map[string]requirement) { for key, value:=range *values { // repeated code value.id=key // repeated code (*values)[key]=value // repeated code } // repeated code } func fillcampaignids(values *map[string]campaign) { for key, value:=range *values { // repeated code value.id=key // repeated code (*values)[key]=value // repeated code } // repeated code }
I want a single function that generalizes access with generics (or interfaces, etc.), kind of...
func fillIds[T Definition|Requirement|Campaign](values *map[string]T) { for key, value:=range *values { value.Id=key (*values)[key]=value } }
Of course, this results in value.id being undefined (type t has no field or method id)
. I've been able to overcome similar problems many times, but this time I can't find a solution.
How to abstract this set of functions into one function?
Solution
type definition struct { id string } type requirement struct { id string } type campaign struct { id string } func (v definition) withid(id string) definition { v.id = id; return v } func (v requirement) withid(id string) requirement { v.id = id; return v } func (v campaign) withid(id string) campaign { v.id = id; return v }
type withid[t any] interface { withid(id string) t } func fillids[t withid[t]](values map[string]t) { for key, value := range values { values[key] = value.withid(key) } }
func main() { m1 := map[string]definition{"foo": {}, "bar": {}} fillids(m1) fmt.println(m1) m2 := map[string]campaign{"abc": {}, "def": {}} fillids(m2) fmt.println(m2) }
https://www.php.cn/link/0db32de7aed05af092becfc3789e7700
An alternative to @blackgreen's answer if you need to use value mapping.
type common struct { id string } func (v *common) setid(id string) { v.id = id } type definition struct { common } type requirement struct { common } type campaign struct { common }
type idsetter[t any] interface { *t setid(id string) } func fillids[t any, u idsetter[t]](values map[string]t) { for key, value := range values { u(&value).setid(key) values[key] = value } }
func main() { m1 := map[string]definition{"foo": {}, "bar": {}} fillids(m1) fmt.println(m1) m2 := map[string]campaign{"abc": {}, "def": {}} fillids(m2) fmt.println(m2) }
https://www.php.cn/link/fec3392b0dc073244d38eba1feb8e6b7
The above is the detailed content of Generic function for setting fields of different structures used as mapped values. For more information, please follow other related articles on the PHP Chinese website!

ThebytespackageinGoisessentialformanipulatingbytesliceseffectively.1)Usebytes.Jointoconcatenateslices.2)Employbytes.Bufferfordynamicdataconstruction.3)UtilizeIndexandContainsforsearching.4)ApplyReplaceandTrimformodifications.5)Usebytes.Splitforeffici

Tousethe"encoding/binary"packageinGoforencodinganddecodingbinarydata,followthesesteps:1)Importthepackageandcreateabuffer.2)Usebinary.Writetoencodedataintothebuffer,specifyingtheendianness.3)Usebinary.Readtodecodedatafromthebuffer,againspeci

The encoding/binary package provides a unified way to process binary data. 1) Use binary.Write and binary.Read functions to encode and decode various data types such as integers and floating point numbers. 2) Custom types can be handled by implementing the binary.ByteOrder interface. 3) Pay attention to endianness selection, data alignment and error handling to ensure the correctness and efficiency of the data.

Go's strings package is not suitable for all use cases. It works for most common string operations, but third-party libraries may be required for complex NLP tasks, regular expression matching, and specific format parsing.

The strings package in Go has performance and memory usage limitations when handling large numbers of string operations. 1) Performance issues: For example, strings.Replace and strings.ReplaceAll are less efficient when dealing with large-scale string replacements. 2) Memory usage: Since the string is immutable, new objects will be generated every operation, resulting in an increase in memory consumption. 3) Unicode processing: It is not flexible enough when handling complex Unicode rules, and may require the help of other packages or libraries.

Mastering the strings package in Go language can improve text processing capabilities and development efficiency. 1) Use the Contains function to check substrings, 2) Use the Index function to find the substring position, 3) Join function efficiently splice string slices, 4) Replace function to replace substrings. Be careful to avoid common errors, such as not checking for empty strings and large string operation performance issues.

You should care about the strings package in Go because it simplifies string manipulation and makes the code clearer and more efficient. 1) Use strings.Join to efficiently splice strings; 2) Use strings.Fields to divide strings by blank characters; 3) Find substring positions through strings.Index and strings.LastIndex; 4) Use strings.ReplaceAll to replace strings; 5) Use strings.Builder to efficiently splice strings; 6) Always verify input to avoid unexpected results.

ThestringspackageinGoisessentialforefficientstringmanipulation.1)Itofferssimpleyetpowerfulfunctionsfortaskslikecheckingsubstringsandjoiningstrings.2)IthandlesUnicodewell,withfunctionslikestrings.Fieldsforwhitespace-separatedvalues.3)Forperformance,st


Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

Video Face Swap
Swap faces in any video effortlessly with our completely free AI face swap tool!

Hot Article

Hot Tools

ZendStudio 13.5.1 Mac
Powerful PHP integrated development environment

SecLists
SecLists is the ultimate security tester's companion. It is a collection of various types of lists that are frequently used during security assessments, all in one place. SecLists helps make security testing more efficient and productive by conveniently providing all the lists a security tester might need. List types include usernames, passwords, URLs, fuzzing payloads, sensitive data patterns, web shells, and more. The tester can simply pull this repository onto a new test machine and he will have access to every type of list he needs.

Atom editor mac version download
The most popular open source editor

MinGW - Minimalist GNU for Windows
This project is in the process of being migrated to osdn.net/projects/mingw, you can continue to follow us there. MinGW: A native Windows port of the GNU Compiler Collection (GCC), freely distributable import libraries and header files for building native Windows applications; includes extensions to the MSVC runtime to support C99 functionality. All MinGW software can run on 64-bit Windows platforms.

MantisBT
Mantis is an easy-to-deploy web-based defect tracking tool designed to aid in product defect tracking. It requires PHP, MySQL and a web server. Check out our demo and hosting services.
