c21---结构体
- //
- // main.c
- // 结构体基本概念
- //
- #include <stdio.h>
- int main(int argc, const char * argv[]) {
- /*
- 基本数据类型: int double float char
- 构造类型: 数组/ 结构体
- 数组: 是用于保存一组相同类型的数据
- 结构体: 是用于保存一组不同类型的数据
- 要想保存人得数据, 就必须先定义变量
- 数据类型 变量名称;
- 如何定义一个结构体变量
- 1.定义结构体类型
- 2.根据结构体类型, 定义结构体变量
- 定义结构体类型的格式:
- struct 结构体类型名称
- {
- 属性;
- };
- */
- // 1.定义结构体类型, 8 + 4 + 8个字节,结构体Person总共20个字节。
- struct Person
- {
- char *name; // char name[20];
- int age;
- double height;
- };
- // 2.定义结构体变量, int num;
- struct Person p;
- // 注意: 数组不能先定义再进行一次性的初始化, 所有下面的写法是错误的
- // p.name = "lnj"; name = {'l', 'n', 'j', '\0'}; 所以要用指针char *name。
- p.name = "lnj";
- p.age = ;
- p.height = 1.75;
- /*
- 这时不允许的
- int nums[3];
- nums[0] = 998;
- nums[1] = 887;
- nums[2] = 789;
- int nums[3];
- nums = {1, 3, 5}; */
- return ;
- }
- //
- // main.c
- // 结构体初始化
- #include <stdio.h>
- int main(int argc, const char * argv[]) {
- int nums[] = {, , };
- int nums[];
- nums[] = ;
- nums[] = ;
- nums[] = ;
- int nums[];
- nums = {, , }; // 错误
- int nums[] = {[] = };
- printf("nums[0] = %i\n", nums[]);
- struct Dog
- {
- char *name;
- int age;
- double height;
- };
- // 1.定义的同时初始化
- struct Dog sd = {"wc", , 5.0};
- // 2.先定义再初始化(逐个初始化)
- struct Dog sd1;
- sd1.name = "ww";
- sd1.age = ;
- sd1.height = 10.9;
- // 3.先定义再初始化(一次性初始化)
- struct Dog sd2;
- // 特别注意: 结构体和数组有一点区别, 数组不能先定义再进行一次性的初始化, 而结构体可以
- // 只不过需要明确的告诉系统{}中是一个结构体而不是数组。
- sd2 = (struct Dog){"xq", , 8.8}; // 数组? 结构体?
- // 4.指定将数据赋值给指定的属性
- struct Dog sd3 = {.height = 1.77, .name = "ww", .age = };
- printf("name = %s, age = %i, height = %lf\n", sd3.name, sd3.age, sd3.height);
- return ;
- }
- //
- // main.c
- // 结构体的内存存储细节
- #include <stdio.h>
- int main(int argc, const char * argv[]) {
- // 1.定义结构体类型并不会分配存储空间
- struct Person{
- int age; //
- int height; //
- int width; //
- };
- // 2.只有定义结构体变量才会真正的分配存储空间,12个存储空间,
- struct Person sp = {, , };
- // 结构体第0个属性的地址就是结构体的地址
- printf("&sp = %p\n", &sp);//0x0,不是结构体的地址,
- printf("age = %p\n", &sp.age);//0xffd8
- printf("age = %p\n", &sp.height);//0xffdc
- printf("age = %p\n", &sp.width);//0xffe0
- printf("size = %lu\n", sizeof(sp));//
- int nums[] = {, , };
- // nums == &nums == &nums[0]
- // 和数组一样, 结构体内存寻址从大到小, 存储数组是从小到大(先存储第0个属性, 再一次存储其它属性)
- /*
- 结构体如何开辟存储空间
- 看上去, 结构体分配存储空间是将所有属性占用的存储空间的总和加在一起后再分配
- 注意:
- 其实结构体分配存储空间本质上并不是将所有属性占用的存储空间的总和加在一起后再分配
- 而是会获取结构体类型中占用内存最大的属性的大小, 然后取该大小的倍数
- (每次都开辟8个,所以都是8的倍数)
- 特例:
- 如果剩余的存储空间"不够"存储将要存储的数据, 那么就会重新开辟8个字节的存储空间, 并且将需要存储的数据放到新开辟的存储空间中
- 如果剩余的存储空间"够"存储将要存储的数据, 那么就不会开辟了
- */
- struct Person{
- //double height; // 8
- int age; // 4
- //int heigth; //
- double height; //
- char c; // 1
- //char *name; //
- };
- struct Person sp;
- printf("size = %lu\n", sizeof(sp)); //
- return ;
- }
- //
- // main.c
- // 结构体定义的方式
- #include <stdio.h>
- int main(int argc, const char * argv[]) {
- // 1.先定义结构体类型, 在定义结构体变量
- struct Person
- {
- int age;
- char *name;
- double height;
- };
- struct Person sp;
- // 2.定义结构体类型的同时定义结构体变量
- struct Person
- {
- int age;
- char *name;
- double height;
- } sp;
- // 数据类型 变量名称
- sp.age = ;
- printf("age = %i\n", sp.age); //
- struct Person sp1;
- sp1.name = "lnj";
- printf("name = %s\n", sp1.name);
- // 3.定义结构体类型的同时定义结构体变量, 并且省略结构体名称
- // 如果在定义结构体类型的同时定义结构体变量, 那么可以省略结构体类型名称
- // 弊端: 由于结构体类型没有名称, 所以以后就不能使用该结构体类型
- struct // 优点: 如果结构体类型只需要使用一次, 那么可以使用该方式。
- {
- int age;
- char *name;
- double height;
- } sp;
- sp.age = ;
- printf("age = %i\n", sp.age);
- return ;
- }
- //
- // main.c
- // 结构体类型的作用域
- #include <stdio.h>
- void test();
- // 如果将变量写到函数或者代码块外面, 那么就不是局部变量, 而是全局变量
- // 全局变量的作用域是从定义的那一行开始, 直到文件末尾 (暂时这样理解)
- int num;
- // 如果将结构体类型写在函数或者代码块外面, 那么结构体类型的作用域和全局变量一样, 从定义的那一行开始一直直到文件末尾
- // 相同作用域不能有同名的结构体类型
- struct Person
- {
- int age;
- char *name;
- double height;
- };
- int main(int argc, const char * argv[]) {
- // int num = 10;
- num = ;
- struct Person sp;
- return ;
- }
- void test()
- {
- num = ;
- struct Person sp1;
- // num = 20;
- }
- void demo()
- {
- struct Person
- {
- int age;
- char *name;
- double height;
- };
- int num = ;
- {
- struct Dog
- {
- int age;
- char *name;
- };
- struct Dog sd;
- // 在不同的作用域中可以有同名的局部变量, 如果访问采用就近原则
- int num = ;
- printf("num = %i\n", num);
- // 在不同的作用域中可以定义同名的结构体类型 , 如果使用同名的结构体类型定义结构体变量, 采用就近原则
- struct Person
- {
- int age;
- char *name;
- double height;
- };
- struct Person sp = {, "lnj", 1.75};
- }
- // num = 55;
- // struct Dog sd1;
- struct Person sp;
- }
- void test()
- {
- // 1.如果结构体定义在函数或者代码块中, 那么结构体类型的作用域和变量的作用域一样, 从定义的那一行开始, 一直到函数结束或者到代码块结束
- struct Person sp;
- }
- //
- // main.c
- // 指向结构体的指针
- #include <stdio.h>
- int main(int argc, const char * argv[]) {
- struct Person
- {
- int age;
- char *name;
- double height;
- };
- struct Person sp = {, "lnj", 1.75};
- sp.name = "lnj";
- sp.age = ;
- sp.height = 1.75;
- // 定义了一个指向结构体的指针
- // *sip == sp
- struct Person* sip;
- sip = &sp; //sip是指针
- // 注意: 报错的原因是因为.运算符的优先级比*高
- (*sip).name = "xxx";
- (*sip).age = ;
- (*sip).height = 1.95;
- printf("age = %i, name = %s, height = %lf\n", (*sip).age, (*sip).name, (*sip).height);
- sip->age = ; //sip是指针
- sip->name = "oooo";
- sip->height = 2.1;
- printf("age = %i, name = %s, height = %lf\n", sip->age, sip->name, sip->height);
- /*
- 如何定义指向结构体变量的指针
- 1.拷贝结构体类型 和 结构体变量名称
- 2.在类型和名称中间加上一颗心
- 当指针指向结构体之后如何利用指针访问结构体
- 结构体变量名称.属性;
- (*结构体指针变量名称).属性;
- 结构体指针变量名称->属性;
- */
- return ;
- }
- //
- // main.c
- // 结构体数组
- //
- // Created by xiaomage on 15/6/14.
- // Copyright (c) 2015年 xiaomage. All rights reserved.
- //
- #include <stdio.h>
- int main(int argc, const char * argv[]) {
- // 要求定义变量保存公司中所有部门的绩效
- struct Bumen
- {
- char *name;
- int count;
- double kpi;
- };
- struct Bumen ios = {"iOS", , 100.0};
- struct Bumen andorid = {"Andoird", , 99.0};
- struct Bumen php = {"php", , 88.0};
- // 元素类型 数组名称[元素个数];
- struct Bumen bumens[] =
- {
- {"iOS", , 100.0}, //
- {"Andoird", , 99.0},
- {"php", , 88.0}
- };
- bumens[] = ios;
- bumens[].name = "iOSv587";
- bumens[].count = ;
- bumens[].kpi = 100.0;
- printf("name = %s, count = %i, kpi = %lf\n", bumens[].name, bumens[].count, bumens[].kpi);
- return ;
- }
- //
- // main.c
- // 结构体的嵌套定义
- #include <stdio.h>
- int main(int argc, const char * argv[]) {
- /*
- struct Person
- {
- int age; // 年龄
- char *name; // 姓名
- // 出生日期
- int year;
- int month;
- int day;
- // 初始化时晨
- int HH; // 24小时
- int mm; // 分钟
- int ss; // 秒钟
- // 入学时间
- int year2;
- int month2;
- int day2;
- // 毕业时间
- int year3;
- int month3;
- int day3;
- };
- struct Person sp = {30, "lnj", 1986, 1, 15 , 15, 20, 8};
- */
- // 定义一个时间结构体类型
- struct Time
- {
- int HH;
- int mm;
- int ss;
- };
- struct Date
- {
- int year;
- int month;
- int day;
- struct Time time;
- };
- struct Person
- {
- int age;
- char *name;
- // 出生日期
- struct Date birth;
- // 出生时间
- // struct Date time;
- // struct Time shic;
- // 小学入学时间
- struct Date ruxue;
- // 小学毕业时间
- struct Date biye;
- // ....
- };
- struct Person sp =
- {
- ,
- "lnj",
- {
- ,
- ,
- ,
- {
- ,
- ,
- }
- },
- {
- ,
- ,
- },
- {
- ,
- ,
- }
- };
- // 注意: 如果结构体的属性又是一个结构体, 那么可以通过连续.的方式, 访问结构体属性中的属性
- // 如果结构体类型中的属性又是一个结构体, 那么赋值时候通过大括号{}赋值
- printf("year = %i, month = %i, day = %i\n", sp.birth.year, sp.birth.month, sp.birth.day);
- return ;
- }
- //
- // main.c
- // 结构体和函数
- #include <stdio.h>
- void change(int value);
- void change(struct Person value);
- void change(struct Person *p);
- struct Person
- {
- int age;
- char *name;
- };
- int main(int argc, const char * argv[]) {
- struct Person sp = {, "lnj"};
- // 1.将结构体的属性传递给函数, 在函数中修改形参不会影响到实参
- printf("age = %i\n", sp.age); //
- change(sp.age);
- // 2.将结构体名称作为参数传递, 在函数中修改形参不会影响到实参
- // 结构体之间赋值是值传递, 系统会将A结构体的值 拷贝一份到 B结构体中
- change(sp);
- printf("age = %i\n", sp.age); //
- struct Person sp1 = {, "lnj"};
- struct Person sp2 = sp1; // 结构体之间赋值是值传递, 相当于拷贝
- printf("sp1.age = %i\n", sp1.age); //
- sp2.age = ;
- printf("sp1.age = %i\n", sp1.age); //
- printf("sp2.age = %i\n", sp2.age); //
- struct Person sp1 = {, "lnj"};
- printf("sp1.age = %i\n", sp1.age); //
- change(&sp1);
- printf("sp1.age = %i\n", sp1.age); //
- return ;
- }
- void change(int value){
- value = ;
- }
- void change(struct Person value){
- value.age = ;
- }
- void change(struct Person *p){
- p->age = ;
- }
c21---结构体的更多相关文章
- Go结构体实现类似成员函数机制
Go语言结构体成员能否是函数,从而实现类似类的成员函数的机制呢?答案是肯定的. package main import "fmt" type stru struct { testf ...
- C#基础回顾(二)—页面值传递、重载与重写、类与结构体、装箱与拆箱
一.前言 -孤独的路上有梦想作伴,乘风破浪- 二.页面值传递 (1)C#各页面之间可以进行数据的交换和传递,页面之间可根据获取的数据,进行各自的操作(跳转.计算等操作).为了实现多种方式的数据传递,C ...
- go语言结构体
定义: 是一种聚合的数据类型,是由零个或多个任意类型的值聚合成的实体. 成员: 每个值称为结构体的成员. 示例: 用结构体的经典案例处理公司的员工信息,每个员工信息包含一个唯一的员工编号.员工的名字. ...
- C语言中的结构体
用户自己建立自己的结构体类型 1. 定义和使用结构体变量 (1).结构体的定义 C语言允许用户自己建立由不同类型数据组成的组合型的数据结构,它称为结构体. (2).声明一个结构体类型的一般形式为: ...
- C++_系列自学课程_第_12_课_结构体
#include <iostream> #include <string> using namespace std; struct CDAccount { double bal ...
- java socket传送一个结构体给用C++编写的服务器解析的问题
另一端是Java写客户端程序,两者之间需要通信.c++/c接收和发送的都是结构体,而Java是直接发送的字节流或者byte 数组.解决方法:c++/c socket 在发送结构体的时候其实发送的也是字 ...
- swift学习笔记3——类、结构体、枚举
之前学习swift时的个人笔记,根据github:the-swift-programming-language-in-chinese学习.总结,将重要的内容提取,加以理解后整理为学习笔记,方便以后查询 ...
- HDOJ 1009. Fat Mouse' Trade 贪心 结构体排序
FatMouse' Trade Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others) ...
- C语言结构体对齐
1.结构体变量中的元素如何访问? (1)数组中元素的访问方式:表面上有2种方式(数组下标方式和指针方式):实质上都是指针方式访问.(2)结构体变量中的元素访问方式:只有一种,用.或者->的方式来 ...
- C与指针(结构体指针,函数指针,数组指针,指针数组)定义与使用
类型 普通指针 指针数组(非指针类型) 数组指针 结构体指针 函数指针 二重指针 定义方式 int *p; int *p[5]; int (*p)[5]; int a[3][5]; struct{.. ...
随机推荐
- Oracle调整内存参后报ORA-00844和ORA-00851
数据库服务器内存由16G增加为64G,为充分利用内存资源,对Oracle内存参数做了如下调整: SQL>alter system set sga_max_size=40960M scope=sp ...
- React+Dva
Reducer reducer 是一个函数,接受 state 和 action,返回老的或新的 state .即:(state, action) => state Effect app.mode ...
- Android 第一行代码(第二版)分享
今天从网上好不容易看到了别人转发的pdf版的 第一行代码通过下载我把它存在了百度云里面了与大家共享 http://pan.baidu.com/s/1bRztF4
- 【SQL】字符型函数
1. ASCII ASCII(American Standard Code for Information Interchange,美国信息交换标准代码)是基于拉丁字母的一套电脑编码系统. 1) 返回 ...
- js 习题
<!DOCTYPE html> <html> <head> <meta http-equiv="Content-Type" content ...
- Java基础学习笔记三 正则表达式和校验、Date、DateFormat、Calendar
正则表达式 正则表达式(英语:Regular Expression,在代码中常简写为regex).正则表达式是一个字符串,使用单个字符串来描述.用来定义匹配规则,匹配一系列符合某个句法规则的字符串.在 ...
- C# 常用语句
var list = dt.AsEnumerable().Select(t => t.Field<string>("Bed")).ToList();Select( ...
- 第1章 面向对象的JavaScript
针对基础知识的每一个小点,我都写了一些小例子,https://github.com/huyanluanyu1989/DesignPatterns.git,便于大家理解,如有疑问,大家可留言给我,最近工 ...
- [poj3565] Ants (二分图带权匹配)
传送门 Description 年轻自然主义者比尔在学校研究蚂蚁. 他的蚂蚁以苹果树上苹果为食. 每个蚁群都需要自己的苹果树来养活自己. 比尔有一张坐标为 n 个蚁群和 n 棵苹果树的地图. 他知道蚂 ...
- Linux思维导图之文件压缩