草庐IT

strong_typedef

全部标签

c++ - 重载运算符<<(unsigned char typedef as byte)

我想重载(劫持?)ostream和basic_ostream以便它停止尝试将八位字节(无符号字符)显示为可打印字符。我一直住在cout和friend们在屏幕上放笑脸的时间太长了。我厌倦了与Actor一起工作:hex.是否可以覆盖标准行为?我已经尝试过模板和非模板覆盖。它们编译,但似乎没有被调用。 最佳答案 问题是已经有一个templatestd::basic_ostream&operator&,charT);在namespacestd.自basic_ostream也在这个命名空间中,ADL在你输出unsignedchar时选择它.添

c++ - 具有 typedef 返回值的模板化成员函数

为什么下面的代码给我一个错误(g++4.1.2)?templateclassFoo{public:typedefstd::vectorAVec;AVec*foo();};templateFoo::AVec*Foo::foo(){//erroronthislinereturnNULL;}错误是:error:expectedconstructor,destructor,ortypeconversionbefore'*'token我应该如何定义Foo::foo()以其他方式运行(具有正确的返回类型)? 最佳答案 这是一个名为“two-st

c++ - 继承而不是 typedef

C++无法从typedef或typedef模板化类中创建模板。我知道如果我继承并使我的类成为模板,它就会起作用。例子://IllegaltemplatetypedefMyVectorTypevector;//Valid,butadvantageous?templateclassMyVectorType:publicvector{};这样做有利于我“伪造”typedef还是有更好的方法来做到这一点? 最佳答案 C++0x将使用using添加模板类型定义关键字。您的解决方案声明了一个新类型,而不是类型“别名”,例如你不能初始化MyVec

c++ - 如何 typedef 具有未指定大小的 std::array?

我想写一些变量,比如std::arraya;哪里array_num是constint表示数组的长度。但是它很长,我想为它创建一个别名:typedefstd::arraymy_array;是吗?如何使用my_array喜欢my_array? 最佳答案 您需要的是aliastemplate:templateusingmy_array=std::array;您不能直接制作typedef模板,参见thispost.size_t是std::array采用的第二个模板参数的类型,而不是int。既然您了解了使用,您应该会使用它。它可以做typed

这意味着Typedef char *b?

我正在阅读此内存管理代码超载操作员新的。有类似的表达typedefchar*b后来在代码B中使用了这样的使用:b(h);//hisapointertosomeclass;H在这里定义:staticHead*h=(Head*)HEAP_BASE_ADDRESS;我假设当使用B时,它被认为是指向字符的指针。但是,指针如何具有B()之类的表达式?这里有某种转换吗?我可以理解它,因为B现在的地址与H相同吗?看答案您发布的第一个代码行是typedef为此创造了一个别名char*作为b。第二个代码行显示了功能风格类型转换从h至b.我可以理解它,因为B现在的地址与H相同吗?这b只是一个别名char*,所以b

iphone - Xcode "AppDelegate *const __strong' 到不兼容类型的参数”错误

当我如下声明appDelegate接口(interface)以设置NSXMLParserDelegate时,我从其他使用[[UIApplicationsharedApplication]delegate]的View收到一些警告;@interfaceAppDelegate:UIResponderwarning:Initializing'AppDelegate*__strong'withanexpressionofincompatibletype'id'但是,如果我删除它,由于xmlParser的self设置会出现另一个警告,@interfaceAppDelegate:UIResponde

iphone - 解释SDWebImage代码中__weak和__strong的使用原因

我想我很了解strong和weak关键字,但我不明白它在下面的代码中是如何使用的。此代码来自Github上OlivierPoitrey的SDWebImage。我了解这里描述的强关键字和弱关键字:ExplanationofstrongandweakstorageiniOS5下面的代码以我很好奇的方式使用了__weak和__strong关键字。它不是子-父关系或委托(delegate)模式,因为我习惯于看到weakused。但是,我确信这是一种经常使用的模式,正如我之前在其他代码中看到的那样。它在另一个线程上运行的block之前设置一个__weak引用。然后,在block内,它将弱引用设置

ios - 将 'NSError *const __strong *' 发送到类型为 'NSError *__autoreleasing *' 的参数会更改指针的保留/释放属性

这个问题类似于iosNSErrortypes但是那里描述的解决方案没有用,我相信这不是我所需要的。我有一个执行异步调用然后调用完成block的方法。当我尝试将NSError**传递给完成block时,出现此错误:Sending'NSError*const__strong*'toparameteroftype'NSError*__autoreleasing*'changesretain/releasepropertiesofpointer代码如下:+(void)agentWithGUID:(NSString*)guidcompletion:(void(^)(AKAgentProfile*

ios - ARC 不允许将非 Objective-C 指针类型 void* 隐式转换为 NSString*__strong*

迁移到ARC时出现上述错误。这是代码:staticNSString*cashBalanceKeyPath=@"test";...[xxxforKeyPath:cashBalanceKeyPathoptions:NSKeyValueObservingOptionNewcontext:&cashBalanceKeyPath];...-(void)observeValueForKeyPath:(NSString*)keyPathofObject:(id)objectchange:(NSDictionary*)changecontext:(void*)context{if(&cashBalan

为什么block要使用copy而不是strong或者其他属性修饰?

block本身是像对象一样可以retain,和release。但是,block在创建的时候,它的内存是分配在栈上的,而不是在堆上。其本身的作用域是属于创建时候的作用域,一旦在创建时候的作用域外面调用block将导致程序崩溃。因为栈区的特点就是创建的对象随时可能被销毁,一旦被销毁后续再次调用空对象就可能会造成程序崩溃,在对block进行copy后,block存放在堆区。使用retain也可以,但是block的retain行为默认是用copy的行为实现的,因为block变量默认是声明为栈变量的,为了能够在block的声明域外使用,所以要把block拷贝(copy)到堆,所以说为了block属性声明