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{.. ...
随机推荐
- 6月7号shiro
Retains all Cache objects maintained by this cache manager :保留此缓存管理器维护的所有缓存对象 Destroyable可毁灭的 retain ...
- backface-visibility当元素不面向屏幕时是否可见
html代码 <h1>div1可见</h1> <div class="div1">div---1</div> <h1>d ...
- WEB笔记-3、盒子模型+定位+显示
3.1 盒子模型 边距控制 margin/padding:上 右 下 左: padding:内容和边距之间的空间 margin:”盒子“外撑开的空间,两个相邻标签外边距会出现重叠和累加的现象, ...
- MSP430之data type
- MFC和OpenCV结合
最重要的一点:如何把OpenCV的框嵌入MFC的ID.. 把cv显示框嵌入 pic控件 cvNamedWindow("kalman"); HWND hWnd = (HWND) cv ...
- Oracle经验积累
Oracle 常用Funtion ----行转列 开始---- select u_id, wmsys.wm_concat(goods) goods_sum from shopping group by ...
- BZOJ 1688: [Usaco2005 Open]Disease Manangement 疾病管理 状压DP + 二进制 + 骚操作
#include <bits/stdc++.h> #define setIO(s) freopen(s".in","r",stdin) #defin ...
- 后台导出大量数据超时报 nginx404错误
使用nginx服务器如果遇到timeou情况时可以如下设置参数,使用fastcgi: fastcgi_connect_timeout 75; 链接 fastcgi_read_ ...
- python 遍历xml所有节点
1.xml文件 2.代码 #coding:utf-8 import xml import xml.etree.ElementTree as ET """ 实现从xml文件 ...
- win10环境下配置django+Apache2.4.38+python3.6项目
1.)Apache-2.4.38-win64-vc15下载地址: https://www.apachelounge.com/download/VC14/ 解压httpd-2.4.38-win64-VC ...