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” ...
随机推荐
- [webpack]webpack打包优化
1.import优化 a.tree-shaking 把没用到的代码删除掉,import 在生产环境下 会自动去除掉没用的代码 b.scope hosting 作用域提升,在webpack中会自动省略一 ...
- LinkedHashSet
特点: 有序 , 唯一 底层的数据结构为: 链表和哈希表 , 链表保证有序 , 哈希表保证唯一 import java.util.LinkedHashSet; public class Demo2_L ...
- ISO/IEC 9899:2011 条款5——5.2.1 字符集
5.2.1 字符集 1.两个字符集和它们相关联的依次顺序应该被定义:写在源文件中的集合(源字符集),以及在执行环境中被解释的集合(执行字符集).每个集合此外被划分为一个基本字符集,其内容由本子条款给出 ...
- java调用科大讯飞流式(websocket)语音识别接口
要使用讯飞的能力,需先注册讯飞开发平台账号(讯飞官网参见https://www.xfyun.cn/). 再创建应用,点击右上角的控制台 -> 创建新应用: 每个应用都有一个appId,由这个ap ...
- Linux -- 管理锁争用(翻译)
在多线程应用中,程序员会使用互斥锁(mutex)来同步线程进入可访问共享资源的代码区域的行为.受这些锁保护的代码区域被称为关键代码段(Critical Section).如果关键代码段中已存在一个线程 ...
- Apache配置优化之开启GZip传输
1.确保apache已经编译的模块里有mod_deflate模块 2.确保apache的配置文件里引入了压缩的模块 3.确保要开启Gzip压缩的虚拟主机配置里有如下配置,并重启apache服务:如果要 ...
- C# http请求 设置代理(标题可以作为搜索关键字)
例一(C# 通过代理发HTTP请求): https://q.cnblogs.com/q/88682/ 例二(C# 代理HTTP请求): https://www.cnblogs.com/ShalenCh ...
- JsonSchema用法
JsonSchema用法 简介 JSON Schema是基于JSON格式,用于定义JSON数据结构以及校验JSON数据内容.JSON Schema官网地址:http://json-schema.org ...
- Fakes里的stub和shim的区别
stub常用于虚拟接口.类.方法,无法重写静态方法(stub需要传递到具体调用代码中) shim常用于重写静态方法(在ShimsContext.Create()作用域内,拦截Runtime动态修改方法 ...
- react做的react-redux购物车
### 1. 创建项目 create - react - app 项目名(shop) ### 2. 进入项目,下载redux,react-redux cnpm install redux ...