• 嵌入式C语言自我修养——从芯片、编译器到操作系统
  • 嵌入式C语言自我修养——从芯片、编译器到操作系统
  • 嵌入式C语言自我修养——从芯片、编译器到操作系统
  • 嵌入式C语言自我修养——从芯片、编译器到操作系统
  • 嵌入式C语言自我修养——从芯片、编译器到操作系统
  • 嵌入式C语言自我修养——从芯片、编译器到操作系统
  • 嵌入式C语言自我修养——从芯片、编译器到操作系统
  • 嵌入式C语言自我修养——从芯片、编译器到操作系统
  • 嵌入式C语言自我修养——从芯片、编译器到操作系统
21年品牌 40万+商家 超1.5亿件商品

嵌入式C语言自我修养——从芯片、编译器到操作系统

全新正版 急速发货

57.7 4.9折 118 全新

库存12件

天津武清
认证卖家担保交易快速发货售后保障

作者王利涛

出版社电子工业出版社

ISBN9787121408564

出版时间2021-04

装帧平装

开本16开

定价118元

货号29234701

上书时间2024-12-27

当科图书专营店

五年老店
已实名 已认证 进店 收藏店铺

   商品详情   

品相描述:全新
商品描述
前言

你要学习的,不仅仅是C语言……

对于上面的几个C语言测试,如果你已经知道了答案,并且知道其要考查的是什么知识点,恭喜你,你对C语言及计算机体系结构的知识已经很熟悉了。如果回答得不是很好,偷偷用百度也没有搜到理想的答案,也不用气馁,因为这次测试要考查的内容其实已经不仅仅是C语言的知识了,而是和嵌入式C语言开发相关的一些理论知识,如处理器架构、操作系统、编译原理、编译器特性、内存堆栈管理、Linux内核中的GNU C扩展语法等。

当然,上面的测试也不是为了故意扎你心或者卖关子,让你赶紧掏腰包买下这本书,而是想要传递一个信息:要想从事嵌入式开发工作,尤其是嵌入式Linux内核驱动开发工作,你要精通的不仅仅是C语言,好还要掌握和C语言相关的一系列基础理论和调试技能。笔者也是过来人,从初学习嵌入式到从事嵌入式开发工作,这一路走来坎坷崎岖,什么都不说了,说多了都是泪。从一开始连指针都不会用、不敢用,看内核驱动代码一头雾水,越看越没底、越看越没自信,到现在不再犯怵,有自信和能力看懂内核中的代码细节和系统框架,这种进步不是天上掉下来的,也不是一不小心跌入山洞,捡到武功秘籍练出来的,而是不断地学习和实践、反复迭代、不断完善自己的知识体系和技能树,才慢慢达到的。学习没有捷径可走,要想真正学好嵌入式、精通嵌入式,个人觉得除了精通C语言,好还要具备以下完整的知识体系和编程技能。

l 半导体基础、CPU工作原理、硬件电路、计算机系统结构。

l ARM体系结构与汇编指令、汇编程序设计、ARM反汇编分析。

l 程序的编译、链接、安装、运行和重定位分析。

l 熟悉C语言标准、ARM、GNU编译器的特性和扩展语法。

l C语言的模块化编程思想,学会使用模块化思想去分析复杂的系统。

l C语言的面向对象编程(简称OOP)思想,学会使用OOP思想去分析Linux内核驱动。

l 对指针的深刻理解,对复杂指针的声明和灵活应用。

l 对内存堆栈管理、内存泄漏、栈溢出、段错误的深刻理解。

l 多任务并发编程思想,CPU和操作系统基础理论。

本书内容及写作初衷

本书从C语言的角度出发,分10章,在默认读者已经掌握C语言基本语法的基础上,和大家一起探讨、学习C语言背后的CPU工作原理、计算机体系结构、ARM平台下程序的编译/链接、程序运行时的内存堆栈管理等底层知识。同时,针对嵌入式开发领域,用3章分别探讨了C语言的面向对象编程思想、模块化编程思想和多任务编程思想,这些底层知识和编程思想构成了嵌入式开发所需要的通用理论基础和核心技能。尤其是对于很多从不同专业转行到嵌入式开发的朋友,由于专业背景的差异,导致每个人的知识储备和编程技能树参差不齐,在学习嵌入式开发的过程中会经常遇到各种各样的问题,陷入学习的困境。

本书的写作初衷就是为不同专业背景的读者搭建嵌入式开发所需要的完整知识体系和认知框架。掌握了这些基础理论和编程技能,也就补齐了短板,可为后续的嵌入式开发进阶学习打下坚实的基础。

本书特色

l 大白话写作风格,通俗易懂,不怕学不会,就怕你不学。

l 大量的配图、原理图,图文并茂,更加有利于学习和理解。

l 在ARM平台下讲解程序的编译、链接和运行原理(独创)。

l 现场“手撕”ARM汇编代码,从反汇编角度剖析C函数调用、传参过程。

l 多角度剖析C语言:CPU、计算机体系结构、编译器、操作系统、软件工程。

l GNU C编译器扩展语法精讲(在GNU开源软件、Linux内核中大量使用)。

l 内存堆栈管理机制的底层剖析,从根源上理解内存错误。

l 从零开始一步一步搭建和迭代嵌入式软件框架。

l 教你用OOP思想分析Linux内核中复杂的驱动和子系统。

l C语言的多任务并发编程思想,CPU和操作系统零基础入门。

读者定位

本书针对的是嵌入式开发,尤其是嵌入式Linux开发背景下的C语言进阶学习,比较适合在校学生、嵌入式学员、工作1~3年的职场新兵阅读和学习。为了达到更好的学习效果,在阅读本书之前,首先要确保你已经掌握了C语言的基本语法,并且至少使用过一款C语言集成开发环境(VC 6.0、Visual Studio、C-Free、GCC都可以),开发过一个完整的C语言项目(课程设计也算)。有了这些基础和编程经验之后,学习效果会更好。



导语摘要

《嵌入式C语言自我修养:从芯片、编译器到操作系统》是一本专门为嵌入式读者打造的C语言进阶学习图书。本书的学习重点不再是C语言的基本语法,而是和嵌入式、C语言相关的一系列知识。作者以C语言为切入点,分别探讨了嵌入式开发所需要的诸多核心理论和技能,力图帮助读者从零搭建嵌入式开发所需要的完整知识体系和技能树。

《嵌入式C语言自我修养:从芯片、编译器到操作系统》从底层CPU的制造流程和工作原理开始讲起,到计算机体系结构,C程序的反汇编分析,程序的编译、运行和重定位,程序运行时的堆栈内存动态变化,GNU C编译器的扩展语法,指针的灵活使用,C语言的面向对象编程思想,C语言的模块化编程思想,C语言的多任务编程思想,进程、线程和协程的概念,从底层到上层,从芯片、硬件到软件、框架,几乎涵盖了嵌入式开发的所有知识点。

本书适合嵌入式学习者、开发者阅读学习,同样适合从事Linux下C语言开发工作的人员作为参考。阅读本书需要读者有一定的C语言基础,无论你是在校学生,还是需要充电学习的工程师,掌握了C语言的基本语法和编程技能后再阅读本书,学习效果会更佳。



作者简介

王利涛


嵌入式工程师、培训讲师,多年嵌入式开发经验,包括芯片测试、BSP、驱动开发、USB子系统等。目前在开发《嵌入式工程师自我修养》系列在线视频教程,以及在个人博客(www.zhaixue.cc)分享更多的嵌入式、Linux、AIoT技术。



目录

第1章工欲善其事,必先利其器


1.1 代码编辑工具:Vim


1.1.1 安装Vim


1.1.2 Vim常用命令


1.1.3 Vim配置文件:vimrc


1.1.4 Vim的按键映射


1.2 程序编译工具:make


1.2.1 使用IDE编译C程序


1.2.2 使用gcc编译C源程序


1.2.3 使用make编译程序


1.3 代码管理工具:Git


1.3.1 什么是版本控制系统


1.3.2 Git的安装和配置


1.3.3 Git常用命令


第2章计算机体系结构与CPU工作原理


2.1 一颗芯片是怎样诞生的


2.1.1 从沙子到单晶硅


2.1.2 PN结的工作原理


2.1.3 从PN结到芯片电路


2.1.4 芯片的封装


2.2 一颗CPU是怎么设计出来的


2.2.1 计算机理论基石:图灵机


2.2.2 CPU内部结构及工作原理


2.2.3 CPU设计流程


2.3 计算机体系结构


2.3.1 冯·诺依曼架构


2.3.2 哈弗架构


2.3.3 混合架构


2.4 CPU性能提升:Cache机制


2.4.1 Cache的工作原理


2.4.2 一级Cache和二级Cache


2.4.3 为什么有些处理器没有Cache


2.5 CPU性能提升:流水线


2.5.1 流水线工作原理


2.5.2 超流水线技术


2.5.3 流水线冒险


2.5.4 分支预测


2.5.5 乱序执行


2.5.6 SIMD和NEON


2.5.7 单发射和多发射


2.6 多核CPU


2.6.1 单核处理器的瓶颈


2.6.2 片上多核互连技术


2.6.3 big.LITTLE结构


2.6.4 超线程技术


2.6.5 CPU核数越多越好吗


2.7 后摩尔时代:异构计算的崛起


2.7.1 什么是异构计算


2.7.2 GPU


2.7.3 DSP


2.7.4 FPGA


2.7.5 TPU


2.7.6 NPU


2.7.7 后摩尔时代的XPU们


2.8 总线与地址


2.8.1 地址的本质


2.8.2 总线的概念


2.8.3 总线编址方式


2.9 指令集与微架构


2.9.1 什么是指令集


2.9.2 什么是微架构


2.9.3 指令助记符:汇编语言


第3章ARM体系结构与汇编语言


3.1 ARM体系结构


3.2 ARM汇编指令


3.2.1 存储访问指令


3.2.2 数据传送指令


3.2.3 算术逻辑运算指令


3.2.4 操作数:operand2详解


3.2.5 比较指令


3.2.6 条件执行指令


3.2.7 跳转指令


3.3 ARM寻址方式


3.3.1 寄存器寻址


3.3.2 立即数寻址


3.3.3 寄存器偏移寻址


3.3.4 寄存器间接寻址


3.3.5 基址寻址


3.3.6 多寄存器寻址


3.3.7 相对寻址


3.4 ARM伪指令


3.4.1 LDR伪指令


3.4.2 ADR伪指令


3.5 ARM汇编程序设计


3.5.1 ARM汇编程序格式


3.5.2 符号与标号


3.5.3 伪操作


3.6 C语言和汇编语言混合编程


3.6.1 ATPCS规则


3.6.2 在C程序中内嵌汇编代码


3.6.3 在汇编程序中调用C程序


3.7 GNU ARM汇编语言


3.7.1 重新认识编译器


3.7.2 GNU ARM编译器的伪操作


3.7.3 GNU ARM汇编语言中的标号


3.7.4 .section伪操作


3.7.5 基本数据格式


3.7.6 数据定义


3.7.7 汇编代码分析实战


第4章程序的编译、链接、安装和运行


4.1 从源程序到二进制文件


4.2 预处理过程


4.3 程序的编译


4.3.1 从C文件到汇编文件


4.3.2 汇编过程


4.3.3 符号表与重定位表


4.4 链接过程


4.4.1 分段组装


4.4.2 符号决议


4.4.3 重定位


4.5 程序的安装


4.5.1 程序安装的本质


4.5.2 在Linux下制作软件安装包


4.5.3 使用apt-get在线安装软件


4.5.4 在Windows下制作软件安装包


4.6 程序的运行


4.6.1 操作系统环境下的程序运行


4.6.2 裸机环境下的程序运行


4.6.3 程序入口main()函数分析


4.6.4 BSS段的小秘密


4.7 链接静态库


4.8 动态链接


4.8.1 与地址无关的代码


4.8.2 全局偏移表


4.8.3 延迟绑定


4.8.4 共享库


4.9 插件的工作原理


4.10 Linux内核模块运行机制


4.11 Linux内核编译和启动分析


4.12 U-boot重定位分析


4.13 常用的binutils工具集


第5章内存堆栈管理


5.1 程序运行的“马甲”:进程


5.2 Linux环境下的内存管理


5.3 栈的管理


5.3.1 栈的初始化


5.3.2 函数调用


5.3.3 参数传递


5.3.4 形参与实参


5.3.5 栈与作用域


5.3.6 栈溢出攻击原理


5.4 堆内存管理


5.4.1 裸机环境下的堆内存管理


5.4.2 uC/OS的堆内存管理


5.4.3 Linux堆内存管理


5.4.4 堆内存测试程序


5.4.5 实现自己的堆管理器


5.5 mmap映射区域探秘


5.5.1 将文件映射到内存


5.5.2 mmap映射实现机制分析


5.5.3 把设备映射到内存


5.5.4 多进程共享动态库


5.6 内存泄漏与防范


5.6.1 一个内存泄漏的例子


5.6.2 预防内存泄漏


5.6.3 内存泄漏检测:MTrace


5.6.4 广义上的内存泄漏


5.7 常见的内存错误及检测


5.7.1 总有一个Bug,让你泪流满面


5.7.2 使用core dump调试段错误


5.7.3 什么是内存踩踏


5.7.4 内存踩踏监测:mprotect


5.7.5 内存检测神器:Valgrind


第6章GNU C编译器扩展语法精讲


6.1 C语言标准和编译器


6.1.1 什么是C语言标准


6.1.2 C语言标准的内容


6.1.3 C语言标准的发展过程


6.1.4 编译器对C语言标准的支持


6.1.5 编译器对C语言标准的扩展


6.2 指定初始化


6.2.1 指定初始化数组元素


6.2.2 指定初始化结构体成员


6.2.3 Linux内核驱动注册


6.2.4 指定初始化的好处


6.3 宏构造“利器”:语句表达式


6.3.1 表达式、语句和代码块


6.3.2 语句表达式


6.3.3 在宏定义中使用语句表达式


6.3.4 内核中的语句表达式


6.4 typeof与container_of宏


6.4.1 typeof关键字


6.4.2 typeof使用示例


6.4.3 Linux内核中的container_of宏


6.4.4 container_of宏实现分析


6.5 零长度数组


6.5.1 什么是零长度数组


6.5.2 零长度数组使用示例


6.5.3 内核中的零长度数组


6.5.4 思考:指针与零长度数组


6.6 属性声明:section


6.6.1 GNU C编译器扩展关键字:__attribute__


6.6.2 属性声明:section


6.6.3 U-boot镜像自复制分析


6.7 属性声明:aligned


6.7.1 地址对齐:aligned


6.7.2 结构体的对齐


6.7.3 思考:编译器一定会按照aligned指定的方式对齐吗


6.7.4 属性声明:packed


6.7.5 内核中的aligned、packed声明


6.8 属性声明:format


6.8.1 变参函数的格式检查


6.8.2 变参函数的设计与实现


6.8.3 实现自己的日志打印函数


6.9 属性声明:weak


6.9.1 强符号和弱符号


6.9.2 函数的强符号与弱符号


6.9.3 弱符号的用途


6.9.4 属性声明:alias


6.10 内联函数


6.10.1 属性声明:noinline


6.10.2 什么是内联函数


6.10.3 内联函数与宏


6.10.4 编译器对内联函数的处理


6.10.5 思考:内联函数为什么定义在头文件中


6.11 内建函数


6.11.1 什么是内建函数


6.11.2 常用的内建函数


6.11.3 C标准库的内建函数


6.11.4 内建函数:__builtin_constant_p(n)


6.11.5 内建函数:__builtin_expect(exp,c)


6.11.6 Linux内核中的likely和unlikely


6.12 可变参数宏


6.12.1 什么是可变参数宏


6.12.2 继续改进我们的宏


6.12.3 可变参数宏的另一种写法


6.12.4 内核中的可变参数宏


第7章数据存储与指针


7.1 数据类型与存储


7.1.1 大端模式与小端模式


7.1.2 有符号数和无符号数


7.1.3 数据溢出


7.1.4 数据类型转换


7.2 数据对齐


7.2.1 为什么要数据对齐


7.2.2 结构体对齐


7.2.3 联合体对齐


7.3 数据的可移植性


7.4 Linux内核中的size_t类型


7.5 为什么很多人编程时喜欢用typedef


7.5.1 typedef的基本用法


7.5.2 使用typedef的优势


7.5.3 使用typedef需要注意的地方


7.5.4 typedef的作用域


7.5.5 如何避免typedef被大量滥用


7.6 枚举类型


7.6.1 使用枚举的三种方法


7.6.2 枚举的本质


7.6.3 Linux内核中的枚举类型


7.6.4 使用枚举需要注意的地方


7.7 常量和变量


7.7.1 变量的本质


7.7.2 常量存储


7.7.3 常量折叠


7.8 从变量到指针


7.8.1 指针的本质


7.8.2 一些复杂的指针声明


7.8.3 指针类型与运算


7.9 指针与数组的“暧昧”关系


7.9.1 下标运算符[]


7.9.2 数组名的本质


7.9.3 指针数组与数组指针


7.10 指针与结构体


7.11 二级指针


7.11.1 修改指针变量的值


7.11.2 二维指针和指针数组


7.11.3 二级指针和二维数组


7.12 函数指针


7.13 重新认识void


第8章C语言的面向对象编程思想


8.1 代码复用与分层思想


8.2 面向对象编程基础


8.2.1 什么是OOP


8.2.2 类的封装与实例化


8.2.3 继承与多态


8.2.4 虚函数与纯虚函数


8

—  没有更多了  —

以下为对购买帮助不大的评价

此功能需要访问孔网APP才能使用
暂时不用
打开孔网APP