当前位置:首页 » 编程语言 » c语言中0xc7
扩展阅读
webinf下怎么引入js 2023-08-31 21:54:13
堡垒机怎么打开web 2023-08-31 21:54:11

c语言中0xc7

发布时间: 2023-04-14 06:23:06

❶ 请C语言高手来看看小弟的简单程序怎么错这么多啊!求助!!!

你的程序编译族桐不会报错,但是计算出轮穗亮来的最大值和最小值不对,我给你改过了,你看看吧。
#include<stdio.h>
void abc(float x[],int y,float *sum,float *avg,float *max,float *min)
{
float *p;
int i;
*max=x[0];
*min=x[0];
p=x;
for(i=0;i<y;i++)
{
*sum=*sum+x[i];
if(*(p+i)>*max)
*max=*(p+i);
if(*(p+i)<*min)
*min=*(p+i);
}
*avg=*sum/y;
}

void main()
{
float num[80],he=0,pingjun,zuida,zuixiao;
int i,j;
printf("请输入你要输入数字的个数:\n");
scanf("%d",&j);
printf("请输入%d个数字:\n",j);
for(i=0;i<j;i++) scanf("%f",&num[i]);
abc(num,j,&he,&pingjun,&zuida,&zuixiao);
printf("它们的和是:%.2f\n它们腊宽的平均值是:%.2f\n它们的最大值是:%.2f\n它们的最小值是:%.2f\n",he,pingjun,zuida,zuixiao);
}

❷ VC++6.0编译C语言出错

程序没有错误,打出这种调试信息是正常现象,程序已经执行完毕,雀晌跟踪一下即可。
参考:
'ntdll.dll', no matching symbolic information found
在运行程序的时候,会出现一系列的information found的提示 信息,这并不是程序代码错误的原因,是调试本身的问题,如果在程或慎序最后,出现
The program 'C:\Documents and Settings\yytju\桌面\boost_vc\Debug\boost_vc.exe' has exited with code 0 (0x0)
类似于这样的code是0的语句,则表明程序是对的.
但是,有一个问题就衫岁敬是这样的话,表现形式是黑屏一闪,如果想看到结果,就在main最后一句之前加一个断点,则可以看到结果了

❸ 嵌入式温湿度传感器C语言代码求帮忙注释

#include "ioCC2430.h" //包含头文件,相应的板子以及传感器一些信息

#include "hal.h"

#include <math.h>

//#include <intrins.h>

#include <stdio.h>


typedef union //定义联合体,

{

unsigned int i;

float f;

} value; //定义联合体类型名称为value


#define noACK 0

#define ACK 1

#define STATUS_REG_W 0x06 //0x06 = 0000 0110

#define STATUS_REG_R 0x07 //0x07 = 0000 0111

#define MEASURE_TEMP 0x03 //0x03 = 0000 0011

#define MEASURE_HUMI 0x05 //0x05 = 0000 0101

#define RESET 0x1e //0x1e = 0001 1110

#define SDA P1_6 //定义SDA代表的是P1_6脚

#define SCL P1_7

#define begin P2_0

unsigned char d1,d2,d3,d4,d5,d6,d7; //定义无符号字符型变量


void Wait(unsigned int ms) //定义wait函数,主要用于软件循环,延时作用

{

unsigned char g,k;

while(ms)

{

for(g = 0;g <= 167; g++)

{

for(k = 0;k <= 48; k++);

}

ms--;

}

}


void QWait() //1us的延时

{

asm("NOP"); //加入汇编操作语句,空操作,主要用于机器周期执行

asm("NOP");

asm("NOP");

asm("NOP");

asm("NOP");

asm("NOP");

asm("NOP");

asm("NOP");

asm("NOP");

asm("NOP");

asm("NOP");

}


void initUART(void) //初始化单片机的串口

{

IO_PER_LOC_USART0_AT_PORT0_PIN2345(); //具体函数的定义与用法,你得参考头文件中的程序代码了

IO_DIR_PORT_PIN(1, 6, IO_OUT);

IO_DIR_PORT_PIN(1, 7, IO_OUT);

//IO_IMODE_PORT_PIN(1, 6, IO_IMODE_TRI);

//IO_IMODE_PORT_PIN(1, 7, IO_IMODE_TRI);

IO_DIR_PORT_PIN(2, 0, IO_OUT);

IO_FUNC_PORT_PIN(2, 0, IO_FUNC_GIO);

//SET_MAIN_CLOCK_SOURCE(RC);

SET_MAIN_CLOCK_SOURCE(CRYSTAL);

UART_SETUP(0, 115200, HIGH_STOP); //设置传输数据的波特率115200

UTX0IF = 1;

U0CSR |= 0XC7; //U0CSR = U0CSR | 0x1010 0111 (进行位或操作)

IEN0 |= 0x84;

SDA = 1;

SCL = 0;

}


int putchar (int c) //定义输入字符函数,给的参数是一个整型的数

{

if (c == ' ') //判断参数c的值是否和' '的值相等

{

while (!UTX0IF); //执行的时候UTX0IF的值是0,此处不是很理解?

UTX0IF = 0; //给UTX0IF赋0

U0DBUF = 0x0d; //U0DBUF赋值0x0d = 0000 1011

}

while (!UTX0IF);

UTX0IF = 0;

return (U0DBUF = c); //如果c的值不是' '也就是换行符的时候,将c的值传递到U0DBUF寄存器中

}


char s_write_byte(unsigned char value) //定义写字节函数(8位)

{

unsigned char i,error = 0;

for (i = 0x80;i > 0;i /= 2) //i 赋初始值0x80 = 128, 执行判断是i > 0,执行语句是i = i / 2; 即i = 128,64,32,16,8,4,2,1,0.5(0),8位

{

if (i & value)

SDA = 1;

else

SDA = 0;

SCL = 1; //此时SCL端口处,也就是p1_7引脚处是高电平

QWait(); //因为写入需要时间,所以程序之中加入下面几条语句

QWait();

QWait();

QWait();

QWait();

SCL = 0; //使能p1_7眼角处低电平,使的数据写入(具体需要看单片机控制芯片的手册

asm("NOP");

asm("NOP");

}

SDA = 1;

SCL = 1;

asm("NOP");

error = SDA;

QWait();

QWait();

QWait();

SDA = 1;

SCL = 0;

return error;

}


char s_read_byte(unsigned char ack) //读取数据,按照字节位的顺序读取(8位)128 = 1000 0000 ,64 = 0100 0000, 32 = 0010 0000 ,16 = 0001 0000, 8 = 0000 1000, 4 = 0000 0100 , 2 = 0000 0010, 1 = 0000 0001

{

unsigned char i,val = 0;

SDA= 1;

for(i = 0x80;i > 0;i /= 2) //同上

{

SCL = 1;

if (SDA) //判断SDA处是否有高电平

val = (val | i); //进行或操作

else

val = (val | 0x00);

SCL = 0;

QWait();

QWait();

QWait();

QWait();

QWait();

}

SDA = !ack;

SCL = 1;

QWait();

QWait();

QWait();

QWait();

QWait();

SCL = 0;

SDA = 1;


return val; //返回读取到的数据,一个字节,八位

}


void s_transstart(void) //传输使能函数,就是给控制器引脚处相应电平,使对应模块工作

{

SDA = 1;

SCL = 0;

QWait();

QWait();

SCL = 1;

QWait();

QWait();

SDA = 0;

QWait();

QWait();

SCL = 0;

QWait();

QWait();

QWait();

QWait();

QWait();

SCL = 1;

QWait();

QWait();

SDA = 1;

QWait();

QWait();

SCL = 0;

QWait();

QWait();

}


void s_connectionreset(void) //复位操作函数

{

unsigned char i;

SDA = 1;

SCL = 0;

for(i = 0;i < 9; i++)

{

SCL = 1;

QWait();

QWait();

SCL = 0;

QWait();

QWait();

}

s_transstart(); //调用开始函数

}


char s_measure(unsigned char *p_value, unsigned char *p_checksum, unsigned char mode) //函数,主要统计传输的数据个数

{

unsigned er = 0;

unsigned int i,j;

s_transstart();

switch(mode)

{

case 3 :er += s_write_byte(3);

break;

case 5 :er += s_write_byte(5);

break;

default :break;

}

for(i = 0;i < 65535;i++)

{

for(j = 0;j < 65535;j++)

{if(SDA == 0)

{

break;

}

}

if(SDA == 0)

{

break;

}


}

if(SDA)

{

er += 1;

}

*(p_value) = s_read_byte(ACK);

*(p_value + 1) = s_read_byte(ACK);

*p_checksum = s_read_byte(noACK);

d6 = *(p_value);

d7=*(p_value + 1);

return er;

}


void calc_sth11(float *p_humidity ,float *p_temperature)//计算温度值

{

const float C1 =- 4.0;

const float C2 =+ 0.0405;

const float C3 =- 0.0000028;

const float T1 =+ 0.01;

const float T2 =+ 0.00008;

float rh =* p_humidity;

float t =* p_temperature;

float rh_lin;

float rh_true;

float t_C;

t_C = t * 0.01 - 44.0 ;

rh_lin = C3 * rh * rh + C2 * rh + C1;

rh_true = (t * 0.01 - 40.0 - 25) * (T1 + T2 * rh) + rh_lin;

if(rh_true > 100)

{

rh_true = 100;

}

if(rh_true < 0.1)

{

rh_true = 0.1;

}

*p_temperature = t_C;

*p_humidity = rh_true;

}


void main() //主函数

{

value humi_val,temp_val; //声明两个联合体变量

unsigned char error,checksum; //声明两个无符号的字符型变量

initUART(); //初始化串口

P1INP |= 0xC0; //初始化P1引脚 , 0xC0 = 1010 0000 ,使P1_7和P1_5引脚为1

begin = 0;

s_connectionreset();

while(1) //无限循环操作

{

error = 0;

error += s_measure((unsigned char*) &humi_val.i,&checksum,5); //读入串口的数据进行温度的计算

d1 = d6;

d2 = d7;

error += s_measure((unsigned char*) &temp_val.i,&checksum,3);

d3 = d6;

d4 = d7;

if(error != 0)

s_connectionreset();

else

{

humi_val.f = (float)humi_val.i;

temp_val.f = (float)temp_val.i;

humi_val.f = d1 * 256 + d2;

temp_val.f = d3 * 256 + d4;

calc_sth11(&humi_val.f,&temp_val.f);

printf("temp:%5.1fC humi:%5.1f%% ",temp_val.f,humi_val.f);

// printf("t1:%x h1:%x ",d1,d2);

//printf("t2:%x h2:%x ",d3,d4);

}

Wait(150);

}

}


❹ 单片机C语言中0xfc,0xf9,0xf3,0xe7,0xcf,0x9f,0x3f,0x7f,0xff,这些数是什么意思,有什么作用

0x表示十六进制的意思,就是后面两位数是十六进制的数

❺ C语言 位运算

###位运算的逻辑:

1:(位与)运算符(&):双目操作符,当两个位进行相与时,只有两者都为“1”时结果才为“1”(即:全真为真,一假为假),运算规则如下:

左运算量                        右运算量                        &运算结果

    0                    &                0                     =                    0

    0                    &                 1                    =                    0

    1                    &                  0                   =                    州明 0

    1                    &                   1                  =                     1

运算:

例:

#include  <stdio.h>

int main(int     argc,char    *crgv[]){

    unsigned            char    x=0156,    y=0xaf,   z;

z=x&y;

printf("%d",z)

}

结果为:0x2e

运算过程:态燃0156(8进制)==0000 0110 1110(2进制);

进行                                          &(位与运算)

                    0xaf(16进制)     ==0000 1010    1111(2进制);

结果:0000    0010    1110(2进制)==0x2e(十六进制);

2:位或运算符(|):

双目操作符,当两个 位  进行相或时,两者中只要有一方为“1”,结果就为“1”(即:一真为真,两假为假),运算规则如下:

    左运算量                            右运算量                           (|) 运算结果

            0                    |                     0                        =                            0

            1                    |                    1                        =                            1

            0                    |                    1                    =                                1

            1                    |                     1                    =                               1

例:

#include <stdio.h>

int main(int argv,char  *argc[]){

unsigned char x=027,y=0x75;

z=x|y;

}

运行过程:

027(8进制)=0001   0111(2进制)

进行                    |(位或运算)

0x75(16进制)=0111    0101(2进制)

结果:0111   0111(2进制)=0x77(16进制)

3.异或运算(^):

    当两个位进行异或时,只要两者相同,结果为“0”,否者结果为“1”,(即:同假异真)运算规则如下:

左运算量                            右运算量                           (^) 运算结果

            0                    ^                    0                        =                            0

            1                    ^                    1                      帆迹虚   =                            0

            0                    ^                    1                          =                            1

            1                    ^                    0                          =                             1

例:

#include

int main(int argv,char  *argc[]){

unsigned(无符号)     char    x=25,y=0263,z;

z=x^y;

printf("%d\n",z);

}

运算过程:

25(十进制)=0001    1001(二进制)

运算                    ^(异或运算)

0263(8进制)=1011    0011(二进制)

结果:1010     1010(二进制)=0252(8进制)

4:移位操作符(“<<”   或   ">>"):位移位运算的一般形式:<运算量><运算符><表达式>;

<运算量>必须为整型结果数值:

<运算符>为左移位(<<)或 右移位(>>)运算;

<表达式>也必须为整型结果数值;

移位操作就是把一个数值左移或右移若干位;假如左移n位,原来值最左边的n位数被丢掉,右边n卫补“0” ;右移操作就是和左移操作移动方向相反;

符号位的处理方法:

(1):逻辑移位,不考虑符号问题,原数值右移n位后,左边空出的n歌位置,用0填充;

(2):算术移位,原来值进行了右移操作后,需要保证符号位不变,因此,右移n位后,左边空出的n个位置,用原数值的符号位填充。原来若是负数,则符号位为“1”,填充的位也是“1”;原来若是正数,则符号位为“0”,填充的位也是“0”,这样保证移位后的数据与原数正负相同;

例:“1000   1001”将其右移两位,逻辑移位的结果为“0010  0010”,算术移位为:“1110  0010”;

将其左移两位,逻辑移位和算术移位的结果为:“0010  0100”;

(3)***补充:特定位清零(由“1”变成“0”)用 位与  操作;特定位变“1”(由“0”变成“1”)用  位或操作;

例:

a、请把0xd5的第2位进行清零操作

0xd5=1101 0101=>1101 0001

    1111 1011

    ~0000 0100

    =0000 0001<<2

  ~(0x01<<2)&0xd5

b、请把0xed的第3位进行清零操作

0xed=1110 1101=>1110 0101

    1111 0111

    ~

    0000 1000

=    0000 0001<<3

    ~(0x01<<3)&0xed

c、请把0x7d的第2-4位进行清零

0x7d=0111 1101=>0110 0001

    1110 0011

    ~

    0001 1100

=

    0000 0111<<2

~(0x07)&0x7d

d、请把0x7d的第2位和第3位进行清零

0x7d=0111 1101=>0111 0001

    1111 0011

~

    0000 1100

    0000 0011<<2

~(0x03<<2)&0x7d

e、请把0xc7的第4位进行置1

0xc7=1100 0111=>1101 0111

    0001 0000

    =0000 0001<<4

=~(0x01<<4)|0xc7

f、请把0x87的第3位进行置1 

0x87=1000 0111=>1000 1111

    0000 1000

~(0x01<<3)|0x87

g、请把0xc7的第3—5位置1

0xc7=1100 0111=>1111 1111

    0011 1000

    0000 0111<<3

~(0x07<<3)|0x87

❻ 单片机C语言中0xfc,0xf9,0xf3,0xe7,0xcf,0x9f,0x3f,0x7f,0xff,有什么作用

0x表示十六进制的意思,就是后面两位数是十六进制的数

❼ C语言getc()函数是用来获得文件流的一个一个字符,字符是一个字节为什么可以把中文给读出来

这个问题。比较者渣复杂。
简单的说一下吧。
第一个:汉字的编码是有好几种的。UTF-8,UNICODE之类的。所有仔者的汉字编码都不止一个字节。
有的编码汉字是用2个字节表示的。有的更多。
有的编码方式中汉字的念嫌薯字节数甚至不固定。有的汉字字节2个,有的3个4个。
你能读取出来的主要原因是因为读取到固定的几个字节后,系统会翻译一下显示出汉字。
比如读取的是一种编码是2个字节的汉字。系统读取2个字节后会翻译,显示在控制台上。
大概就是这个意思。如果要深入了解的话,那就必须要你自己去学了。

❽ 温度显示C程序修改

#include<reg52.h>
#include<ds1820.h>
#include"哗搏disp.h"
#define date P0
//各数据口定义
sbit disp1=P2^7;
sbit disp2=P2^6;
sbit disp3=P2^5;
sbit disp4=P2^4;
sbit key1=P1^4;
sbit key2=P1^5;
sbit key3=P1^6;
sbit beerr=P3^7;
sbit jdx=P3^4;
sbit dj=P3^5;
unsigned char disp[12]={0xc0,0xf9,0xa4,0xb0,0x99,0x92,0x82,0xf8,0x80,0x90,0xc7,0x89}; //数码管显示内码
unsigned char disptemp[4]={0,2,1,4};
unsigned char dispnum=0;
char THtem=0,TLtem=0;
float temtemp;/****************************************************************
延时程序
*****************************************************************/
delay(unsigned int ms)
{
unsigned char i;
while(--ms)
for(i=0;i<200;i++);}
/**************************************************************
读取温度后显示程序铅芦搏
***************************************************************/
display()
{
date=disp[disptemp[0]];
disp1=0;
disp2=1;
disp3=1;
disp4=1;
delay(3);
date=disp[disptemp[1]]&0x7f;
disp1=1;
disp2=0;
disp3=1;
disp4=1;
delay(3);
date=disp[disptemp[2]];
disp1=1;
disp2=1;
disp3=0;
disp4=1;
delay(3);
date=disp[disptemp[3]];
disp1=1;
disp2=1;
disp3=1;
disp4=0;
delay(3);

}/**************************************************************
读取温度后显示程序
***************************************************************/
display2()
{
date=disp[disptemp[0]];
disp1=0;
disp2=1;
disp3=1;
disp4=1;
delay(3);
date=disp[disptemp[1]]&0x7f;
disp1=1;
disp2=0;
disp3=1;
disp4=1;
delay(3);
date=disp[disptemp[2]];
disp1=1;
disp2=1;
disp3=0;
disp4=1;
delay(3);
date=0xc7;
disp1=1;
disp2=1;
disp3=1;
disp4=0;
delay(3);

}
/**************************************************************
读取温度后显示槐祥程序
***************************************************************/
display3()
{
date=disp[disptemp[0]];
disp1=0;
disp2=1;
disp3=1;
disp4=1;
delay(3);
date=disp[disptemp[1]]&0x7f;
disp1=1;
disp2=0;
disp3=1;
disp4=1;
delay(3);
date=disp[disptemp[2]];
disp1=1;
disp2=1;
disp3=0;
disp4=1;
delay(3);
date=0x89;
disp1=1;
disp2=1;
disp3=1;
disp4=0;
delay(3);

}
/***************************************************************
设置上下限时的温度显示程序
****************************************************************/
display1(dat1,dat2,dat3,dat4)
{
date=dat1;
disp1=0; //第一位数码管显示
disp2=1;
disp3=1;
disp4=1;
delay(3);
date=dat2;
disp1=1;
disp2=0; //第二位数码管显示
disp3=1;
disp4=1;
delay(3);
date=dat3;
disp1=1;
disp2=1; //第三位数码管显示
disp3=0;
disp4=1;
delay(3);
date=dat4;
disp1=1;
disp2=1;
disp3=1;
disp4=0; //第四位数码管显示
delay(3);

}
/*********************************************************
***************蜂鸣器*************************************
**********************************************************/
void beer()
{
unsigned char i;
beerr=!beerr;
for(i=0;i<60;i++);
}
/********************************************************
主程序
*********************************************************/
main()
{
bit i=0;
delay(1000); //开机延时
ReadTHTLTemperature(&TLtem,&THtem); //从DS18B20里读取温度上下限度
while(1){
if(key3==0){
delay(10);
if(key3==0){
dispnum++;
if(dispnum>=3)
dispnum=0;
P2=0XFF;
while(key3==0)beer();
WriteTHTLTemperature(&TLtem,&THtem); //当设置完温度上下限后写入DS18B20
}
}
if(key1==0){
delay(10);
if(key1==0){ if(dispnum==3||dispnum==4)
dispnum=0;
if(dispnum==1){ //设置温度加
THtem++;
if(THtem>=100)
THtem=0;
} if(dispnum==2){
TLtem++;
if(TLtem>=100)
TLtem=0;
} P2=0XFF;
while(key1==0)beer();
}
}
if(key2==0){
delay(10);
if(key2==0){ i=!i; if(dispnum==3&&i==0)
dispnum=4;
if((dispnum==0||dispnum==4)&&i==1)
dispnum=3;
if(dispnum==1){
THtem--;
if(THtem<=0) //设置温度减
THtem=99;
} if(dispnum==2){
TLtem--;
if(TLtem<=0)
TLtem=99;
}
P2=0XFF;
while(key2==0)beer();
}
}

if(dispnum==0){ //只显示温度状态
temtemp=ReadTemperature();
if((temtemp>TLtem)&&(temtemp<THtem))
{
display();
}

temp_data_turn(temtemp);
if((temtemp>TLtem)&&(temtemp<THtem))
{
display();
jdx=0;
dj=0;
}
// display();
if(temtemp<TLtem)
{
jdx=1;
dj=0;
display2();
} //
if(temtemp>THtem)
{
jdx=0;
dj=1;
display3();
} //

}
if(dispnum==1||dispnum==4){ //数码管显示设置上限温度 display1(0xf8,0x89,disp[THtem/10],disp[THtem%10]); }
if(dispnum==2||dispnum==3){ //数码管显示设置下限温度
display1(0xf8,0xc7,disp[TLtem/10],disp[TLtem%10]);
}
}

}