当前位置: 首页>>代码示例>>C++>>正文


C++ basic_string::cend方法代码示例

本文整理汇总了C++中std::basic_string::cend方法的典型用法代码示例。如果您正苦于以下问题:C++ basic_string::cend方法的具体用法?C++ basic_string::cend怎么用?C++ basic_string::cend使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在std::basic_string的用法示例。


在下文中一共展示了basic_string::cend方法的3个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C++代码示例。

示例1: StringICompare

bool StringICompare(const std::basic_string<CharT> &lhs, const std::basic_string<CharT> &rhs)
{
    if (lhs.length() == rhs.length()) {
        return std::equal(lhs.cbegin(), lhs.cend(), rhs.cbegin(), ICompare);
    } else {
        return false;
    }
}
开发者ID:myd7349,项目名称:Ongoing-Study,代码行数:8,代码来源:strutils.hpp

示例2:

   basic_str_wrap( std::basic_string<Char_T> const& str )
       :fst( &*str.cbegin() )
	   ,lst( &*str.cend() )
	   ,cstr( str.c_str() )
    {}
开发者ID:nyaocat,项目名称:BigMan,代码行数:5,代码来源:utils.hpp

示例3: if

bool UTF8string::utf8_is_valid_() const noexcept
{
    const std::basic_string<unsigned char> U8STRING = toUstring( _utf8string );
    auto it = U8STRING.begin();
    const auto ITEND = U8STRING.cend();

    while ( it < ITEND )
    {
        if ( ( 0xF8 & *it ) == 0xF0 && *it <= 0xF4 )
        {
            // The UTF-8 codepoint begin with 0b11110xxx -> 4-byte codepoint
            // If the iterator reach the end of the string before the
            // end of the 4-byte codepoint -> invalid string
            if ( ( it + 1 ) == ITEND || ( it + 2 ) == ITEND || ( it + 3 ) == ITEND )
                return false;

            // Each of the following bytes is a value
            // between 0x80 and 0xBF
            if ( ( ( 0xC0 & *( it + 1 ) ) != 0x80 ) || ( ( 0xC0 & *( it + 2 ) ) != 0x80 )
                    || ( ( 0xC0 & *( it + 3 ) ) != 0x80 ) )
            {
                return false;
            }

            // If the first byte of the sequence is 0xF0
            // then the first continuation byte must be between 0x90 and 0xBF
            // otherwise, if the byte is 0xF4
            // then the first continuation byte must be between 0x80 and 0x8F
            if ( *it == 0xF0 )
            {
                if ( *( it + 1 ) < 0x90 || *( it + 1 ) > 0xBF )
                    return false;
            }
            else if ( *it == 0xF4 )
            {
                if ( *( it + 1 ) < 0x80 || *( it + 1 ) > 0x8F )
                    return false;
            }

            it += 4;    // Jump to the next codepoint
        }
        else if ( ( 0xF0 & *it ) == 0xE0 )
        {
            // The UTF-8 codepoint begin with 0b1110xxxx -> 3-byte codepoint
            if ( ( it + 1 ) == ITEND || ( it + 2 ) == ITEND )
                return false;

            // Each of the following bytes starts with
            // 0b10xxxxxx in a valid string
            if ( ( ( 0xC0 & *( it + 1 ) ) != 0x80 ) || ( ( 0xC0 & *( it + 2 ) ) != 0x80 ) )
                return false;

            // If the first byte of the sequence is 0xE0
            // then the first continuation byte must be between 0xA0 and 0xBF
            // otherwise, if the byte is 0xF4
            // then the first continuation byte must be between 0x80 and 0x9F
            if ( *it == 0xE0 )
            {
                if ( *( it + 1 ) < 0xA0 || *( it + 1 ) > 0xBF )
                    return false;
            }
            else if ( *it == 0xED )
            {
                if ( *( it + 1 ) > 0x9F )
                    return false;
            }

            it += 3;
        }
        else if ( ( 0xE0 & *it ) == 0xC0 )
        {
            // The UTF-8 codepoint begin with 0b110xxxxx -> 2-byte codepoint
            if ( ( it + 1 ) == ITEND )
                return false;

            // The following byte starts with 0b10xxxxxx in a valid string
            if ( ( 0xC0 & *( it + 1 ) ) != 0x80 )
                return false;

            it += 2;
        }
        else if ( ( 0x80 & *it ) == 0x00 )
        {
            // The UTF-8 codepoint begin with 0b0xxxxxxx -> 1-byte codepoint
            it += 1;
        }
        else
        {
            // Invalid codepoint
            return false;
        }
    }

    return true;
}
开发者ID:Gumichan01,项目名称:lunatix-engine,代码行数:95,代码来源:utf8_string.cpp


注:本文中的std::basic_string::cend方法示例由纯净天空整理自Github/MSDocs等开源代码及文档管理平台,相关代码片段筛选自各路编程大神贡献的开源项目,源码版权归原作者所有,传播和使用请参考对应项目的License;未经允许,请勿转载。