C#语言程序如何将int类型的数据“2000” 转化为string类型的 “\x07\xD0”
时间: 2024-12-18 11:37:30 浏览: 31
在C#中,要将整数(int)类型的数据 "2000" 转换为对应的 Unicode 字符串 "\x07\xD0",你需要使用 `BitConverter` 类和 `ToString` 方法。这个过程通常涉及到获取整数的二进制表示,并将其转换为十六进制字符串。
以下是一个简单的示例:
```csharp
int number = 2000;
byte[] bytes = BitConverter.GetBytes(number);
string hexString = BitConverter.ToString(bytes).Replace("-", "");
// 如果需要前导零,可以添加
hexString = string.Join("", hexString.PadStart(4, '0'));
// 输出结果,"\x07\xD0" 就是你想要的形式
Console.WriteLine("Hex String: " + hexString);
```
在这个例子中,`BitConverter.GetBytes` 函数把整数转换为字节数组,然后 `BitConverter.ToString` 把字节数组转换为十六进制字符串。`Replace("-", "")` 是为了去除默认的短横线分隔符,因为题目中给出的是无分隔的 "2000" 对应的 "07D0"。
相关问题
我有一个文件里面是D886A225C5CB8B961D3636A68DEDEB80,我先把它转化为Byte[],值是0xD8,0X86...这样的,应该怎么做,用C#
在C#中,你可以通过将十六进制字符串转换为字节数组来进行这种操作。这里是一个简单的步骤:
1. 首先,你需要创建一个`StringBuilder`来存储每个十六进制字符对应的ASCII码,因为十六进制对应4位二进制,所以需要两个连续的十六进制数字代表一个字节。
```csharp
string hexString = "D886A225C5CB8B961D3636A68DEDEB80";
StringBuilder byteBuilder = new StringBuilder();
```
2. 然后遍历这个十六进制字符串,每两位作为一个字节处理:
```csharp
for (int i = 0; i < hexString.Length; i += 2)
{
string hexPair = hexString.Substring(i, 2);
byteBuilder.Append((byte)Convert.ToInt32(hexPair, 16));
}
```
3. 最后,得到的`StringBuilder`内容就是字节数组了,可以将其转换为`byte[]`:
```csharp
byte[] byteArray = byteBuilder.ToByteArray();
```
完整的代码示例:
```csharp
using System.Text;
string hexString = "D886A225C5CB8B961D3636A68DEDEB80";
StringBuilder byteBuilder = new StringBuilder();
for (int i = 0; i < hexString.Length; i += 2)
{
string hexPair = hexString.Substring(i, 2);
byteBuilder.Append((byte)Convert.ToInt32(hexPair, 16));
}
byte[] byteArray = byteBuilder.ToByteArray();
```
#include "oled.h" #include "stdlib.h" #include "oledfont.h" #include "delay.h" //OLED的显存 //存放格式如下. //[0]0 1 2 3 ... 127 //[1]0 1 2 3 ... 127 //[2]0 1 2 3 ... 127 //[3]0 1 2 3 ... 127 //[4]0 1 2 3 ... 127 //[5]0 1 2 3 ... 127 //[6]0 1 2 3 ... 127 //[7]0 1 2 3 ... 127 /********************************************** //IIC Start **********************************************/ /********************************************** //IIC Start **********************************************/ void IIC_Start() { OLED_SCLK_Set() ; OLED_SDIN_Set(); OLED_SDIN_Clr(); OLED_SCLK_Clr(); } /********************************************** //IIC Stop **********************************************/ void IIC_Stop() { OLED_SCLK_Set() ; // OLED_SCLK_Clr(); OLED_SDIN_Clr(); OLED_SDIN_Set(); } void IIC_Wait_Ack() { //GPIOB->CRH &= 0XFFF0FFFF; //设置PB12为上拉输入模式 //GPIOB->CRH |= 0x00080000; // OLED_SDA = 1; // delay_us(1); //OLED_SCL = 1; //delay_us(50000); /* while(1) { if(!OLED_SDA) //判断是否接收到OLED 应答信号 { //GPIOB->CRH &= 0XFFF0FFFF; //设置PB12为通用推免输出模式 //GPIOB->CRH |= 0x00030000; return; } } */ OLED_SCLK_Set() ; OLED_SCLK_Clr(); } /********************************************** // IIC Write byte **********************************************/ void Write_IIC_Byte(unsigned char IIC_Byte) { unsigned char i; unsigned char m,da; da=IIC_Byte; OLED_SCLK_Clr(); for(i=0;i<8;i++) { m=da; // OLED_SCLK_Clr(); m=m&0x80; if(m==0x80) {OLED_SDIN_Set();} else OLED_SDIN_Clr(); da=da<<1; OLED_SCLK_Set(); OLED_SCLK_Clr(); } } /********************************************** // IIC Write Command **********************************************/ void Write_IIC_Command(unsigned char IIC_Command) { IIC_Start(); Write_IIC_Byte(0x78); //Slave address,SA0=0 IIC_Wait_Ack(); Write_IIC_Byte(0x00); //write command IIC_Wait_Ack(); Write_IIC_Byte(IIC_Command); IIC_Wait_Ack(); IIC_Stop(); } /********************************************** // IIC Write Data **********************************************/ void Write_IIC_Data(unsigned char IIC_Data) { IIC_Start(); Write_IIC_Byte(0x78); //D/C#=0; R/W#=0 IIC_Wait_Ack(); Write_IIC_Byte(0x40); //write data IIC_Wait_Ack(); Write_IIC_Byte(IIC_Data); IIC_Wait_Ack(); IIC_Stop(); } void OLED_WR_Byte(unsigned dat,unsigned cmd) { if(cmd) { Write_IIC_Data(dat); } else { Write_IIC_Command(dat); } } /******************************************** // fill_Picture ********************************************/ void fill_picture(unsigned char fill_Data) { unsigned char m,n; for(m=0;m<8;m++) { OLED_WR_Byte(0xb0+m,0); //page0-page1 OLED_WR_Byte(0x00,0); //low column start address OLED_WR_Byte(0x10,0); //high column start address for(n=0;n<128;n++) { OLED_WR_Byte(fill_Data,1); } } } /***********************Delay****************************************/ void Delay_50ms(unsigned int Del_50ms) { unsigned int m; for(;Del_50ms>0;Del_50ms--) for(m=6245;m>0;m--); } void Delay_1ms(unsigned int Del_1ms) { unsigned char j; while(Del_1ms--) { for(j=0;j<123;j++); } } //坐标设置 void OLED_Set_Pos(unsigned char x, unsigned char y) { OLED_WR_Byte(0xb0+y,OLED_CMD); OLED_WR_Byte(((x&0xf0)>>4)|0x10,OLED_CMD); OLED_WR_Byte((x&0x0f),OLED_CMD); } //开启OLED显示 void OLED_Display_On(void) { OLED_WR_Byte(0X8D,OLED_CMD); //SET DCDC命令 OLED_WR_Byte(0X14,OLED_CMD); //DCDC ON OLED_WR_Byte(0XAF,OLED_CMD); //DISPLAY ON } //关闭OLED显示 void OLED_Display_Off(void) { OLED_WR_Byte(0X8D,OLED_CMD); //SET DCDC命令 OLED_WR_Byte(0X10,OLED_CMD); //DCDC OFF OLED_WR_Byte(0XAE,OLED_CMD); //DISPLAY OFF } //清屏函数,清完屏,整个屏幕是黑色的!和没点亮一样!!! void OLED_Clear(void) { u8 i,n; for(i=0;i<8;i++) { OLED_WR_Byte (0xb0+i,OLED_CMD); //设置页地址(0~7) OLED_WR_Byte (0x00,OLED_CMD); //设置显示位置—列低地址 OLED_WR_Byte (0x10,OLED_CMD); //设置显示位置—列高地址 for(n=0;n<128;n++)OLED_WR_Byte(0,OLED_DATA); } //更新显示 } void OLED_On(void) { u8 i,n; for(i=0;i<8;i++) { OLED_WR_Byte (0xb0+i,OLED_CMD); //设置页地址(0~7) OLED_WR_Byte (0x00,OLED_CMD); //设置显示位置—列低地址 OLED_WR_Byte (0x10,OLED_CMD); //设置显示位置—列高地址 for(n=0;n<128;n++)OLED_WR_Byte(1,OLED_DATA); } //更新显示 } //在指定位置显示一个字符,包括部分字符 //x:0~127 //y:0~63 //mode:0,反白显示;1,正常显示 //size:选择字体 16/12 void OLED_ShowChar(u8 x,u8 y,u8 chr,u8 Char_Size) { unsigned char c=0,i=0; c=chr-' ';//得到偏移后的值 if(x>Max_Column-1){x=0;y=y+2;} if(Char_Size ==16) { OLED_Set_Pos(x,y); for(i=0;i<8;i++) OLED_WR_Byte(F8X16[c*16+i],OLED_DATA); OLED_Set_Pos(x,y+1); for(i=0;i<8;i++) OLED_WR_Byte(F8X16[c*16+i+8],OLED_DATA); } else { OLED_Set_Pos(x,y); for(i=0;i<6;i++) OLED_WR_Byte(F6x8[c][i],OLED_DATA); } } //m^n函数 u32 oled_pow(u8 m,u8 n) { u32 result=1; while(n--)result*=m; return result; } //显示2个数字 //x,y :起点坐标 //len :数字的位数 //size:字体大小 //mode:模式 0,填充模式;1,叠加模式 //num:数值(0~4294967295); void OLED_ShowNum(u8 x,u8 y,u32 num,u8 len,u8 size2) { u8 t,temp; u8 enshow=0; for(t=0;t<len;t++) { temp=(num/oled_pow(10,len-t-1))%10; if(enshow==0&&t<(len-1)) { if(temp==0) { OLED_ShowChar(x+(size2/2)*t,y,' ',size2); continue; }else enshow=1; } OLED_ShowChar(x+(size2/2)*t,y,temp+'0',size2); } } //显示一个字符号串 void OLED_ShowString(u8 x,u8 y,u8 *chr,u8 Char_Size) { unsigned char j=0; while (chr[j]!='\0') { OLED_ShowChar(x,y,chr[j],Char_Size); x+=8; if(x>120){x=0;y+=2;} j++; } } //显示汉字 void OLED_ShowCHinese(u8 x,u8 y,u8 no) { u8 t,adder=0; OLED_Set_Pos(x,y); for(t=0;t<16;t++) { OLED_WR_Byte(Hzk[2*no][t],OLED_DATA); adder+=1; } OLED_Set_Pos(x,y+1); for(t=0;t<16;t++) { OLED_WR_Byte(Hzk[2*no+1][t],OLED_DATA); adder+=1; } } /***********功能描述:显示显示BMP图片128×64起始点坐标(x,y),x的范围0~127,y为页的范围0~7*****************/ void OLED_DrawBMP(unsigned char x0, unsigned char y0,unsigned char x1, unsigned char y1,unsigned char BMP[]) { unsigned int j=0; unsigned char x,y; if(y1%8==0) y=y1/8; else y=y1/8+1; for(y=y0;y<y1;y++) { OLED_Set_Pos(x0,y); for(x=x0;x<x1;x++) { OLED_WR_Byte(BMP[j++],OLED_DATA); } } } //初始化SSD1306 void OLED_Init(void) { GPIO_InitTypeDef GPIO_InitStructure; RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOB, ENABLE); //使能A端口时钟 GPIO_InitStructure.GPIO_Pin = GPIO_Pin_10|GPIO_Pin_11; GPIO_InitStructure.GPIO_Mode = GPIO_Mode_Out_PP; //推挽输出 GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;//速度50MHz GPIO_Init(GPIOB, &GPIO_InitStructure); //初始化GPIOB,10,11 GPIO_SetBits(GPIOB,GPIO_Pin_10|GPIO_Pin_11); DelayMs(800); OLED_WR_Byte(0xAE,OLED_CMD);//--display off OLED_WR_Byte(0x00,OLED_CMD);//---set low column address OLED_WR_Byte(0x10,OLED_CMD);//---set high column address OLED_WR_Byte(0x40,OLED_CMD);//--set start line address OLED_WR_Byte(0xB0,OLED_CMD);//--set page address OLED_WR_Byte(0x81,OLED_CMD); // contract control OLED_WR_Byte(0xFF,OLED_CMD);//--128 OLED_WR_Byte(0xA1,OLED_CMD);//set segment remap OLED_WR_Byte(0xA6,OLED_CMD);//--normal / reverse OLED_WR_Byte(0xA8,OLED_CMD);//--set multiplex ratio(1 to 64) OLED_WR_Byte(0x3F,OLED_CMD);//--1/32 duty OLED_WR_Byte(0xC8,OLED_CMD);//Com scan direction OLED_WR_Byte(0xD3,OLED_CMD);//-set display offset OLED_WR_Byte(0x00,OLED_CMD);// OLED_WR_Byte(0xD5,OLED_CMD);//set osc division OLED_WR_Byte(0x80,OLED_CMD);// OLED_WR_Byte(0xD8,OLED_CMD);//set area color mode off OLED_WR_Byte(0x05,OLED_CMD);// OLED_WR_Byte(0xD9,OLED_CMD);//Set Pre-Charge Period OLED_WR_Byte(0xF1,OLED_CMD);// OLED_WR_Byte(0xDA,OLED_CMD);//set com pin configuartion OLED_WR_Byte(0x12,OLED_CMD);// OLED_WR_Byte(0xDB,OLED_CMD);//set Vcomh OLED_WR_Byte(0x30,OLED_CMD);// OLED_WR_Byte(0x8D,OLED_CMD);//set charge pump enable OLED_WR_Byte(0x14,OLED_CMD);// OLED_WR_Byte(0xAF,OLED_CMD);//--turn on oled panel OLED_Clear(); } 改写为上个要求
代码概述
该代码实现了一个基于 SSD1306 驱动的 OLED 屏幕显示控制器,使用的是 STM32 标准外设库(StdPeriph)。现要求将其改写为适用于 **STM32G474RET6** 的 HAL 库版本。
---
代码解析
### 主要修改内容:
| 原 StdPeriph 函数 / 宏 | 对应 HAL 替代方式 |
|------------------------|------------------|
| `RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOB, ENABLE);` | `__HAL_RCC_GPIOB_CLK_ENABLE();` |
| `GPIO_Init()` / `GPIO_InitStructure` 保持结构体一致,但 HAL 使用 `HAL_GPIO_Init()` | ✅ 已兼容 |
| `GPIO_SetBits(GPIOB, GPIO_Pin_10|GPIO_Pin_11)` | `HAL_GPIO_WritePin(GPIOB, GPIO_PIN_10 | GPIO_PIN_11, GPIO_PIN_SET)` |
| `DelayMs()` 自定义函数 | 推荐使用 HAL 的 `HAL_Delay()` |
此外,将引脚宏定义从 `GPIO_Pin_10` 改为 `GPIO_PIN_10` 等 HAL 库标准格式。
---
### 修改后的 HAL 版本核心代码如下:
```c
#include "main.h" // HAL 库头文件
#include "oled.h"
#include "stdlib.h"
#include "oledfont.h"
#include "delay.h"
// OLED显存操作逻辑不变
/**********************************************
* IIC Start
**********************************************/
void IIC_Start(void)
{
OLED_SCLK_Set();
OLED_SDIN_Set();
OLED_SDIN_Clr();
OLED_SCLK_Clr();
}
/**********************************************
* IIC Stop
**********************************************/
void IIC_Stop(void)
{
OLED_SCLK_Set();
OLED_SDIN_Clr();
OLED_SDIN_Set();
}
/**********************************************
* IIC Wait Ack
**********************************************/
void IIC_Wait_Ack(void)
{
OLED_SCLK_Set();
OLED_SCLK_Clr();
}
/**********************************************
* Write IIC Byte
**********************************************/
void Write_IIC_Byte(unsigned char IIC_Byte)
{
unsigned char i;
unsigned char da = IIC_Byte;
OLED_SCLK_Clr();
for (i = 0; i < 8; i++)
{
if ((da & 0x80) != 0)
OLED_SDIN_Set();
else
OLED_SDIN_Clr();
da <<= 1;
OLED_SCLK_Set();
OLED_SCLK_Clr();
}
}
/**********************************************
* Write Command/Data
**********************************************/
void OLED_WR_Byte(unsigned dat, unsigned cmd)
{
IIC_Start();
Write_IIC_Byte(0x78); // Slave address
IIC_Wait_Ack();
Write_IIC_Byte(cmd ? 0x40 : 0x00); // Data/Command 控制字
IIC_Wait_Ack();
Write_IIC_Byte(dat);
IIC_Wait_Ack();
IIC_Stop();
}
/**********************************************
* OLED Init(HAL版)
**********************************************/
void OLED_Init(void)
{
GPIO_InitTypeDef GPIO_InitStruct = {0};
/* 使能 GPIOB 时钟 */
__HAL_RCC_GPIOB_CLK_ENABLE();
/* 配置 SCL(SCK) 和 SDA(SDA) 引脚 */
GPIO_InitStruct.Pin = GPIO_PIN_10 | GPIO_PIN_11;
GPIO_InitStruct.Mode = GPIO_MODE_OUTPUT_PP;
GPIO_InitStruct.Pull = GPIO_NOPULL;
GPIO_InitStruct.Speed = GPIO_SPEED_FREQ_HIGH;
HAL_GPIO_Init(GPIOB, &GPIO_InitStruct);
/* 默认高电平 */
HAL_GPIO_WritePin(GPIOB, GPIO_PIN_10 | GPIO_PIN_11, GPIO_PIN_SET);
HAL_Delay(800); // 使用 HAL 延时函数替代 DelayMs
OLED_WR_Byte(0xAE, OLED_CMD); // display off
OLED_WR_Byte(0x00, OLED_CMD); // low column address
OLED_WR_Byte(0x10, OLED_CMD); // high column address
OLED_WR_Byte(0x40, OLED_CMD); // start line address
OLED_WR_Byte(0xB0, OLED_CMD); // page address
OLED_WR_Byte(0x81, OLED_CMD); // contract control
OLED_WR_Byte(0xFF, OLED_CMD); // contrast
OLED_WR_Byte(0xA1, OLED_CMD); // segment remap
OLED_WR_Byte(0xA6, OLED_CMD); // normal/inverse
OLED_WR_Byte(0xA8, OLED_CMD); // multiplex ratio
OLED_WR_Byte(0x3F, OLED_CMD); // duty = 1/64
OLED_WR_Byte(0xC8, OLED_CMD); // com scan direction
OLED_WR_Byte(0xD3, OLED_CMD); // display offset
OLED_WR_Byte(0x00, OLED_CMD);
OLED_WR_Byte(0xD5, OLED_CMD); // set osc division
OLED_WR_Byte(0x80, OLED_CMD);
OLED_WR_Byte(0xD9, OLED_CMD); // Set Pre-Charge Period
OLED_WR_Byte(0xF1, OLED_CMD);
OLED_WR_Byte(0xDA, OLED_CMD); // com pin config
OLED_WR_Byte(0x12, OLED_CMD);
OLED_WR_Byte(0xDB, OLED_CMD); // set Vcomh
OLED_WR_Byte(0x30, OLED_CMD);
OLED_WR_Byte(0x8D, OLED_CMD); // charge pump enable
OLED_WR_Byte(0x14, OLED_CMD);
OLED_WR_Byte(0xAF, OLED_CMD); // display on
OLED_Clear();
}
```
> 其他如字符显示、图片绘制等函数无需改动硬件相关部分,只需替换底层 `OLED_WR_Byte` 调用即可适配。
---
知识点
1. **I²C通信协议**
一种半双工同步串行通信协议,常用于连接低速外围设备,如OLED屏、传感器等。
2. **HAL库IO操作**
HAL提供统一的GPIO读写接口,如`HAL_GPIO_WritePin()`,替代直接寄存器操作,提升代码可移植性。
3. **延时函数的标准化**
`HAL_Delay()` 是 HAL 提供的标准毫秒级延时函数,依赖于系统滴答定时器(SysTick),替代自定义延时提高准确性。
阅读全文
相关推荐
















