C# 整型数和浮点型数的进制转换
1.十进制转二进制
/// <summary>
/// 十进制转二进制
/// </summary>
public class Convert10To2
{
/// <summary>
/// 将十进制的16位整型数转换为16位二进制字符串
/// </summary>
/// <param name="i"></param>
/// <returns></returns>
public static bool TryTo2(short i, out string v)
{
try
{
v = Convert.ToString(i, ).PadLeft(, '');
return true;
}
catch (Exception)
{
v = default;
return false;
}
} /// <summary>
/// 将十进制的32位整型数转换为32位二进制字符串
/// </summary>
/// <param name="i"></param>
/// <returns></returns>
public static bool TryTo2(int i, out string v)
{
try
{
v = Convert.ToString(i, ).PadLeft(, '');
return true;
}
catch (Exception)
{
v = default;
return false;
}
} /// <summary>
/// 将十进制的64位整型数转换为64位二进制字符串
/// </summary>
/// <param name="i"></param>
/// <returns></returns>
public static bool TryTo2(long i, out string v)
{
try
{
v = Convert.ToString(i, ).PadLeft(, '');
return true;
}
catch (Exception)
{
v = default;
return false;
}
} /// <summary>
/// 将十进制的32位单精度浮点数转换为32位二进制字符串
/// </summary>
/// <param name="i"></param>
/// <param name="v"></param>
/// <returns></returns>
public static bool TryTo2(float i, out string v)
{
try
{
float j = i;
i = Math.Abs(i);
int i_left = Convert.ToInt32(Math.Floor(i));//获取整数部分
float i_right = i - i_left;//获取小数部分
TryTo2(i_left, out string left);//整数部分转换为二进制
string right = "";
while (i_right != )//小数部分转换为二进制
{
float temp = i_right * ;
right += temp >= ? "" : "";
if (temp == || temp == )
{
break;
}
i_right = temp > ? temp - : temp;
}
string S = j > ? "" : "";//获取符号位的二进制
if (!left.Contains(""))
{
int e = - (right.IndexOf('') + );//获取指数位的十进制
TryTo2(e, out string E);//获取指数位的二进制
string M = right.Substring(right.IndexOf('') + );
if (M.Length > )
{
M = M.Substring(, );
}
else if (M.Length < )
{
M = M.PadRight(, '');
}
v = S + E.Substring(E.Length - ) + M;
}
else
{
int e = left.Length - left.IndexOf('') - + ;//获取指数位的十进制
TryTo2(e, out string E);//获取指数位的二进制
var z = (left.IndexOf('') + );//获取最高正数位
string M = ((z >= left.Length ? "" : left.Substring(z)) + right);//获取尾数
if (M.Length > )
{
M = M.Substring(, );
}
else if (M.Length < )
{
M = M.PadRight(, '');
}
v = S + E.Substring(E.Length - ) + M;
}
return true;
}
catch (Exception)
{
v = default;
return false;
}
}
}
十进制转二进制
2.二进制转十进制
/// <summary>
/// 二进制转十进制
/// </summary>
public class Convert2To10
{
/// <summary>
/// 将32位二进制字符串转换为十进制的单精度浮点数
/// </summary>
/// <param name="i"></param>
/// <param name="v"></param>
/// <returns></returns>
public static bool TryTo10(string i, out float v)
{
try
{
var s = i.Substring(, );//获取符号位字符串
var e = i.Substring(, );//获取指数位字符串
var m = i.Substring();//获取尾数字符串
TryTo10(s, out int S);//把符号转换成十进制
TryTo10(e, out int E);//获取指数转换成十进制
var m_left = $"1{m.Substring(0, E - 127)}";//获取整数部分二进制字符串
var m_right = m.Substring(E - );//获取小数部分二进制字符串
TryTo10(m_left, out int left);//把整数部分转换为十进制
var right = 0f;
for (int index = ; index < m_right.Length; index++)//把小数部分转换为十进制
{
var temp_value = Convert.ToSingle(m_right[index].ToString());
var temp_index = Convert.ToSingle(Math.Pow(, -(index + )));
right += (temp_value * temp_index);
}
v = left + right;//合并整数部分和小数部分
v = S == ? -v : v;//添加符号
return true;
}
catch
{
v = default;
return false;
}
} /// <summary>
/// 将32位二进制字符串转换为十进制的32位整型数
/// </summary>
/// <param name="i"></param>
/// <param name="v"></param>
/// <returns></returns>
public static bool TryTo10(string i, out int v)
{
try
{
v = Convert.ToInt32(i, );
return true;
}
catch
{
v = default;
return false;
}
}
}
二进制转十进制
C# 整型数和浮点型数的进制转换的更多相关文章
- Linux命令之bc - 浮点计算器、进制转换
用途说明 Bash内置了对整数四则运算的支持,但是并不支持浮点运算,而bc命令可以很方便的进行浮点运算,当然整数运算也不再话下.手册页上说bc是An arbitrary precision calcu ...
- python27期day03:字符串详解:整型、可变数据类型和不可变数据类型、进制转换、索引、切片、步长、字符串方法、进制转换、作业题。
1.%s: a = "我是新力,我喜欢:%s,我钟爱:%s"b = a%("开车","唱跳rap")print(b)2.整型: 整数在Pyt ...
- Java 基础入门随笔(2) JavaSE版——关键字、进制转换、类型转换
1.Java语言-关键字 关键字:被java语言赋予了特殊含义的词,特点是所有的字母都为小写. java涉及到的关键字整理: 用于定义数据类型的关键字 class interface byte sho ...
- php进制转换函数
1 十进制(decimal system)转换函数 ① 十进制转二进制 string decbin(int number). 参数为一个十进制整型数字,不是整型数字会自动转为整型数字,如'3'转为3 ...
- Java:进制转换
进制转换是常常需要的一种数据处理,在java中的一些类中封装了具有转换功能的方法,这个不做介绍.其实,进制之间的转化是通过先位异或&,再位移动>>>的方式实现的. 例如,对于 ...
- 九度OJ 1026:又一版 A+B (进制转换)
时间限制:1 秒 内存限制:32 兆 特殊判题:否 提交:11412 解决:3086 题目描述: 输入两个不超过整型定义的非负10进制整数A和B(<=231-1),输出A+B的m (1 < ...
- 004-Java进制转换
整型数据共有4中进制形式 二进制(binary):以0b或者0B开头 十进制(decimal) 八进制(octal):以数字0开头 十六进制(hex):以0x或者0X开头 二进制数据包含原码反码和补码 ...
- Java基础复习之一篇:关健字,标识符,注释,常量,进制转换,变量,数据类型,数据类型转换
1.关健字 1.1.被Java语言赋予特定意义的单词(如:class,interface,public ,static) 1.2.全部是小写 1.3.注意事项(goto和const作为关健字保留起来) ...
- JavaSE学习(二):进制转换—数据类型转换—Java运算符
一.进制转换 1.1 其他进制转十进制(以十六进制为例): 十六进制范围:0-9, A-F对应数字10-15 2A7E(16) = 14*16(0) +7*16(1) + 10*16(2) + ...
- PHP开发——进制转换
常用进制 l 10进制:有10个基本数,分别为0.1.2.3.4.5.6.7.8.9,运算规则”逢10进1”: l 8进制:有8个基本数,分别为0.1.2.3.4.5.6.7,运算规则”逢8进1” ...
随机推荐
- vuecli3集成easyui
思路是这样的,首先要将jquery设置成全局,然后就可以正常使用easyUI了. jquery安装命令: npm install --save jquery jquery-easyui安装命令: np ...
- 沙箱测试环境配置AND证书添加
支付宝SDK接口项目Demo测试 一.进入支付宝开放中心 下载密钥生成器 https://developers.alipay.com/developmentAccess/developmentAcce ...
- Python使用设计模式中的责任链模式与迭代器模式的示例
Python使用设计模式中的责任链模式与迭代器模式的示例 这篇文章主要介绍了Python使用设计模式中的责任链模式与迭代器模式的示例,责任链模式与迭代器模式都可以被看作为行为型的设计模式,需要的朋友可 ...
- (一)java面试易忘题目精选(1)
1. int和Integer有什么区别? 答:Java是一个近乎纯洁的面向对象编程语言,但是为了编程的方便还是引入了基本数据类型,但是为了能够将这些基本数据类型当成对象操作,Java为每一个基本数据类 ...
- jQuery插件—获取URL参数
做的项目中需要用到通过JS获取GET参数,上网找了一下,找到如下插件: 例如 当前你的URL是: http://www.xxx.com/index.php?test=1&kk=2 //如果想获 ...
- iOS面试考察点
)自我介绍.项目经历.专业知识.自由提问 (2)准备简历.投发简历.笔试(电话面试.).面试.复试.终面试.试用.转正.发展.跳槽(加薪升职) 1闲聊 a)自我介绍:自我认识能力 b)评价上一家公司: ...
- MariaDB集群配置(主从和多主)
1.mariadb主从 主从多用于网站架构,因为主从的同步机制是异步的,数据的同步有一定延迟,也就是说有可能会造成数据的丢失,但是性能比较好,因此网站大多数用的是主从架构的数据库,读写分离必须基于主从 ...
- Flutter 弹出键盘屏幕溢出问题
在使用输入框获取焦点,弹出键盘的时候,会导致屏幕溢出, 解决办法: resizeToAvoidBottomPadding: false, //输入框抵住键盘 return Scaffold( appB ...
- 【OpenGL学习】 四种绘制直线的算法
我是用MFC框架进行测试的,由于本人也没有专门系统学习MFC框架,代码若有不足之处,请指出. 一,先来一个最简单的DDA算法 DDA算法全称为数值微分法,基于微分方程来绘制直线. ①推导微分方程如下: ...
- SQL 语句是如何执行的
SQL 语句是如何执行的,虽然SQL是声明式语言,我们可以像使用英语一样使用它,不过在RDBMS(关系型数据库管理系统)中,SQL的实现方式还是有差别的.极客教程从数据库的角度来思考一下SQL是如何被 ...