热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

嵌入式C语言笔记基础

C语言变量结构体1.结构体进行变量赋值时,数据输入需要使用取地址运算符结构体指针变量,结构体数组#includestructst
C语言变量

结构体

1.结构体进行变量赋值时,数据输入需要使用取地址运算符
结构体指针变量,结构体数组

#include
struct student
{
char sname[10];
float score[3];
float sum;
}stu[3];
void main()
{
int i;
struct student *p = stu;
for (; p {
scanf("%s%f%f%f", p->sname, &p->score[0], &p->score[1], &p->score
[2]);
p->sum = p->score[0] + p->score[1] + p->score[2];
}
p = stu;
for (i &#61; 0; i <3; i&#43;&#43;)
{
printf("%s的总成绩:%5.2f\n", (*p).sname, (*p).sum);
p&#43;&#43;;
}
}
输出&#xff1a;
张三 80 60 80
李四 80 60 60
王二 80 80 90
张三的总成绩:220.00
李四的总成绩:200.00
王二的总成绩:250.00
请按任意键继续. . .

数组

int占用4字节&#xff0c;short占用2字节&#xff0c;double占用8字节&#xff0c;指针大小8字节

const int days[] &#61; { 31,28,30,30,32,35,36,32,32,32,31,30 };
printf("%d", sizeof days);//48,int是4个字节
printf("%d", sizeof days[0]);//4,days[0]中是一个元素的大小
printf("%d", sizeof days / sizeof days[0]);//12&#xff0c;获取数组大小
return 0;

数组作为参数时的表示方式&#xff0c;以下是等价的&#xff0c;都是传入数组的指针&#xff1a;

#include "stdafx.h"
#define SIZE 12
int sum(int *p, int n)
{
int i;
int total&#61;0;
for (i &#61; 0; i total &#43;&#61; p[i];
return total;
}
int main()
{
int days[SIZE] &#61; { 31,28,30,30,32,35,36,32,32,32,31,30 };
long answer;
answer &#61; sum(days, SIZE);
printf("total is %ld .\n", answer);
return 0;
}

指针

指针的加减

int main()
{
int urn[SIZE] &#61; { 100,200,300,400,500 };
int *ptr1, *ptr2, *ptr3;
ptr1 &#61; urn;
ptr2 &#61; &urn[2];
printf("ptr1&#61;%p,*ptr1&#61;%d,&ptr1&#61;%p\n", ptr1, *ptr1, &ptr1);
ptr3 &#61; ptr1 &#43; 4;
printf("ptr1&#43;4&#61;%p,*(ptr1&#43;4)&#61;%d\n", ptr1 &#43; 4, *(ptr1 &#43; 4));//指针移4个i
nt&#xff0c;一个int4字节&#xff0c;共移16字节
ptr1&#43;&#43;;
printf("ptr1&#61;%p,*ptr1&#61;%d,&ptr1&#61;%p\n",ptr1,*ptr1,&ptr1);//&#xff0c;ptr1中存放的
是*ptr1的地址值。&ptr1是指存放指针名称的地址&#xff0c;这里ptr1&#43;&#43;&#xff0c;地址移了4个字节&#xff0c;但是存放该
指针地址的%ptr1的值不变
ptr2--;
printf("ptr2&#61;%p,*ptr2&#61;%d,&ptr2&#61;%p\n", ptr2, *ptr2, &ptr2);//ptr2和ptr1
指向的值一样&#xff0c;地址值就一样&#xff0c;那么ptr1和ptr2存放的值就一样&#xff0c;但是存放ptr1和ptr2的地址的&
ptr1&#xff0c;&ptr2不一样
--ptr1;
&#43;&#43;ptr2;//恢复原来的指针位置
printf("ptr1&#61;%p,ptr2&#61;%p\n", ptr1, ptr2);
//指针的加减
printf("ptr2-ptr1&#61;%d\n", ptr2 - ptr1);
printf("ptr2-2&#61;%p\n", ptr2 - 2);
//ptr1&#61;00DFFCDC,ptr2&#61;00DFFCE4,ptr2 - ptr1 &#61; 2,E4-DC&#61;8个字节&#xff0c;int占用4个
字节&#xff0c;就是8/4&#61;2个位移
return 0;
}

在声明字符串变量时&#xff0c;如果要修改字符串变量&#xff0c;就不要用指针初始化&#xff0c;用数组初始化

//以下代码可以运行
char p1[] &#61; "KING";
p1[0] &#61; &#39;P&#39;;
printf(p1);
//以下不能运行
char *p1 &#61; "KING";
p1[0] &#61; &#39;P&#39;;
printf(p1);

回调函数

函数 F1 调用函数 F2 的时候&#xff0c;函数 F1 通过参数给 函数 F2 传递了另外一个函数 F3 的指针&#xff0c;在函
数 F2 执行的过程中&#xff0c;函数F2 调用了函数 F3&#xff0c;这个动作就叫做回调&#xff08;Callback&#xff09;&#xff0c;而先被当做指
针传入、后面又被回调的函数 F3 就是回调函数。

#include
#include // 包含Library Function所在读得Software library库的
头文件
int Callback() // Callback Function
{
// TODO
return 0;
}
int main() // Main program
{
// TODO
Library(Callback);
// TODO
return 0;
}

在回调中&#xff0c;主程序把回调函数像参数一样传入库函数。这样一来&#xff0c;只要我们改变传进库函数的参
数&#xff0c;就可以实现不同的功能&#xff0c;这样有没有觉得很灵活&#xff1f;并且丝毫不需要修改库函数的实现&#xff0c;这就是
解耦。


推荐阅读
  • 题目描述:给定n个半开区间[a, b),要求使用两个互不重叠的记录器,求最多可以记录多少个区间。解决方案采用贪心算法,通过排序和遍历实现最优解。 ... [详细]
  • UNP 第9章:主机名与地址转换
    本章探讨了用于在主机名和数值地址之间进行转换的函数,如gethostbyname和gethostbyaddr。此外,还介绍了getservbyname和getservbyport函数,用于在服务器名和端口号之间进行转换。 ... [详细]
  • 题目Link题目学习link1题目学习link2题目学习link3%%%受益匪浅!-----&# ... [详细]
  • 本实验主要探讨了二叉排序树(BST)的基本操作,包括创建、查找和删除节点。通过具体实例和代码实现,详细介绍了如何使用递归和非递归方法进行关键字查找,并展示了删除特定节点后的树结构变化。 ... [详细]
  • 本文详细介绍了C语言中链表的两种动态创建方法——头插法和尾插法,包括具体的实现代码和运行示例。通过这些内容,读者可以更好地理解和掌握链表的基本操作。 ... [详细]
  • 本文详细探讨了VxWorks操作系统中双向链表和环形缓冲区的实现原理及使用方法,通过具体示例代码加深理解。 ... [详细]
  • Codeforces Round #566 (Div. 2) A~F个人题解
    Dashboard-CodeforcesRound#566(Div.2)-CodeforcesA.FillingShapes题意:给你一个的表格,你 ... [详细]
  • 在多线程编程环境中,线程之间共享全局变量可能导致数据竞争和不一致性。为了解决这一问题,Linux提供了线程局部存储(TLS),使每个线程可以拥有独立的变量副本,确保线程间的数据隔离与安全。 ... [详细]
  • 本文介绍如何使用Objective-C结合dispatch库进行并发编程,以提高素数计数任务的效率。通过对比纯C代码与引入并发机制后的代码,展示dispatch库的强大功能。 ... [详细]
  • 文件描述符、文件句柄与打开文件之间的关联解析
    本文详细探讨了文件描述符、文件句柄和打开文件之间的关系,通过具体示例解释了它们在操作系统中的作用及其相互影响。 ... [详细]
  • 本题通过将每个矩形视为一个节点,根据其相对位置构建拓扑图,并利用深度优先搜索(DFS)或状态压缩动态规划(DP)求解最小涂色次数。本文详细解析了该问题的建模思路与算法实现。 ... [详细]
  • 本文介绍了几种不同的编程方法来计算从1到n的自然数之和,包括循环、递归、面向对象以及模板元编程等技术。每种方法都有其特点和适用场景。 ... [详细]
  • 扫描线三巨头 hdu1928hdu 1255  hdu 1542 [POJ 1151]
    学习链接:http:blog.csdn.netlwt36articledetails48908031学习扫描线主要学习的是一种扫描的思想,后期可以求解很 ... [详细]
  • 本题涉及一棵由N个节点组成的树(共有N-1条边),初始时所有节点均为白色。题目要求处理两种操作:一是改变某个节点的颜色(从白变黑或从黑变白);二是查询从根节点到指定节点路径上的第一个黑色节点,若无则输出-1。 ... [详细]
  • Linux设备驱动程序:异步时间操作与调度机制
    本文介绍了Linux内核中的几种异步延迟操作方法,包括内核定时器、tasklet机制和工作队列。这些机制允许在未来的某个时间点执行任务,而无需阻塞当前线程,从而提高系统的响应性和效率。 ... [详细]
author-avatar
粗陶工作室
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有