boost序列化警告C4308:负积分常量转换为无符号类型

时间:2013-05-25 06:41:54

标签: c++ visual-studio-2008 serialization boost

我的结构:

  struct member{
        std::string ip_address;
        std::string port;

    protected:
        friend class boost::serialization::access;

        template<class Archive>
        void serialize(Archive & ar, const unsigned int version)
        {
            ar & ip_address;
            ar & port;
        }
    };

当我使用它来保存和加载它完美无缺时,所有数据都是我期望的那样,

std::vector<member> members;
std::ostringstream ss; 
boost::archive::text_oarchive oa(ss); 
oa<<members;


std::istringstream ss_(received_data.data()); 
boost::archive::text_iarchive ia(ss_); 
ia>>members;

但是在编译时我得到了这个警告

warning C4308: negative integral constant converted to unsigned type
1>        c:\program files\boost\boost_1_51\boost\serialization\static_warning.hpp(92) : see reference to class template instantiation 'boost::mpl::print<T>' being compiled
1>        with
1>        [
1>            T=boost::serialization::BOOST_SERIALIZATION_STATIC_WARNING_LINE<98>
1>        ]
1>        c:\program files\boost\boost_1_51\boost\archive\detail\check.hpp(98) : see reference to class template instantiation 'boost::serialization::static_warning_test<B,L>' being compiled
1>        with
1>        [
1>            B=false,
1>            L=98
1>        ]
1>        c:\program files\boost\boost_1_51\boost\archive\detail\oserializer.hpp(313) : see reference to function template instantiation 'void boost::archive::detail::check_object_tracking<T>(void)' being compiled
1>        with
1>        [
1>            T=std::vector<member>
1>        ]
1>        c:\program files\boost\boost_1_51\boost\archive\detail\oserializer.hpp(525) : see reference to function template instantiation 'void boost::archive::detail::save_non_pointer_type<Archive>::invoke<T>(Archive &,T &)' being compiled
1>        with
1>        [
1>            Archive=boost::archive::text_oarchive,
1>            T=std::vector<member>
1>        ]
1>        c:\program files\boost\boost_1_51\boost\archive\detail\common_oarchive.hpp(69) : see reference to function template instantiation 'void boost::archive::save<Archive,T>(Archive &,T &)' being compiled
1>        with
1>        [
1>            Archive=boost::archive::text_oarchive,
1>            T=std::vector<member>
1>        ]
1>        c:\program files\boost\boost_1_51\boost\archive\basic_text_oarchive.hpp(80) : see reference to function template instantiation 'void boost::archive::detail::common_oarchive<Archive>::save_override<T>(T &,int)' being compiled
1>        with
1>        [
1>            Archive=boost::archive::text_oarchive,
1>            T=std::vector<member>
1>        ]
1>        c:\program files\boost\boost_1_51\boost\archive\detail\interface_oarchive.hpp(63) : see reference to function template instantiation 'void boost::archive::basic_text_oarchive<Archive>::save_override<T>(T &,int)' being compiled
1>        with
1>        [
1>            Archive=boost::archive::text_oarchive,
1>            T=std::vector<member>
1>        ]
1>        c:\users\user\desktop\shve\shve\member_server.h(58) : see reference to function template instantiation 'Archive &boost::archive::detail::interface_oarchive<Archive>::operator <<<std::vector<_Ty>>(T &)' being compiled
1>        with
1>        [
1>            Archive=boost::archive::text_oarchive,
1>            _Ty=member,
1>            T=std::vector<member>
1>        ]

1 个答案:

答案 0 :(得分:16)

如果不同的跟踪对象使用相同的地址,那么<{>} 可能会导致对象跟踪出现问题,我很担心你是archiving non-const class instances

要删除警告,您可以将对象强制转换为const:

oa << const_cast<const std::vector<member>&>(members);

或者你可以简单地使用&amp;操作者:

oa & members;

这是这个特殊(和普通)案件中警告的来源。通常,这种类型的编译器警告是由Boost故意生成的,调用BOOST_STATIC_WARNING宏,因此原因可能是Boost希望您小心的任何事情。这通常在宏调用附带的注释中拼写出来(您可以从编译器错误消息中找到)。例如,此特定警告的调用来自boost\archive\detail\check.hpp

// saving an non-const object of a type not marked "track_never)
// may be an indicator of an error usage of the
// serialization library and should be double checked.  
// See documentation on object tracking.  Also, see the 
// "rationale" section of the documenation
// for motivation for this checking.

BOOST_STATIC_WARNING(typex::value);