㈠ c语言综合实验报告 帮我弄一个
姓名 *** **学 院 ** 专业 052 班 2007 年 11 月 24 日实验内容实验五 指导老师 陈老师一、实验内容及要求:编译运行习题5-3,观察x、y变量的值。实现客户机类(类名为CLIENT),其中包含的成员有:字符型静态数据成员ServerName,用来保存服务器名称;整型静态数据成员ClientNum,记录已定义的客户数量;静态函数ChangeServerName(),用来改变服务器名称。在头文件client.h中声明这个类,在文件client.cpp中实现,在文件test.cpp中测试这个类,观察相应的成员变量取值的变化情况。二、实验目的:1、复习类的声明和使用、掌握对象的声明和使用;2、学习构造函数和析构函数的使用,观察构造函数和析构函数的执行过程。三、程序://client.hclass Client{public: Client(); ~Client(); static ChangeServerName(char *); //改变服务器名称 char * GetServerName(); //返回服务器名称 int GetClientNum (); //返回客户机数量protected: static char ServerName[20]; //服务器名称 static int ClientNum; //存放服务器数量};///////////////////////////////////////////////////////client.cpp# include <iostream># include <cstring># include "client.h"using namespace std;static char *ServerName = "";int Client::ClientNum = 0;Client::Client(){ClientNum ++;}Client::~Client(){}void Client::ChangeServerName(char * names) //改变服务器名称{strcpy(ServerName,names);}char * GetServerName() //返回服务器名称{return ServerName;}int GetClientNum () //返回服务器数量{return ClientNum;}//////////////////////////////////////////////////////////test.cpp# include <iostream># include "client.cpp"using namespace std;void main() //用于测试的主函数{ Client threeclient[3]; char namestr[20]; //临时存放服务器名称 cout<<"定义了3个客户"<<endl; cout<<"请输入新服务器名称:"<<endl; cin>> namestr; CC.ChangeServerName(namestr); cout<<"服务器的名称是"<<Client::GetServerName()<<endl; cout<<"客户数量为"<<CC.GetClientNum ();}思考题:(1)C语言有五种基本数据类型:字符、整型、单精度实型、双精度实型和空类型。结构体可以定义自己所需特殊类型.其他类型是已经定义好,不可修改的,而结构体是根据自己的需要定义的特殊的类型.(3)采用了循环,复合语句.
㈡ C语言实验 结构体与文件程序设计
//main.c文件#include<stdio.h>#include<stdlib.h>#define BufLen 20#define KeChengCount 3typedef struct tagStuInfor{char xh[BufLen]; //学号 char xm[BufLen]; //姓名 char kchm[KeChengCount][BufLen]; //课程名 float pshchj[KeChengCount]; //平时成绩 float kshchj[KeChengCount]; //考试成绩 float zpchj[KeChengCount]; //总评成绩float zf; }StudentInformation;typedef struct tagBookInfor{char shm[BufLen]; //书名 float dj; //单价 }BookInformation;void shurustu();void zongfen();void shuchumaxmin();void sortbook();void freeall();//学生数,书数 int xshsh,shsh;StudentInformation *ptstu=NULL;BookInformation *ptbook=NULL;int main(){char in[]="data.txt",out[]="T_data.txt";int i;float chjs[6],zf;FILE *fin,*fout;printf("250这个数字太不好了,能换成350吗?\n\n");shurustu();zongfen();shuchumaxmin();printf("请输入书数:");scanf("%d",&shsh);ptbook=(BookInformation*)calloc(shsh,sizeof(BookInformation));for(i=0;i<shsh;i++){printf("请输入第%d本书的书名:",i+1);scanf("%s",ptbook[i].shm);printf("请输入第%d本书的单价:",i+1);scanf("%f",&ptbook[i].dj);}printf("\n");sortbook(); printf("按书的单价升序排序后的结果:\n书名\t单价\n");for(i=0;i<shsh;i++){printf("%s\t%.2f\n",ptbook[i].shm,ptbook[i].dj);}fin=fopen(in,"r");fout=fopen(out,"w");while(!feof(fin)){for(i=0;i<6;i++){fscanf(fin,"%f",&chjs[i]);}zf=0.2*(chjs[0]+chjs[1]+chjs[2])+0.8*(chjs[3]+chjs[4]+chjs[5]);printf("%.2f\n",zf);fprintf(fout,"%.2f\r\n",zf);}printf("\n");fclose(fin);fclose(fout);freeall(); system("PAUSE"); return EXIT_SUCCESS; }void shurustu(){int i;printf("请输入学生的个数:");scanf("%d",&xshsh);ptstu=(StudentInformation*)calloc(xshsh,sizeof(StudentInformation));for(i=0;i<xshsh;i++){strcpy(ptstu[i].kchm[0],"C语言");strcpy(ptstu[i].kchm[1],"高等数学");strcpy(ptstu[i].kchm[2],"英语");printf("请输入第%d个学生的学号:",i+1);scanf("%s",ptstu[i].xh);printf("请输入第%d个学生的姓名:",i+1);scanf("%s",ptstu[i].xm);printf("请输入第%d个学生的C语言课程的平时成绩和考试成绩:",i+1);scanf("%f %f",&ptstu[i].pshchj[0],&ptstu[i].kshchj[0]);printf("请输入第%d个学生的高等数学课程的平时成绩和考试成绩:",i+1);scanf("%f %f",&ptstu[i].pshchj[1],&ptstu[i].kshchj[1]);printf("请输入第%d个学生的英语课程的平时成绩和考试成绩:",i+1);scanf("%f %f",&ptstu[i].pshchj[2],&ptstu[i].kshchj[2]);}printf("\n");}void zongfen(){int i;for(i=0;i<xshsh;i++){ptstu[i].zpchj[0]=0.2*ptstu[i].pshchj[0]+0.8*ptstu[i].kshchj[0];ptstu[i].zpchj[1]=0.2*ptstu[i].pshchj[1]+0.8*ptstu[i].kshchj[1];ptstu[i].zpchj[2]=0.2*ptstu[i].pshchj[2]+0.8*ptstu[i].kshchj[2];ptstu[i].zf=ptstu[i].zpchj[0]+ptstu[i].zpchj[1]+ptstu[i].zpchj[2];printf("%s的%s,%s,%s的总评成绩是:",ptstu[i].xm,ptstu[i].kchm[0],ptstu[i].kchm[1],ptstu[i].kchm[2]);printf("%.2f,%.2f,%.2f\n",ptstu[i].zpchj[0],ptstu[i].zpchj[1],ptstu[i].zpchj[2]);printf("%s的总分是:%.2f\n",ptstu[i].xm,ptstu[i].zf);}printf("\n");}void shuchumaxmin(){int i,min,max;min=max=0;for(i=1;i<xshsh;i++){if(ptstu[i].zf<ptstu[min].zf){min=i;}if(ptstu[i].zf>ptstu[max].zf){max=i;}}printf("总分最高的学生的信息:\n学号\t姓名\t");printf("%s(平时)\t%s(平时)\t%s(平时)",ptstu[max].kchm[0],ptstu[max].kchm[1],ptstu[max].kchm[2]);printf("\t%s(考试)\t%s(考试)\t%s(考试)\t总分\n",ptstu[max].kchm[0],ptstu[max].kchm[1],ptstu[max].kchm[2]); printf("%s\t%s\t",ptstu[max].xh,ptstu[max].xm);printf("%.2f\t%.2f\t%.2f\t",ptstu[max].pshchj[0],ptstu[max].pshchj[1],ptstu[max].pshchj[2]);printf("%.2f\t%.2f\t%.2f\t%.2f\n\n",ptstu[max].kshchj[0],ptstu[max].kshchj[1],ptstu[max].kshchj[2],ptstu[max].zf);printf("总分最低的学生的信息:\n学号\t姓名\t");printf("%s(平时)\t%s(平时)\t%s(平时)",ptstu[min].kchm[0],ptstu[min].kchm[1],ptstu[min].kchm[2]);printf("\t%s(考试)\t%s(考试)\t%s(考试)\t总分\n",ptstu[min].kchm[0],ptstu[min].kchm[1],ptstu[min].kchm[2]); printf("%s\t%s\t",ptstu[min].xh,ptstu[min].xm);printf("%.2f\t%.2f\t%.2f\t",ptstu[min].pshchj[0],ptstu[min].pshchj[1],ptstu[min].pshchj[2]);printf("%.2f\t%.2f\t%.2f\t%.2f\n\n",ptstu[min].kshchj[0],ptstu[min].kshchj[1],ptstu[min].kshchj[2],ptstu[min].zf);}void sortbook(){int i,j,min;BookInformation t;for(i=0;i<shsh-1;i++){min=i;for(j=i+1;j<shsh;j++){if(ptbook[j].dj<ptbook[min].dj){min=j;}}t=ptbook[i];ptbook[i]=ptbook[min];ptbook[min]=t;}}void freeall(){if(NULL!=ptstu){free(ptstu);}if(NULL!=ptbook){free(ptbook);}}//data.txt文件50 65 70 88 97 8066 87 95 46 88 9777 82 65 58 91 5878 87 91 48 66 70
㈢ c语言实验:查找c盘中的所有文件夹,对于子文件夹中的文件也要进行查找输出。
优化了一下,但还是有bug,需要细查#include<io.h>#include<stdio.h>#include<string.h>#define_A_SUBDIR0x10/*Subdirectory*/voidsearch(char*str1){longflag1=0;longhandle1;chars1[]="\",s2[]="*.*",s3[100],name[100];struct_finddata_tffblk1;strcat(str1,s1);strcpy(s3,str1);strcat(str1,s2);handle1=_findfirst(str1,&ffblk1);while(!flag1){if(strcmp(ffblk1.name,".")&&strcmp(ffblk1.name,"..")){if(ffblk1.attrib==_A_SUBDIR){printf("%sisasub-directory",ffblk1.name);strcpy(name,ffblk1.name);strcat(s3,name);search(s3);}else{printf("%s",ffblk1.name);}}flag1=_findnext(handle1,&ffblk1);}}voidmain(){//struct_finddata_tffblk;charstr[200]="C:";//必须是数组,不然空间不够search(str);}
㈣ C语言实验题,文件方面知识没学好,望大神帮忙:
太晚了,只帮你把程序架起来了,你自己先往里填代码吧,关于文件的库函数调用也很简单的,fopen(),fwrite();fread(),fclose(),FILE *文件指针等 ,你要是在linux下边更方便 ,man 这几个函数名就能看到原型,要不你下载一个C库函数大全的PDF,找到文件操作那一节,找到这几个函数原型,其中要注意的几项提醒你一下,在打开文件的时候,有几个参数的选项,像打开标志和打开模式等等,其实我要是完全帮你做了,一点意义都没有。#include<stdio.h>enum MENU_ACT{ INPUT=1,TOTAL_LES,AVR_LES,TOTAL_STU,AVR_STU,SORT_H,SORT_L,SORT_ID,SORT_N,SEARCH_ID,SEARCH_NAME,TONGJI,SAVE,READFILE };struct students{ int id; char name[16]; float mt; float en; float ph;} ;void do_input();void do_total_lession();void do_avrage_lession();void do_total_students();void do_avrage_students();void do_sort_high_to_low();void do_sort_low_to_high();void do_sort_student_id();void do_sort_student_name();void do_search_by_id();void do_search_by_name();void do_statistics();void do_save();void do_read_from_file();void do_input(){}void do_total_lession(){}void do_avrage_lession(){}void do_total_students(){}void do_avrage_students(){}void do_sort_high_to_low(){}void do_sort_low_to_high(){}void do_sort_student_id(){}void do_sort_student_name(){}void do_search_by_id(){}void do_search_by_name(){}void do_statistics(){}void do_save(){}void do_read_from_file(){}int main(void){ int cmd; while(1) { putchar('\n'); printf("*****************************************************\n"); printf("* 录入:1, 计算每门课程总分:2 计算每门课程平均分:3\n"); printf("* 计算每个学生的总分:4, 计算每个学生的平均分:5 \n"); printf("* 按每个学生的总分由高到低排出名次:6\n"); printf("* 按每个学生的总分由低到高排出名次:7\n"); printf("* 按学号由小到大排出成绩表:8\n"); printf("* 按姓名的字典顺序排出成绩表:9\n"); printf("* 按学号查询学生排名及其考试成绩:10\n"); printf("* 按姓名查询学生排名及其考试成绩:11\n"); printf("* 按优秀(90-100),良好(80-89),中等(70-79),及格(60-69),不及格(0-59)\n"); printf("* 5个类别,对每门课程分别统计每个类别的人数和百分比 : 12\n"); printf("* 输出每个学生的学号、姓名、各科考试成绩、\n* 以及每门课程的总分和平均分 : 13\n"); printf("* 将每个学生的记录信息写入文件 : 14\n"); printf("* 从文件中读出每个学生的记录信息并显示 : 15 \n"); printf("* 退出系统:0 \n"); printf("*****************************************************\n\n"); printf("请参照上面的提示办入指令码并按回车键:\n"); scanf("%d",&cmd); switch (cmd) { case INPUT : do_input();break; case TOTAL_LES : do_total_lession();break; case AVR_LES : do_avrage_lession();break; case TOTAL_STU : do_total_students();break; case AVR_STU : do_avrage_students();break; case SORT_H : do_sort_high_to_low();break; case SORT_L : do_sort_low_to_high();break; case SORT_ID : do_sort_student_id();break; case SORT_N : do_sort_student_name();break; case SEARCH_ID : do_search_by_id();break; case SEARCH_NAME : do_search_by_name();break; case TONGJI : do_statistics();break; case SAVE : do_save();break; case READFILE : do_read_from_file();break; case 0 : goto END; default : break; } }END: return 0;}
㈤ C语言15大头文件引见怎么解决
C语言15大头文件介绍 C89(标准C) 有15个头文件 ,这些头文件包含了标准库的函数的声明 1. assert.h /* assert.h assert macro Copyright (c) 1987, 1991 by Borland International All Rights Reserved.*/#if !defined( __DEFS_H )#include <_defs.h>#endif#ifdef __cplusplusextern "C" {#endifvoid _Cdecl __assertfail(char *__msg, char *__cond, char *__file, int __line);#ifdef __cplusplus}#endif#undef assert#ifdef NDEBUG# define assert(p) ((void)0)#else# define _ENDL "\n"# define assert(p) ((p) ? (void)0 : (void) __assertfail( \ "Assertion failed: %s, file %s, line %d" _ENDL, \ #p, __FILE__, __LINE__ ) )#endif2. float.h /* float.h Defines implementation specific macros for dealing with floating point. Copyright (c) 1987, 1991 by Borland International All Rights Reserved.*/#ifndef __FLOAT_H#define __FLOAT_H#if !defined( __DEFS_H )#include <_defs.h>#endif#define FLT_RADIX 2#define FLT_ROUNDS 1#define FLT_GUARD 1#define FLT_NORMALIZE 1#define DBL_DIG 15#define FLT_DIG 6#define LDBL_DIG 19#define DBL_MANT_DIG 53#define FLT_MANT_DIG 24#define LDBL_MANT_DIG 64#define DBL_EPSILON 2.2204460492503131E-16#define FLT_EPSILON 1.19209290E-07F#define LDBL_EPSILON 1.084202172485504E-19/* smallest positive IEEE normal numbers */#define DBL_MIN 2.2250738585072014E-308#define FLT_MIN 1.17549435E-38F#define LDBL_MIN _tiny_ldble#define DBL_MAX _huge_dble#define FLT_MAX _huge_flt#define LDBL_MAX _huge_ldble#define DBL_MAX_EXP +1024#define FLT_MAX_EXP +128#define LDBL_MAX_EXP +16384#define DBL_MAX_10_EXP +308#define FLT_MAX_10_EXP +38#define LDBL_MAX_10_EXP +4932#define DBL_MIN_10_EXP -307#define FLT_MIN_10_EXP -37#define LDBL_MIN_10_EXP -4931#define DBL_MIN_EXP -1021#define FLT_MIN_EXP -125#define LDBL_MIN_EXP -16381extern float _Cdecl _huge_flt;extern double _Cdecl _huge_dble;extern long double _Cdecl _huge_ldble;extern long double _Cdecl _tiny_ldble;#ifdef __cplusplusextern "C" {#endifunsigned int _Cdecl _clear87(void);unsigned int _Cdecl _control87(unsigned int __newcw, unsigned int __mask);void _Cdecl _fpreset(void);unsigned int _Cdecl _status87(void);#ifdef __cplusplus}#endif#if !__STDC__/* 8087/80287 Status Word format */#define SW_INVALID 0x0001 /* Invalid operation */#define SW_DENORMAL 0x0002 /* Denormalized operand */#define SW_ZERODIVIDE 0x0004 /* Zero divide */#define SW_OVERFLOW 0x0008 /* Overflow */#define SW_UNDERFLOW 0x0010 /* Underflow */#define SW_INEXACT 0x0020 /* Precision (Inexact result) *//* 8087/80287 Control Word format */#define MCW_EM 0x003f /* interrupt Exception Masks*/#define EM_INVALID 0x0001 /* invalid */#define EM_DENORMAL 0x0002 /* denormal */#define EM_ZERODIVIDE 0x0004 /* zero divide */#define EM_OVERFLOW 0x0008 /* overflow */#define EM_UNDERFLOW 0x0010 /* underflow */#define EM_INEXACT 0x0020 /* inexact (precision) */#define MCW_IC 0x1000 /* Infinity Control */#define IC_AFFINE 0x1000 /* affine */#define IC_PROJECTIVE 0x0000 /* projective */#define MCW_RC 0x0c00 /* Rounding Control */#define RC_CHOP 0x0c00 /* chop */#define RC_UP 0x0800 /* up */#define RC_DOWN 0x0400 /* down */#define RC_NEAR 0x0000 /* near */#define MCW_PC 0x0300 /* Precision Control */#define PC_24 0x0000 /* 24 bits */#define PC_53 0x0200 /* 53 bits */#define PC_64 0x0300 /* 64 bits *//* 8087/80287 Initial Control Word *//* use affine infinity, mask underflow and precision exceptions */#define CW_DEFAULT _default87extern unsigned int _Cdecl _default87;/* SIGFPE signal error types (for integer & float exceptions). */#define FPE_INTOVFLOW 126 /* 80×86 Interrupt on overflow */#define FPE_INTDIV0 127 /* 80×86 Integer divide by zero */#define FPE_INVALID 129 /* 80×87 invalid operation */#define FPE_ZERODIVIDE 131 /* 80×87 divide by zero */#define FPE_OVERFLOW 132 /* 80×87 arithmetic overflow */#define FPE_UNDERFLOW 133 /* 80×87 arithmetic underflow */#define FPE_INEXACT 134 /* 80×87 precision loss */#define FPE_STACKFAULT 135 /* 80×87 stack overflow */#define FPE_EXPLICITGEN 140 /* When SIGFPE is raise()'d *//* SIGSEGV signal error types.*/#define SEGV_BOUND 10 /* A BOUND violation (SIGSEGV) */#define SEGV_EXPLICITGEN 11 /* When SIGSEGV is raise()'d *//* SIGILL signal error types.*/#define ILL_EXECUTION 20 /* Illegal operation exception */#define ILL_EXPLICITGEN 21 /* When SIGILL is raise()'d */#endif /* !__STDC__ */#endif
㈥ c语言实验报告心得
c语言实验心得:1、只有频繁用到或对运算速度要求很高的变量才放到data区内,如for循环中的计数值。2、其他不频繁调用到和对运算速度要求不高的变量都放到xdata区。3、常量放到code区,如字库、修正系数。4、逻辑标志变量可以定义到bdata中。在51系列芯片中有16个字节位寻址区bdata,其中可以定义8*16=128个逻辑变量。这样可以大大降低内存占用空间。定义方法是: bdata bit LedState;但位类型不能用在数组和结构体中。5、data区内最好放局部变量。因为局部变量的空间是可以覆盖的(某个函数的局部变量空间在退出该函数是就释放,由别的函数的局部变量覆盖),可以提高内存利用率。当然静态局部变量除外,其内存使用方式与全局变量相同;6、确保程序中没有未调用的函数。在Keil C里遇到未调用函数,编译器就将其认为可能是中断函数。函数里用的局部变量的空间是不释放,也就是同全局变量一样处理。这一点Keil做得很愚蠢,但也没办法。7、如果想节省data空间就必须用large模式。将未定义内存位置的变量全放到xdata区。当然最好对所有变量都要指定内存类型。8、使用指针时,要指定指针指向的内存类型。在C51中未定义指向内存类型的通用指针占用3个字节;而指定指向data区的指针只占1个字节;指定指向xdata区的指针占2个字节。如指针p是指向data区,则应定义为: char data *p;。还可指定指针本身的存放内存类型,如:char data * xdata p;。其含义是指针p指向data区变量,而其本身存放在xdata区。以前没搞过C51,大学时代跟单片机老师的时候也是捣鼓下汇编,现在重新搞单片机,因为手头资料不多,找到一些C51的程序,发现里面有这些关键字,不甚明了,没办法只好找了下,发现如下描述:从数据存储类型来说,8051系列有片内、片外程序存储器,片内、片外数据存储器,片内程序存储器还分直接寻址区和间接寻址类型,分别对应code、data、xdata、idata以及根据51系列特点而设定的pdata类型,使用不同的存储器,将使程序执行效率不同,在编写C51程序时,最好指定变量的存储类型,这样将有利于提高程序执行效率(此问题将在后面专门讲述)。与ANSI-C稍有不同,它只分SAMLL、COMPACT、LARGE模式,各种不同的模式对应不同的实际硬件系统,也将有不同的编译结果。在51系列中data,idata,xdata,pdata的区别data:固定指前面0x00-0x7f的128个RAM,可以用acc直接读写的,速度最快,生成的代码也最小。idata:固定指前面0x00-0xff的256个RAM,其中前128和data的128完全相同,只是因为访问的方式不同。idata是用类似C中的指针方式访问的。汇编中的语句为:mox ACC,@Rx.(不重要的补充:c中idata做指针式的访问效果很好) xdata:外部扩展RAM,一般指外部0x0000-0xffff空间,用DPTR访问。pdata:外部扩展RAM的低256个字节,地址出现在A0-A7的上时读写,用movx ACC,@Rx读写。这个比较特殊,而且C51好象有对此BUG,建议少用。但也有他的优点,具体用法属于中级问题,这里不提。三、有关单片机ALE引脚的问题 "单片机不访问外部锁存器时ALE端有正脉冲信号输出,此频率约为时钟振荡频率的1/6.每当访问外部数据存储器是,在两个机器周期中ALE只出现一次,即丢失一个ALE脉冲."这句话是不是有毛病.我觉得按这种说法,应该丢失3个ALE脉冲才对,我一直想不通是怎么回事,希望大虾们帮帮我.小弟感激涕零.答:其他所有指令每6个机器周期发出一个ALE,而MOVX指令占用12个机器周期只发出一个ALE 四、如何将一个INT型数据转换成2个CHAR型数据? 经keil优化后,char1=int1/256,char2=int1%256或char1=int1>>8,char2=int1&0x00ff效率是一样的。 五、在KEIL C51上仿真完了,怎样生成HEX文件去烧写?? 右键点项目中Target 1,选第二个,在OUTPUT中选中CREAT HEX 六、typedef 和 #define 有何不同?? typedef 和 #define 有何不同》》》 如typedef unsigned char UCHAR ;#define unsigned char UCHAR ;typedef命名一个新的数据类型,但实际上这个新的数据类型是已经存在的,只不过是定义了一个新的名字.#define只是一个标号的定义.你举的例子两者没有区别,但是#define还可以这样用#define MAX 100#define FUN(x) 100-(x)#define LABEL等等,这些情况下是不能用typedef定义的 七、请问如何设定KELC51的仿真工作频(时钟) 用右键点击左边的的target 1,然后在xtal一栏输入 八、不同模块怎样共享sbit变量,extern不行? 把SBIT定义单独放到一个.H中,每个模块都包含这个.h文件 九、C51中对于Px.x的访问必须自己定义吗? 是的。如sbit P17 = 0x97;即可定义对P1.7的访问 十、SWITCH( )语句中表达式不可以是位变量对吗? 可以用位变量:#include#includevoid main(){bit flag;flag=0;switch(flag){case '0':{printf("0\n");break;}case '1':{printf("1\n");break;}default:break; }}bit 变量只有两种状态,if 语句足够啦,!!! 十一、const常数声明占不占内存??? const 只是用来定义“常量”,所占用空间与你的定义有关,如:const code cstStr[] = {"abc"};占用代码空间;而如:const char data cstStr[] = {"abc"};当然占用内存空间。另外,#define 之定义似乎不占用空间。 十二、philips的单片机P89C51RD+的扩展RAM在C51中如何使用? 试一试将auxr.1清0,然后在c语言中直接声明xdata类型的变量 十三、BUG of Keil C51 程序中用如下语句:const unsigned char strArr[] = {"数学"};结果发现strArr[] 内容为 {0xCA,0xD1,0xA7},真奇怪!凡是有0xfd,则会通通不见了,所以只能手工输入内码了,例如 uchar strArr[]={0xCA,0xfd,0xd1,0xa7}(用Ultraedit会很方便)。 十四、Keil C51中如何实现代码优化? 菜单Project下Option for target "Simulator"的C51.看到Code optimization了吗? 十五、请教c的!和 ~ 符号有甚区别?? !是逻辑取反,~是按位取反。 十六、c51编程,读端口,还要不要先输出1? 我怎么看到有的要,有的不要,请高手给讲讲,到底咋回事?谢了要输出1的,除非你能保证之前已经是1,而中间没有输出过其他值。 十七、当定时器1(T1)用于产生波特率时,P3^5还是否可以用作正常的I/O口呢? p3.5完全可以当普通的io使用 十八、C51中 INT 转换为 2个CHAR? 各位高手:C51中 INT 转换为 CHAR 如何转换诸如:X = LOW(Z);Y = HIGH(Z);答: x=(char)z;y=(char)(z>>8); 十九、如果我想使2EH的第7位置1的话,用位操作可以吗? 现在对位操作指令我一些不太明白请各位多多指教:如 SETB 07H 表示的是20H.7置1,对吗?(我在一本书上是这么看到的)那么如果我想使2EH的第7位置1的话,象我举的这个例子怎么表示呢?谢谢!SETB 77Hsetb (2eh-20h)*8+7 20h-2fh每字节有8个可位操作(00h-7fh),其它RAM不可位直接操作 二十、char *addr=0xc000 和char xdata *addr=0xc000有何区别? char *addr=0xc000;char xdata *addr=0xc000;除了在内存中占用的字节不同外,还有别的区别吗?char *addr=0xc000; 是通用定义,指针变量 addr 可指向任何内存空间的值;char xdata *addr=0xc000; 指定该指针变量只能指向 xdata 中的值;后一种定义中该指针变量(addr)将少占用一个存储字节。uchar xdata *addr=0xc000;指针指向外ram;如果:data uchar xdata *addr=0xc000;指针指向外ram但指针本身存在于内ram(data)中以此类推可以idata uchar xdata *addr=0xc000;pdata uchar xdata *addr=0xc000;data uchar idata *addr=0xa0;……… 二十一、while(p1_0)的执行时间? 假设,P1_0为单片机P1口的第一脚,请问,while(P1_0){P1_0=0;}while(!P1_0){P1_0=1;}以上代码,在KEIL C中,需要多长时间,执行完。能具体说明while(P1_0)的执行时间吗?仿真运行看看就知道了,我仿真了试了一下,约14个周期 二十二、怎样编写C51的watchdog程序? 各位大虾,我用KEIL C51 编写了一个带外部开门狗的程序,可程序无法运行起来,经过查找,发现程序在经过C51编译后,在MAIN()函数的前部增加了一端初始化程序,等到进入主程序设置开门狗时,开门狗已经时间到,将我的程序复位了,请问我怎样才能修改这一端初始花程序,使他一运行,就设置开门狗?可以在startup.a51中加入看门狗刷新指令,当然用汇编,然后重新编译startup.a51,将他和你的程序连接即可。新的startup.a51会自动代替系统默认的启动模块。 二十三、keil C51 怎样把修改的startup.a51 加到工程文件中 直接加入即可注意不要改动?STACK,?C_START,?C_STARTUP等符号。startup.a51直接加入项目,不用修改也可。可在内面自己修改汇编的一些限制或堆栈指针。 二十四、关于波特率的设置 我在设定串口波特率时发现一个问题:在晶体震荡器为11.0592MHz时,若设9600BPS的话,TH1=0XFD,TL1=0XFD,而要设19200BPS的话,TH1、TL1有否变化,如果没变,为什么?如果变了,又为什么?(因为我看书上俩个是一样的),希望大家点拨。答:当电源控制寄存器(PCON)第BIT7(SMOD)为1时波特率加倍。TH1和TL1的值不变. 二十五、如何在C中声明保留这部分RAM区不被C使用? 我不知道在C源程序中怎么控制这个,但在汇编程序中加入下面一段就行:DSEG AT 20HAA: DS 10这样C51就不会占用20H–29H了或者在c51里这样定义:uchar data asm_buff[10] _at_ 0x20; 二十六、问浮点运算问题 我在用C51时发现它对传递浮点参数的个数有限制,请问:1)参数是以全局变量的形式传递的,请问以全局变量的形式传递的参数也有限制吗?2)这种传递浮点参数的限制有多少呢?3)float*float的结果是float类型还是double类型?能否直接赋值给float类型的变量?答:由于KEIL C51的参数传递是通过R0-R7来传递的,所以会有限制。不过KEIL提供了一个编译参数,可以支持更多参数的传递。具体的内容见KEIL的PDF文档。我建议你把多个要传递的参数定义到指针或结构体中去,传递参数通过指针或结构进行,这样好一些。第3个问题回答是YES,你自己试试不就知道了。 二十七、如何在某一个地址定义ram 用_at_ 命令,这样可以定位灵活一点的地址uchar xdata dis_buff[16] _at_ 0x6020 ;//定位RAM将dis_buff[16]定位在0x6020开始的16个字节 二十八、keil c中,用什么函数可以得到奇偶校验位? 例如32位数据,将四个字节相互异或后检查P即可,若耽心P被改变,可用内嵌汇编。#include unsigned char parity(unsigned char x){x^=x;if(P)return(1);else return(0);}unsigned char parity2(unsigned int x){#pragma asmmov a,r7xrl ar6,a#pragma endasmif(P)return(1);else return(0);}