草庐IT

cast_sender

全部标签

interface - Golang : Can I cast to chan interface{}

我正在尝试为订阅编写一个通用包装器,例如:typeSubscriberinterface{Subscribe(addrstring)chaninterface{}}假设我想使用一个库,其中有一个订阅方法,但它使用chanlibrary.Object。我希望能够做类似的事情:func(s*mySubscriber)Subscribe(addrstring)chaninterface{}{ch:=make(chanlibrary.Object)library.Subscribe(addr,ch)returnchaninterface{}(ch)}目前,我认为这样的Actor阵容是不可能的。

Golang : cast an interface to a typed variable dynamically

在go中,是否可以以某种方式动态转换变量?例如,如果一个简单的Actor是:varintAge=interfaceAge.(int)如果我事先不知道年龄是一个整数怎么办?一个简单的写法是varx=getType()varsomeTypeAge=interfaceAge(.x)有没有办法实现这样的目标?reflect包提供了一些在运行时确定或强制转换类型的方法-但我找不到像上面提到的任何东西(适用于所有类型的通用方案)。 最佳答案 不,你不能。Go是一种静态类型语言。变量的类型是在编译时确定的。如果您想动态确定interface{}的

Golang : cast an interface to a typed variable dynamically

在go中,是否可以以某种方式动态转换变量?例如,如果一个简单的Actor是:varintAge=interfaceAge.(int)如果我事先不知道年龄是一个整数怎么办?一个简单的写法是varx=getType()varsomeTypeAge=interfaceAge(.x)有没有办法实现这样的目标?reflect包提供了一些在运行时确定或强制转换类型的方法-但我找不到像上面提到的任何东西(适用于所有类型的通用方案)。 最佳答案 不,你不能。Go是一种静态类型语言。变量的类型是在编译时确定的。如果您想动态确定interface{}的

casting - Go:在类型开关中将任何 int 值转换为 int64

我经常遇到这样的情况,我期望int(任何类型,int/int8/16/32/64)并使用类型开关检查它switcht:=v.(type){caseint,int8,int16,int32,int64://casttoint64caseuint,uint8,uint16,uint32,uint64://casttouint64}现在我不能使用直接转换,因为t在这种情况下,类型为interface{}.我真的必须把它分成case吗?s每个整数类型?我知道我可以使用reflect.ValueOf(v).Int()通过反射来做到这一点,但不应该有更好(不那么冗长)的方法吗?更新:提交了一个问题

casting - Go:在类型开关中将任何 int 值转换为 int64

我经常遇到这样的情况,我期望int(任何类型,int/int8/16/32/64)并使用类型开关检查它switcht:=v.(type){caseint,int8,int16,int32,int64://casttoint64caseuint,uint8,uint16,uint32,uint64://casttouint64}现在我不能使用直接转换,因为t在这种情况下,类型为interface{}.我真的必须把它分成case吗?s每个整数类型?我知道我可以使用reflect.ValueOf(v).Int()通过反射来做到这一点,但不应该有更好(不那么冗长)的方法吗?更新:提交了一个问题

c++ - 在 64 位机器上编译 32 位代码时,我应该如何处理 "cast from ‘void*’ 到 ‘int’ 丢失精度?

我有一个可以在32位机器上编译并正常工作的包。我现在正在尝试让它在64位机器上编译并发现以下错误-error:castfrom‘void*’to‘int’losesprecision是否有一个编译器标志来抑制这些错误?还是我必须手动编辑这些文件以避免这些强制转换? 最佳答案 问题在于,在32位中,int(它是一个32位整数)将保存一个指针值。当您移至64位时,您不能再将指针存储在int中-它不足以容纳64位指针。intptr_ttype就是为此而设计的。 关于c++-在64位机器上编译3

c++ - 在 64 位机器上编译 32 位代码时,我应该如何处理 "cast from ‘void*’ 到 ‘int’ 丢失精度?

我有一个可以在32位机器上编译并正常工作的包。我现在正在尝试让它在64位机器上编译并发现以下错误-error:castfrom‘void*’to‘int’losesprecision是否有一个编译器标志来抑制这些错误?还是我必须手动编辑这些文件以避免这些强制转换? 最佳答案 问题在于,在32位中,int(它是一个32位整数)将保存一个指针值。当您移至64位时,您不能再将指针存储在int中-它不足以容纳64位指针。intptr_ttype就是为此而设计的。 关于c++-在64位机器上编译3

c++ - const_cast 安全吗?

我在const_cast上找不到太多信息.我能找到的唯一信息(在StackOverflow上)是:Theconst_cast()isusedtoadd/removeconst(ness)(orvolatile-ness)ofavariable.这让我很紧张。可以使用const_cast导致意外行为?如果有,是什么?或者,什么时候可以使用const_cast? 最佳答案 const_cast仅当您正在转换最初不是const的变量时才是安全的.例如,如果您有一个函数,其参数为constchar*,你传入一个可修改的char*,const

c++ - const_cast 安全吗?

我在const_cast上找不到太多信息.我能找到的唯一信息(在StackOverflow上)是:Theconst_cast()isusedtoadd/removeconst(ness)(orvolatile-ness)ofavariable.这让我很紧张。可以使用const_cast导致意外行为?如果有,是什么?或者,什么时候可以使用const_cast? 最佳答案 const_cast仅当您正在转换最初不是const的变量时才是安全的.例如,如果您有一个函数,其参数为constchar*,你传入一个可修改的char*,const

c++ - C++ 中的 dynamic_cast 和 static_cast

我对C++中的dynamic_cast关键字感到很困惑。structA{virtualvoidf(){}};structB:publicA{};structC{};voidf(){Aa;Bb;A*ap=&b;B*b1=dynamic_cast(&a);//NULL,because'a'isnota'B'B*b2=dynamic_cast(ap);//'b'C*c=dynamic_cast(ap);//NULL.A&ar=dynamic_cast(*ap);//Ok.B&br=dynamic_cast(*ap);//Ok.C&cr=dynamic_cast(*ap);//std::bad