model层不允许使用 json,构体格式 dto层又重复造轮子,问题一个表的中结字段可能20个左右,那么赋值语句难受死了。构体格式

其次就是问题json直接解析,model层的中结time.Time,完蛋格式不对,构体格式返回的问题数据不对。
比如
{ "user_name": "xiaoli",中结 "create_time": "2020-06-05T13:53:06.293614+08:00" }这种情况,无法解决,构体格式就需要必须重写一个dto。问题
那么如何解决这个问题呢,中结本人思考了一段时间,构体格式最终使用Map来解决。问题
那么反射会遇到,各种奇葩的书写方式,有些人什么都出传入指针,有些人各种interface{} 隐藏转换,反正就是太过于差异化。
所以就是需要解决,如何准确的拿到Value对象,下面是我写的一个工具类
func GetRealValue(value reflect.Value) reflect.Value { kind := value.Kind() if kind == reflect.Ptr { return GetRealValue(value.Elem()) } if kind == reflect.Interface { // eg:var s2 interface{} // s2 = User{} // fmt.Println(reflect.ValueOf(&s2).Elem().Kind())// interface // 所以这里需要将它转换 if value.CanInterface() { return GetRealValue(reflect.ValueOf(value.Interface())) } return GetRealValue(value.Elem()) } return value }解决这个问题,开干
2、下划线命名法下划线如何解决,结构体的字段属于驼峰命名法,高防服务器怎么解决呢?
写了一个简单的工具类
问题:
如果是ID,连续大写,输出i_d 因为数组到切片需要拷贝一次,所以可以利用unsafe解决,因为字符串底层就是切片,但是不安全 func CamelCase(s string) string { if s == "" { return "" } t := make([]byte, 0, 32) i := 0 for ; i < len(s); i++ { c := s[i] if isASCIIDigit(c) { t = append(t, c) continue } if isASCIIUpper(c) { c ^= } t = append(t, c) for i+1 < len(s) && isASCIIUpper(s[i+1]) { i++ t = append(t, _, s[i]+32) } } //return *(*string)(unsafe.Pointer(&t)) return string(t) } func isASCIIUpper(c byte) bool { return A <= c && c <= Z } func isASCIIDigit(c byte) bool { return 0 <= c && c <= 9 }输出结果:
完美,美中不足是需要使用likedMap,由于Golang源码包没有,所以,注定乱序
{"create_time":"2020-06-05 14:05:31","user_name":"xiaoli"} 服务器托管相关文章:
相关推荐:
源码下载IT技术网服务器租用亿华云益华科技源码库IT资讯网香港云服务器企商汇码力社智能时代亿华云汇智坊全栈开发亿华科技极客码头科技前瞻益强IT技术网益华IT技术论坛益华科技益强智未来亿华智造思维库码上建站亿华灵动运维纵横益强科技益强智囊团益强科技益强数据堂云站无忧编程之道亿华互联益强编程舍创站工坊技术快报亿华智慧云益强资讯优选云智核益强编程堂益强前沿资讯
0.1286s , 11685.671875 kb
Copyright © 2025 Powered by Go开发中结构体 model、dto 、time格式问题,汇智坊 滇ICP备2023006006号-2