- r - 以节省内存的方式增长 data.frame
- ruby-on-rails - ruby/ruby on rails 内存泄漏检测
- android - 无法解析导入android.support.v7.app
- UNIX 域套接字与共享内存(映射文件)
我正在使用 gob 将结构序列化到磁盘。所讨论的结构包含一个接口(interface)字段,因此需要使用 gob.Register(...)
注册具体类型。
这里的问题是执行 gob-ing 的库应该不知道正在使用的具体类型。我希望即使调用者定义了他们自己的接口(interface)实现也可以进行序列化。
我可以通过动态注册类型成功地对数据进行编码(参见下面的简单示例),但是在尝试重新读取该数据时,gob 拒绝接受未注册的类型。这令人沮丧,因为感觉所有数据都在那里 - 为什么 gob 不将其解包为 main.UpperCaseTransformation
结构,如果它被标记为这样?
package main
import (
"encoding/gob"
"fmt"
"os"
"strings"
)
type Transformation interface {
Transform(s string) string
}
type TextTransformation struct {
BaseString string
Transformation Transformation
}
type UpperCaseTransformation struct{}
func (UpperCaseTransformation) Transform(s string) string {
return strings.ToUpper(s)
}
func panicOnError(err error) {
if err != nil {
panic(err)
}
}
// Execute this twice to see the problem (it will tidy up files)
func main() {
file := os.TempDir() + "/so-example"
if _, err := os.Stat(file); os.IsNotExist(err) {
tt := TextTransformation{"Hello, World!", UpperCaseTransformation{}}
// Note: didn't need to refer to concrete type explicitly
gob.Register(tt.Transformation)
f, err := os.Create(file)
panicOnError(err)
defer f.Close()
enc := gob.NewEncoder(f)
err = enc.Encode(tt)
panicOnError(err)
fmt.Println("Run complete, run again for error.")
} else {
f, err := os.Open(file)
panicOnError(err)
defer os.Remove(f.Name())
defer f.Close()
var newTT TextTransformation
dec := gob.NewDecoder(f)
// Errors with: `gob: name not registered for interface: "main.UpperCaseTransformation"'
err = dec.Decode(&newTT)
panicOnError(err)
}
}
我的解决方法是要求接口(interface)的实现者向 gob 注册他们的类型。但我不喜欢这样向调用者揭示我的序列化选择。
是否有任何前进路线可以避免这种情况?
最佳答案
encoding/gob
包不能(或者更确切地说不应该)自己做出决定。由于 gob
包创建了一个独立于应用程序/从应用程序分离的序列化形式,因此无法保证接口(interface)类型的值将存在于解码器中;即使它们这样做(通过具体类型名称匹配),也不能保证它们表示相同的类型(或给定类型的相同实现)。
调用 gob.Register()
(或 gob.RegisterName()
)你明确了 intent ,你给 gob
包开了绿灯以使用该类型。这也确保类型确实存在,否则您将无法在注册时传递它的值。
还有一个技术观点规定了此要求(您必须事先注册):您无法获得 reflect.Type
。由其 string
名称给出的类型的类型描述符。不只是你,encoding/gob
包也做不到。
因此,通过要求您事先调用 gob.Register()
,gob
包将接收到相关类型的值,因此它可以(而且它将) 在内部访问并存储其 reflect.Type
描述符,因此当检测到这种类型的值时,它能够按顺序创建这种类型的新值(例如使用 reflect.New()
)将正在解码的值存储到其中。
您不能按名称“查找”类型的原因是除非您明确引用它们,否则它们可能不会出现在您的二进制文件中(它们可能会被“优化掉”)。详情见Call all functions with special prefix or suffix in Golang ;和 Splitting client/server code .注册您的自定义类型(通过传递它们的值)时,您正在对它们进行显式引用,从而确保它们不会被排除在二进制文件之外。
关于go - 在不知 Prop 体类型的情况下解码 gob 输出,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/47071276/
我仍在学习如何将 API 数据与 react 和 nextjs 一起使用。但是,为什么我的函数只在我编写 {props.props.title} 而不是我期望的 {props.title} 时起作用?
我仍在学习如何将 API 数据与 react 和 nextjs 一起使用。但是,为什么我的函数只在我编写 {props.props.title} 而不是我期望的 {props.title} 时起作用?
我正在用 TypeScript 构建一个 React 应用程序。我有一个 RequiresPermission基于谓词的组件应该渲染一个或另一个组件并转发所有 Prop 。 type Props =
我想通过 gatsby 布局传递我所有的 props。例如: import React, { Component } from 'react'; export default class Exampl
如果我使用合成属性,那我为什么不直接说: self.property = nil; 这将释放引用计数,并确保我没有悬挂指针。 看起来很简单,但我看到的 99% 的代码似乎都是这样做的: [proper
Eslint 抛出 eslint(react/prop-types) 错误,尽管已经声明了 propTypes。我正在使用 eslint-plugin-react 我研究了其他几个类似的问题以及 li
我正在使用以下由 linter eslint-plugin-react 解析的代码。它返回警告: "product is missing in props validation" 当我在底部的 pro
我正在尝试在 React 应用程序中添加 TypeScript。 版本: "react": "16.9.0", "typescript": "3.5.3", 我有一个像这样的数组 import aLo
我有一个组件 . 如果组件没有 this.props.children , 我想设置 Prop ariaLabel作为isRequired ,否则 in 可以是可选的。我该怎么做? ariaLabe
我应该用一个代替另一个吗?一起使用它们更好吗?谢谢。 最佳答案 prop in obj 检查 obj 是否有名为 prop 的属性,即使它只是从原型(prototype)继承而来。 obj.hasOw
我的组件 Text有 2 个 Prop :isHideable: boolean和 hidden: boolean .我如何允许 Hidden仅在 isHideable 时作为 Prop 是true
我试图将带有一些 Prop 的功能组件发送到另一个组件,并在接收组件中尝试键入检查该组件的某些 Prop 。这是代码: // BaseButton.tsx export type ButtonProp
是否可以从也作为 prop 传递的未知组件推断出正确的 props 类型? 如果已知组件(存在于当前文件中),我可以获得 Prop : type ButtonProps = React.Compone
我对 react 还很陌生,这是我正在努力解决的问题。 有一个父组件 家长 它将 Prop 传递给 child 。 其中一个 Prop ,包括一个要渲染的元素,如下所示: 在子组件中,我想获取这个组
我想做一个 Tabs推断 active 的可能值的组件prop 基于它的 child 拥有的东西 name Prop 。这就是我尝试这样做的方式: import React from 'react'
我对 react 还很陌生,并且只有当用户开始向下滚动时,我才尝试将更多信息加载到记录数组中。问题是新信息出现在数组中,但如果您尝试调用它,它将返回undefined。我在这里不明白什么? 父组件:
因此,如果我对一个组件有很多不同的 Prop ,我希望我可以做类似的事情 const { ...props } = props; 而不是 const { prop1, prop2, prop3, ..
这是我寻求指导的问题类型,因为我不确定我正在寻找的内容是否存在...... 上下文:我正在使用 Firestore 来保存数据,并且正在构建一个可重用的自定义 Hook (React 16.8),以便
我有一个 React 组件,它获取一个配置对象作为 prop,它看起来像这样: { active: true, foo: { bar: 'baz' } } 在
如何附加另一个属性?我有一个 react 组件,其中有人传入 ...props,我想附加一个额外的 Prop 最佳答案 请记住,传递 Prop 的顺序将决定将哪个值传递给该组件。这适用于有两个同名
我是一名优秀的程序员,十分优秀!