c/c++中结构体的入门教程

2016-02-19 19:16 6 1 收藏

今天天气好晴朗处处好风光,好天气好开始,图老师又来和大家分享啦。下面给大家推荐c/c++中结构体的入门教程,希望大家看完后也有个好心情,快快行动吧!

【 tulaoshi.com - 编程语言 】

什么是结构体?
  
  简单的来说,结构体就是一个可以包含不同数据类型的一个结构,它是一种可以自己定义的数据类型,它的特点和数组主要有两点不同,首先结构体可以在一个结构中声明不同的数据类型,第二相同结构的结构体变量是可以相互赋值的,而数组是做不到的, !-- frame contents -- !-- /frame contents -- 因为数组是单一数据类型的数据集合,它本身不是数据类型(而结构体是),数组名称是常量指针,所以不可以做为左值进行运算,所以数组之间就不能通过数组名称相互复制了,即使数据类型和数组大小完全相同。
  
  
  定义结构体使用strUCt修饰符,例如:
  
  struct test
  {
  float a;
  int b;
  };
  
  上面的代码就定义了一个名为test的结构体,它的数据类型就是test,它包含两个成员a和b,成员a的数据类型为浮点型,成员b的数据类型为整型。
  
  由于结构体本身就是自定义的数据类型,定义结构体变量的方法和定义普通变量的方法一样。
  
  test pn1;
  
  这样就定义了一test结构体数据类型的结构体变量pn1,结构体成员的访问通过点操作符进行,
  
  pn1.a=10 就对结构体变量pn1的成员a进行了赋值操作,
  
  注重:结构体生命的时候本身不占用任何内存空间,只有当你用你定义的结构体类型定义结构体变量的时候计算机才会分配内存。
  
  结构体,同样是可以定义指针的,那么结构体指针就叫做结构指针。
  
  结构指针通过-符号来访问成员,下面我们就以上所说的看一个完整的例子:
  
  
  //程序作者:管宁
  //站点:www.cndev-lab.com
  //所有稿件均有版权,如要转载,请务必闻名出处和作者
  
  #include iostream
  #include string
  using namespace std;
  
  struct test//定义一个名为test的结构体
  {
  int a;//定义结构体成员a
  int b;//定义结构体成员b
  };
  
  void main()
  {
  test pn1;//定义结构体变量pn1
  test pn2;//定义结构体变量pn2
  
  pn2.a=10;//通过成员操作符.给结构体变量pn2中的成员a赋值
  pn2.b=3;//通过成员操作符.给结构体变量pn2中的成员b赋值
  
  pn1=pn2;//把pn2中所有的成员值复制给具有相同结构的结构体变量pn1
  coutpn1.a""pn1.bendl;
  coutpn2.a""pn2.bendl;
  
  test *point;//定义结构指针
  
  point=&pn2;//指针指向结构体变量pn2的内存地址
  coutpn2.a""pn2.bendl;
  point-a=99;//通过结构指针修改结构体变量pn2成员a的值
  coutpn2.a""pn2.bendl;
  coutpoint-a""point-bendl;
  cin.get();
  }
  

  
  总之,结构体可以描述数组不能够清楚描述的结构,它具有数组所不具备的一些功能特性。 更多内容请看Asp.Net教程  C/C++技术学堂  C/C++技术专题专题,或 下面我们来看一下,结构体变量是如何作为函数参数进行传递的。
  
  
   !-- frame contents -- !-- /frame contents --
  //程序作者:管宁
  //站点:www.cndev-lab.com
  //所有稿件均有版权,如要转载,请务必闻名出处和作者
  
  #include iostream
  #include string
  using namespace std;
  
  
  struct test
  {
  char name[10];
  float socre;
  };
  
  void print_score(test pn)//以结构变量进行传递
  {
  coutpn.name""pn.socreendl;
  }
  
  void print_score(test *pn)//一结构指针作为形参
  {
  coutpn-name""pn-socreendl;
  }
  
  void main()
  {
  test a[2]={{"marry",88.5},{"jarck",98.5}};
  int num = sizeof(a)/sizeof(test);
  for(int i=0;inum;i++)
  {
  print_score(a[i]);
  }
  for(int i=0;inum;i++)
  {
  print_score(&a[i]);
  }
  cin.get();
  }
  

  
  void print_score(test *pn)的效率是要高过void print_score(test pn)的,因为直接内存操作避免了栈空间开辟结构变量空间需求,节省内存。 下面我们再说一下,传递结构引用的例子。
  
  利用引用传递的好处很多,它的效率和指针相差无几,但引用的操作方式和值传递几乎一样,种种优势都说明善用引用可以做到程序的易读和易操作,它的优势尤其在结构和大的时候,避免传递结构变量很大的值,节省内存,提高效率。
  
  
  
  //程序作者:管宁
  //站点:www.cndev-lab.com
  //所有稿件均有版权,如要转载,请务必闻名出处和作者
  
  #include iostream
  #include string
  using namespace std;
  
  struct test
  {
  char name[10];
  float socre;
  };
  
  void print_score(test &pn)//以结构变量进行传递
  {
  coutpn.name""pn.socreendl;
  }
  
  void main()
  {
  test a[2]={{"marry",88.5},{"jarck",98.5}};
  int num = sizeof(a)/sizeof(test);
  for(int i=0;inum;i++)
  {
  print_score(a[i]);
  }
  cin.get();
  }
  
更多内容请看ASP.NET教程  C/C++技术学堂  C/C++技术专题专题,或 上面我们说明了易用引用对结构体进行操作的优势,下面我们重点对比两个例程,进一部分析关于效率的问题。
  
  
  
   !-- frame contents -- !-- /frame contents --
  //程序作者:管宁
  //站点:www.cndev-lab.com
  //所有稿件均有版权,如要转载,请务必闻名出处和作者
  
  
  //-------------------------------------例程1---------------------------------
  
  #include iostream
  #include string
  using namespace std;
  
  struct test
  {
  char name[10];
  float socre;
  };
  
  void print_score(test &pn)
  {
  coutpn.name""pn.socreendl;
  }
  
  test get_score()
  {
  test pn;
  cinpn.namepn.socre;
  return pn;
  }
  void main()
  {
  test a[2];
  int num = sizeof(a)/sizeof(test);
  for(int i=0;inum;i++)
  {
  a[i]=get_score();
  }
  cin.get();
  for(int i=0;inum;i++)
  {
  print_score(a[i]);
  }
  cin.get();
  }
  
  //-------------------------------------例程2---------------------------------
  
  
  
  
  #include iostream
  #include string
  using namespace std;
  
  struct test
  {
  char name[10];
  float socre;
  };
  
  void print_score(test &pn)
  {
  coutpn.name""pn.socreendl;
  }
  
  void get_score(test &pn)
  {
  cinpn.namepn.socre;
  }
  void main()
  {
  test a[2];
  int num = sizeof(a)/sizeof(test);
  for(int i=0;inum;i++)
  {
  get_score(a[i]);
  }
  cin.get();
  for(int i=0;inum;i++)
  {
  print_score(a[i]);
  }
  cin.get();
  }
  

  
  例程2的效率要远高过例程1的原因主要有以下两处:
  
  
  第一:
  
  例程1中的
  
  test get_score()
  {
  test pn;
  cinpn.namepn.socre;
  return pn;
  }
  
  调用的时候在内部要在栈空间开辟一个名为pn的结构体变量,程序pn的时候又再次在栈内存空间内自动生成了一个临时结构体变量temp,在前面的教程中我们已经说过,它是一个copy,而例程2中的:
  
  void get_score(test &pn)
  {
  cinpn.namepn.socre;
  }
  
  却没有这一过程,不开辟任何新的内存空间,也没有任何临时变量的生成。 更多内容请看ASP.NET教程  C/C++技术学堂  C/C++技术专题专题,或
  
  第二:
  
  例程1在mian()中,必须对返回的结构体变量进行一次结构体变量与结构体变量直接的相互赋值操作。
  
  for(int i=0;inum;i++)
  {
  a[i]=get_score();
  }
  
   !-- frame contents -- !-- /frame contents -- 而例程2中由于是通过内存地址直接操作,所以完全没有这一过程,提高了效率。
  
  for(int i=0;inum;i++)
  {
  get_score(a[i]);
  }  函数也是可以返回结构体应用的,例子如下:
  
  
  //程序作者:管宁
  //站点:www.cndev-lab.com
  //所有稿件均有版权,如要转载,请务必闻名出处和作者
  
  #include iostream
  #include string
  using namespace std;
  
  struct test
  {
  char name[10];
  float socre;
  };
  
  test a;
  
  
  test &get_score(test &pn)
  {
  cinpn.namepn.socre;
  return pn;
  }
  
  void print_score(test &pn)
  {
  coutpn.name""pn.socreendl;
  }
  
  void main()
  {
  test &sp=get_score(a);
  cin.get();
  coutsp.name""sp.socre;
  cin.get();
  }
  

  
  调用get_score(a);结束并返回的时候,函数内部没有临时变量的产生,返回直接吧全局结构变量a的内存地址赋予结构引用sp
  
  最后提一下指针的引用
  
  定义指针的引用方法如下
  void main()
  {
  int a=0;
  int b=10;
  int *p1=&a;
  int *p2=&b;
  int *&pn=p1;
  cout pn""*pnendl;
  pn=p2;
  cout pn""*pnendl;
  cin.get();
  }
  

  pn就是一个指向指针的引用,它也可以看做是指针别名,总之使用引用要非凡注重它的特性,它的操作是和普通指针一样的,在函数中对全局指针的引用操作要十分小心,避免破坏全局指针! 更多内容请看ASP.NET教程 
    C/C++技术学堂  C/C++技术专题专题,或

来源:http://www.tulaoshi.com/n/20160219/1620549.html

延伸阅读
  假如一个变量你需要几种可能存在的值,那么就可以被定义成为枚举类型。之所以叫枚举就是说将变量或者叫对象可能存在的情况也可以说是可能的值一一例举出来。 !-- frame contents -- !-- /frame contents -- 举个例子来说明一吧,为了让大家更明白一点,比如一个铅笔盒中有一支笔,但在没有打开...
在学习c/c+过程中,指针是一个比较让人头痛的问题,稍微不注重将会是程序编译无法通过,甚至造成死机。在程序设计过程中,指针也往往是产生隐含bug的原因。下面就来谈谈指针的应用以及需要注重的一些问题,里面也许就有你平时没有注重到的问题,希望能帮助各位读者理解好指针。 !-- frame contents -- !-- /frame contents -- ...
在c++中,为了解决一些频繁调用的小涵数大量消耗栈空间或者是叫栈内存的问题,非凡的引入了inline修饰符,表示为内联涵数。 !-- frame contents -- !-- /frame contents -- 可能说到这里,很多人还不明白什么是栈空间,其实栈空间就是指放置程序的局部数据也就是函数内数据的内存空间,在系统下,栈空间是有限的,假如频...
布尔类型对象可以被赋予文字值true或者false,所对应的关系就是真与假的概念。 我们通常使用的方法是利用他来判定条件的真与假,例如下面的代码: !-- frame contents -- !-- /frame contents -- #include iostream  using namespace std;    void main(void)  ...
//程序作者:管宁 //站点:www.cndev-lab.com //所有稿件均有版权,如要转载,请务必著名出处和作者 #include iostream #include string using namespace std; void main(int argc,char* argv[]) { int a=10; int b=20; int &rn=a; coutrn"|"aendl; cout&rn"|"&aendl;//c++中是无法取得应用的内存地址的,取引用的地址就...

经验教程

172

收藏

74
微博分享 QQ分享 QQ空间 手机页面 收藏网站 回到头部