您的位置:

c语言数据驱动,c++ 驱动开发

本文目录一览:

什么是linux下的C语言驱动开发?

驱动一般是指硬件驱动,当然也有数据库驱动程序。

至于为什么要在Linux下开发,主要是为了在Linux下使用测试。

驱动程序就是Linux内核的一个重要组成部分。

c语言驱动usb

答案是可以。

网上有许多学习板,去淘宝搜索USB学习板就知道了。

单片机一般是STM32或者是silicon公司的C8051F34系列这些自带USB的单片机或者51单片机加上一块USB控制器。

使用silicon公司的丹皮纳吉,你可以很快做出一个成品,因为silicon公司提供了windows驱动和下位机的驱动。你只需要去调用他提供的API函数就够了。

使用前者或者是51结合USB控制器,你可以学到很多更详细的USB知识(很直接的说,USB是个非常复杂的东西)

需要掌握的知识有:

上位机,需要掌握VC或者VB之类的能生成图形界面的软件,来调用siliocn的库实现通过USB向单片机传递数据或者是自己去定义USB的那些结构体实现设备的枚举握手等过程(初学者不建议,有点难,但网上的源码非常多,肯钻研,这条路更好。)。

下位机,就需要掌握单片机的使用。

当然所有的这些,需要熟练使用C语言,以及了解C++面向对象的思想。

这东西比较复杂,不是一蹴而就的,慢慢来,相信你会有个好的前景的!

请c语言大神帮忙!

这个题目要点。

1、收费标准必须为可操作修改。

2、收费标准档位是不确定的,需要动态数组。(当然用常量,每次手改源代码就不需要了)

3、收费标准的输入除第一个阀值,其他要求增量(较上一个阀值),不能直接用于运算。

4、输入范围需要有验证。

最简易做法是将标准定义成常量,然后需要时修改代码常量,但这样对用户够不友好,所以我这里把标准定义成结构,定义函数动态申请数组,修改收费标准。

#includestdio.h

#includemalloc.h

typedef struct eq

{

  int tn;//表示共有几档

  float **fb;//表示各档计费标准的二维数组

}EQ;

int newFb(int tn);//构建收费标准数组地址空间,成功返回1,失败返回2。(成功自动释放旧地址,无需单独释放)

EQ *init();//初始化计费标准

void showEQ();//打印当前收费标准

int setEQ();//修改收费标准,成功返回1,失败返回0

float ecost(float amount);//计算电费

EQ *eq=NULL;

int main()

{

  int n=0;

  float at;

  eq=init();

  if(!eq)

  {

      printf("异常终止!\n");

      return 1;

  }

  while(1)

  {

      printf("1、打印收费标准;2、修改收费标准;3、计算电费\n");

      n=0;

      while(n!=1 n!=2 n!=3)

          scanf("%d",n);

      switch(n)

      {

          case 1:showEQ();break;

          case 2:

              if(!setEQ())

                  printf("异常!修改失败!\n\n");

              else

                  printf("修改成功!\n\n");

              break;

          case 3:printf("请输入年度用电量:");

                 scanf("%f",at);

                 printf("年度用电费用:%.2f\n\n",ecost(at));

                 break;

      }

  }

  return 0;

}

float ecost(float amount)//计算电费

{

  int i;

  float sum=0;

  if(amount=eq-fb[0][0])

      return 0;

  for(i=eq-tn-1;i=0;i--)

      if(amounteq-fb[i][0])

      {

          sum+=(amount-eq-fb[i][0])*eq-fb[i][1];

          amount=eq-fb[i][0];

      }

  return sum;

}

EQ *init()//初始化计费标准,

{

  if(eq)

      return eq;

  eq=(EQ *)malloc(sizeof(EQ));

  if(!eq)

      return NULL;

  eq-tn=4;

  eq-fb=NULL;

  if(!newFb(4))

  {

      free(eq);

      return NULL;

  }

  eq-fb[0][0]=0,eq-fb[0][1]=0.6;

  eq-fb[1][0]=3000,eq-fb[1][1]=0.7;

  eq-fb[2][0]=5000,eq-fb[2][1]=0.9;

  eq-fb[3][0]=7000,eq-fb[3][1]=1.2;

  return eq;

}

int newFb(int tn)//构建收费标准数组地址空间,成功返回1,失败返回0。(成功自动释放旧地址,无需单独释放)

{

  int i,flag=1;

  float **fbSave=NULL;

  if(!eq)

      return 0;

  eq-tn=tn;

  if(!eq-fb)//如果有旧地址,保存该地址,用于还原

      fbSave=eq-fb;

  eq-fb=(float **)malloc(sizeof(float *)*tn);

  if(!eq-fb)

      flag=2;

  for(i=0;flag itn;i++)

  {

      eq-fb[i]=(float *)malloc(sizeof(float)*2);

      if(!eq-fb)

          flag=3;

  }

  if(flag==3)//内存申请失败,释放已申请的新地址,还原旧地址

  {

      for(i=0;itn;i++)

          free(eq-fb[i]);

      free(eq-fb);

      eq-fb=fbSave;

      return 0;

  }

  if(flag==2)

  {

      eq-fb=fbSave;

      return 0;

  }

  return 1;

}

void showEQ()//打印当前收费标准

{

  int i;

  printf("当前共计%d档计费标准:\n",eq-tn);

  for(i=0;ieq-tn;i++)

      printf("电量超过%.0f,%s%.1f(实际金额%.1f)\n",eq-fb[i][0],i0?"每度再增加":"每度",i0?eq-fb[i][1]-eq-fb[i-1][1]:eq-fb[i][1],eq-fb[i][1]);

  printf("\n");

}

int setEQ()//修改收费标准,成功返回1,失败返回0

{

  int i,tn;

  float money;

  printf("请输入新的计费档数(输入0退出修改):");

  scanf("%d",tn);

  if(!tn)

      return 0;

  if(newFb(tn))

  {

      for(i=0;ieq-tn;i++)

      {

          printf("请输入第%d档电量阀值(%s%.0f),及%s(单位元)",i+1,i0?"必须大于":"大于等于",i0?eq-fb[i-1][0]:0,i0?"每度增加收费":"每度收费");

          scanf("%f%f",eq-fb[i][0],money);

          if(i==0 eq-fb[i][0]0)

          {

              printf("输入错误!起始阀值不能小于0!请重新输入\n");

              i--;

              continue;

          }

          if(i0  eq-fb[i][0]=eq-fb[i-1][0])

          {

              printf("输入错误!当前阀值不能小于上一次的阀值!请重新输入\n");

              i--;

              continue;

          }

          if(i==0)

              eq-fb[i][1]=money;

          else

              eq-fb[i][1]=eq-fb[i-1][1]+money;

      }

  }

  return 1;

}

//PS:你说你代码运算不对,看看是否把增量当金额来用了。