类型声明:

 class uint128
{
public:
uint128() :hi(), lo(){}
uint128(uint32_t l) :hi(), lo(l){}
uint128(int32_t l) :hi(-(l < )), lo(l){}
uint128(int64_t l) :hi(-(l < )), lo(l){}
uint128(uint64_t l) :hi(), lo(l){}
uint128(const std::string& s);
uint128(uint64_t _h, uint64_t _l)
:hi(_h), lo(_l){} bool operator == (const uint128& o)const{ return hi == o.hi && lo == o.lo; }
bool operator != (const uint128& o)const{ return hi != o.hi || lo != o.lo; }
bool operator < (const uint128& o)const { return (hi == o.hi) ? lo < o.lo : hi < o.hi; }
bool operator < (const int64_t& o)const { return *this < uint128(o); }
bool operator !()const { return !(hi != || lo != ); }
uint128 operator -()const { return ++uint128(~hi, ~lo); }
uint128 operator ~()const { return uint128(~hi, ~lo); } uint128& operator++() { hi += (++lo == ); return *this; }
uint128& operator--() { hi -= (lo-- == ); return *this; }
uint128 operator++(int) { auto tmp = *this; ++(*this); return tmp; }
uint128 operator--(int) { auto tmp = *this; --(*this); return tmp; } uint128& operator |= (const uint128& u) { hi |= u.hi; lo |= u.lo; return *this; }
uint128& operator &= (const uint128& u) { hi &= u.hi; lo &= u.lo; return *this; }
uint128& operator ^= (const uint128& u) { hi ^= u.hi; lo ^= u.lo; return *this; }
uint128& operator <<= (const uint128& u);
uint128& operator >>= (const uint128& u); uint128& operator += (const uint128& u) { const uint64_t old = lo; lo += u.lo; hi += u.hi + (lo < old); return *this; }
uint128& operator -= (const uint128& u) { return *this += -u; }
uint128& operator *= (const uint128& u); friend uint128 operator + (const uint128& l, const uint128& r) { return uint128(l) += r; }
friend uint128 operator + (const uint128& l, const uint64_t& r) { return uint128(l) += uint128(r); }
friend uint128 operator + (const uint128& l, const uint32_t& r) { return uint128(l) += uint128(r); }
friend uint128 operator + (const uint128& l, const int32_t& r) { return uint128(l) += uint128(r); }
friend uint128 operator + (const uint64_t& l, const uint128& r) { return uint128(l) += r; }
friend uint128 operator - (const uint128& l, const uint128& r) { return uint128(l) -= r; }
friend uint128 operator * (const uint128& l, const uint128& r) { return uint128(l) *= r; }
friend uint128 operator * (const uint128& l, const uint64_t& r) { return uint128(l) *= uint128(r); }
friend uint128 operator * (const uint128& l, const uint32_t& r) { return uint128(l) *= uint128(r); }
friend uint128 operator | (const uint128& l, const uint128& r) { return uint128(l) = (r); }
friend uint128 operator & (const uint128& l, const uint128& r) { return uint128(l) &= r; }
friend uint128 operator & (const uint128& l, const uint64_t& r) { return uint128(l) &= uint128(r); }
friend uint128 operator ^ (const uint128& l, const uint128& r) { return uint128(l) ^= r; }
friend uint128 operator << (const uint128& l, const uint128& r) { return uint128(l) <<= r; }
friend uint128 operator >> (const uint128& l, const uint128& r) { return uint128(l) >>= r; }
friend uint128 operator >> (const uint128& l, const int32_t& r) { return uint128(l) >>= uint128(r); }
friend bool operator > (const uint128& l, const uint128& r) { return r < l; }
friend bool operator >(const uint128& l, const int64_t& r) { return uint128(r) < l; }
friend bool operator > (const int64_t& l, const uint128& r) { return r < uint128(l); } friend bool operator >= (const uint128& l, const uint128& r) { return l == r || l > r; }
friend bool operator >= (const uint128& l, const int64_t& r) { return l >= uint128(r); }
friend bool operator >= (const int64_t& l, const uint128& r) { return uint128(l) >= r; }
friend bool operator <= (const uint128& l, const uint128& r) { return l == r || l < r; }
friend bool operator <= (const uint128& l, const int64_t& r) { return l <= uint128(r); }
friend bool operator <= (const int64_t& l, const uint128& r) { return uint128(l) <= r; } operator uint64_t() { return lo; } //强制转换为uint64_t
operator uint32_t() { return (uint32_t)lo; } //强制转换为uint32_t
operator int32_t() { return (int32_t)lo; } //强制转换为int32_t uint32_t low_32_bits()const { return (uint32_t)lo; }
uint64_t low_bits()const { return lo; }
uint64_t high_bits()const { return hi; } uint64_t hi;
uint64_t lo;
};

实现函数:

 uint128::uint128(const std::string &sz)
:hi(), lo()
{
// do we have at least one character?
if (!sz.empty()) {
// make some reasonable assumptions
int radix = ;
bool minus = false; std::string::const_iterator i = sz.begin(); // check for minus sign, i suppose technically this should only apply
// to base 10, but who says that -0x1 should be invalid?
if (*i == '-') {
++i;
minus = true;
} // check if there is radix changing prefix (0 or 0x)
if (i != sz.end()) {
if (*i == '') {
radix = ;
++i;
if (i != sz.end()) {
if (*i == 'x') {
radix = ;
++i;
}
}
} while (i != sz.end()) {
unsigned int n = ;
const char ch = *i; if (ch >= 'A' && ch <= 'Z') {
if (((ch - 'A') + ) < radix) {
n = (ch - 'A') + ;
}
else {
break;
}
}
else if (ch >= 'a' && ch <= 'z') {
if (((ch - 'a') + ) < radix) {
n = (ch - 'a') + ;
}
else {
break;
}
}
else if (ch >= '' && ch <= '') {
if ((ch - '') < radix) {
n = (ch - '');
}
else {
break;
}
}
else {
/* completely invalid character */
break;
} (*this) *= radix;
(*this) += n; ++i;
}
} if (minus) {
*this = -*this;
}
}
} uint128& uint128::operator<<=(const uint128& rhs)
{
if (rhs >= )
{
hi = ;
lo = ;
}
else
{
unsigned int n = rhs.to_integer();
const unsigned int halfsize = / ; if (n >= halfsize){
n -= halfsize;
hi = lo;
lo = ;
} if (n != ) {
// shift high half
hi <<= n; const uint64_t mask(~(uint64_t(-) >> n)); // and add them to high half
hi |= (lo & mask) >> (halfsize - n); // and finally shift also low half
lo <<= n;
}
} return *this;
} uint128 & uint128::operator>>=(const uint128& rhs)
{
if (rhs >= )
{
hi = ;
lo = ;
}
else
{
unsigned int n = rhs.to_integer();
const unsigned int halfsize = / ; if (n >= halfsize) {
n -= halfsize;
lo = hi;
hi = ;
} if (n != ) {
// shift low half
lo >>= n; // get lower N bits of high half
const uint64_t mask(~(uint64_t(-) << n)); // and add them to low qword
lo |= (hi & mask) << (halfsize - n); // and finally shift also high half
hi >>= n;
}
}
return *this;
} uint128& uint128::operator*=(const uint128 &b)
{
uint64_t a0 = (uint32_t)(this->lo);
uint64_t a1 = (uint32_t)(this->lo >> 0x20);
uint64_t a2 = (uint32_t)(this->hi);
uint64_t a3 = (uint32_t)(this->hi >> 0x20); uint64_t b0 = (uint32_t)(b.lo);
uint64_t b1 = (uint32_t)(b.lo >> 0x20);
uint64_t b2 = (uint32_t)(b.hi);
uint64_t b3 = (uint32_t)(b.hi >> 0x20); this->hi = ;
this->lo = a3*b0;
(*this) += a2*b1;
(*this) += a1*b2;
(*this) += a0*b3;
(*this) <<= 0x20;
(*this) += a2*b0;
(*this) += a1*b1;
(*this) += a0*b2;
(*this) <<= 0x20;
(*this) += a1*b0;
(*this) += a0*b1;
(*this) <<= 0x20;
(*this) += a0*b0; return *this;
}

uint128_t 添加 c++ 重载类型强制转换的更多相关文章

  1. C#高级编程9-第7章 运算符和类型强制转换

    运算符和类型强制转换 1.运算符 运算符的简化操作 条件运算符: if-else的简化操作,也称三元运算符.如果条件为真,返回一个值,为假返回另外一个值. condition?true_value:f ...

  2. C#高级编程 (第六版) 学习 第六章:运算符和类型强制转换

    第六章 运算符和类型强制转换 1,运算符 类别 运算符 算术运算符 + - * / % 逻辑运算符 & | ^ ~ && || ! 字符串连接运算符 + 增量和减量运算符 ++ ...

  3. C#学习笔记二 (资源托管,泛型,数组和元组,运算符和类型强制转换)

     托管和非托管资源 1.托管资源是指GC管理的内存空间,非托管资源是指文件句柄,网络连接,数据库连接等. 2.方法中临时申请的变量,被存放在栈中.栈存储非对象成员的值数据.例如在方法中有B b=new ...

  4. 3_PHP表达式_5_数据类型转换_类型强制转换

    以下为学习孔祥盛主编的<PHP编程基础与实例教程>(第二版)所做的笔记. PHP类型转换分为类型自动转换和类型强制转换. 3.5.2 类型强制转换 类型强制转换允许编程人员手动将变量的数据 ...

  5. C# 运算符和类型强制转换(6) 持续更新

    C#支持的运算符 https://msdn.microsoft.com/zh-cn/library/6a71f45d(v=vs.140).aspx checked 和 unchecked ; b++; ...

  6. 【读书笔记】C#高级编程 第七章 运算符和类型强制转换

    (一)运算符 类别 运算符 算术运算符 + - * / % 逻辑运算符 & | ^ ~ && || ! 字符串连接运算符 + 增量和减量运算符 ++ -- 移位运算符 < ...

  7. C#高级编程笔记 2016年10月8日运算符和类型强制转换

    1.checked和unchecked 运算符 C#提供了checked 和uncheckde 运算符.如果把一个代码块标记为checked, CLR就会执行溢出检查,如果发生溢出,就抛出overfl ...

  8. C语言指针类型 强制转换

    关于C语言指针类型 强制转换  引用一篇文章: C语言中,任何一个变量都必须占有一个地址,而这个地址空间内的0-1代码就是这个变量的值.不同的数据类型占有的空间大小不一,但是他们都必须有个地址,而这个 ...

  9. OC中的类型强制转换

    在Objective-C中,以数字格式组成的字符串经常需要转换为NSNumber对象后再使用.例如有一个字符串对象@"111.22",需要转为NSNumber对象,最简单的方法就是 ...

随机推荐

  1. 怎样通过html标签名获取元素节点集合

    方法1. 使用document.querySelectorAll(); 方法2. 使用document.getElementsByTagName(); document.querySelectorAl ...

  2. python-gitlab 统计代码行数

    需求:根据时间段,统计各个研发提交的代码行 实现逻辑:调用原生gitlab接口太复杂,引用python-gitlab 获取commit详情,然后进行统计 ======================= ...

  3. NopCommerce的autofac的理解

    nop项目4.1是core.2.1开发的,Startup.cs文件开始 从入口进去ServiceCollectionExtensions这个文件 this IServiceCollection ser ...

  4. Ubuntu 上网

    1.打开终端 2.sudo gedit /etc/wpa_supplicant/wpa_supplicant.conf(回车之后会弹出一个编辑页面,在里面打入第三步里面的配置文件)3.配置文件如下:c ...

  5. spark2.0 DataSet操作的一些问题记录

    随着新版本的Spark已经逐渐稳定,最近拟将原有框架升级到spark 2.0.还是比较兴奋的,特别是SQL的速度真的快了许多.. 然而,在其中一个操作时却卡住了.主要是dataframe.map操作, ...

  6. 数据分析基础之pandas & numpy

    一.jupyter的常用快捷键 - 插入cell: a, b   a是after从后插入  a是before 从前插入 - 删除cell: dd, x 都可以 - 修改cell的模式:m, y - t ...

  7. C++ STL 之 string

    #include <iostream> #include <string> using namespace std; // 初始化 void test01() { string ...

  8. Win Server 2012 配置运行 .net core 环境

    今天拿到一台 全新的win 2012 服务器配置服务器环境 记录一下 首先装好IIS 打开服务器管理器  - 添加功能和角色     好 安装完IIS 看一下服务器有没有安装 core的运行环境(全新 ...

  9. 如何上传HTML5应用到SAP云平台的Cloud Foundry环境下

    先使用WebIDE创建一个HTML5应用.New->Project from Template: 从可选模板里选择SAPUI5 Application: 创建一个HTML5 Module,取名为 ...

  10. java oop 基础

    1.如果将一个类打包,使用该类的时候,必须使用该类的全名,java编译器才能找到. 2.也可以使用import 导入这个包. 3.可以不需要import语句 直接使用 java.lang包中的类. 4 ...