c语言 英文教材,C语言教程(英文版·第4版)-程序员宅基地

技术标签: c语言 英文教材  

PrefaCe

Chapter 0

Starting from Zero

0.1 Why C?

0.2 ANSI C Standard

0.3 From C to C++

0.4 From C and C++to java

Chapter 1

An Overview of C

1.1 Programming and Preparation

1.2 Program Output

1.3 Variables,Expressions,and Assignment

1.4 The Use of #define and #include

1.5 The USe of printf()and Scanf()

1.6 Flow of Control

1.7 Functions

Call-by-value

1. 8 ArrayS,Strings,and Pointers

Arrays

Strings

Pointers

1.9 Files

1.10 Operating System Considerations

Writing and Running a C Program

Interrupting a Program

Typing an End-of-file Signal

Redirection of the Input and the Output

Summary

Exercises

Chapter 2

Lexical Elements, Operators, and the C System

2.1 Characters and Lexical Elements

2.2 Syntax Rules

2.3 Comments

2.4 Keywords

2.5 Identifiers

2.6 Constants

2.7 String Constants

2.8 Operators and Punctuators

2.9 Precedence and Associativity of Operators

2.10 Increment and Decrement Operators

2.11 Assignment Operators

2.12 An Example: Computing Powers of 2

2.13 The C System

The Preprocessor

The Standard Library

Summary

Exercises

Chapter 3

The Fundamental Data Types

3.1 Declarations, Expressions, and Assignment

3.2 The Fundamental Data Types

3.3 Characters and the Data Type char

3.4 The Data Type int

3.5 The integral Types short, long, and unsigned

3.6 The Floating Types

3.7 The Use of typedef

3.8 The sizeof Operator

3.9 The Use of getchar() and putchar()

3.10 Mathematical Functions

The Use of abs() and fabs()

UNIX and the Mathematics Library

3.11 Conversions and Casts

The Integral Promotions

The Usual Arithmetic Conversions

Casts

3.12 Hexadecimal and Octal Constants

C.13 Summary

Exercises

Chapter 4

Flow of Control

4.1 Relational, Equality, and Logical Operators

4.2 Relational Operators and Expressions

4.3 Equality Operators and Expressions

4.4 Logical Operators and Expressions

Short-circuit Evaluation

4.5 The Compound Statement

4.6 The Expression and Empty Statement

4.7 The if and the if-else Statements

4.8 The while Statement

4.9 The for Statement

4.10 An Example: Boolean Variables

4.11 The Comma Operator

4.12 The do Statement

4.13 An Example: Fibonacci Numbers

4.14 The goto Statement

4.15 The break and continue Statements

4.16 The switch Statement

4.17 The Conditional Operator

Summary

Exercises

Chapter 5

Functions

5.1 Function Definition

5.2 The return Statement

5.3 Function Prototypes

Function Prototypes in C++

5.4 An Example: Creating a Table of Powers

5.5 Function Declarations from the Compiler's Viewpoint

Limitations

5.6 An Alternate Style for Function Definition Order

5.7 Function Invocation and Call-by-Value

5.8 Developing a Large Program

What Constitutes a Large Program?

5.9 Using Assertions

5.10 Scope Rules

Parallel and Nested Blocks

Using a Block for Debugging

5.11 Storage Classes

The Storage Class auto

The Storage Class extern

The Storage Class register

The Storage Class static

5.12 Static External Variables

5.13 Default Initialization

5.14 Recu rsion

Efficiency Considerations

5.15 An Example: The Towers of Hanoi

Summary

Exercises

Chapter 6

Arrays, Pointers, and Strings

6.1 One-dimensional Arrays

Initialization

Subscripting

6.2 Pointers

6.3 Call-by-Reference

6.4 The Relationship Between Arrays and Pointers

6.5 Pointer Arithmetic and Element Size

6.6 Arrays as Function Arguments

6.7 An Example: Bubble Sort

6.8 Dynamic Memory Allocation With calloc() and malloc()

Offsetting the Pointer

6.9 An Example: Merge and Merge Sort

6.10 Strings

6.11 String-Handling Functions in the Standard Library

6.12 Multidimensional Arrays

Two-dimensional Arrays

The Storage Mapping Function

Formal Parameter Declarations

Three-dimensional Arrays

Initialization

The Use of typedef

6.13 Arrays of Pointers

6.14 Arguments to main()

6.15 Ragged Arrays

6.16 Functions as Arguments

Functions as Formal Parameters in Function Prototypes

6.17 An Example: Using Bisection to Find the Root of a Function

The Kepler Equation

6.18 Arrays of Pointers to Function

6.19 The Type Qualifiers const and volati 1 e

Summary

Exercises

Chapter 7

Bitwise Operators and Enumeration Types

7.1 Bitwise Operators and Expressions

Bitwise Complement

Two's Complement

Bitwise Binary Logical Operators

Left and Right Shift Operators

7.2 Masks

7.3 Software Tools: Printing an int Bitwise

7.4 Packing and Unpacking

Multibyte Character Constants

7.5 Enumeration Types

7.6 An Example: The Game of Paper, Rock, Scissors

Summary

Exercises

Chapter 8

The Preprocessor

8.1 The Use of #include

8.2 The Use of #define

Syntactic Sugar

8.3 Macros with Arguments

8.4 The Type Definitions and Macros in stddef, h

8.5 An Example: Sorting with qsort()

8.6 An Example: Macros with Arguments

8.7 The Macros in stdio, h and ctype.h

8.8 Conditional Compilation

8.9 The Predefined Macros

8.10 The Operators # and ##

8.11 The assert() Macro

8.1 2 The Use of #error and #pragma

8.1 3 Line Numbers

8.14 Corresponding Functions

8.15 An Example: Quicksort

Summary

Exercises

Chapter 9

Structures and Unions

9.1 Structures

9.2 Accessing Members of a Structure

9.3 Operator Precedence and Associativity: A Final Look

9.4 Using Structures with Functions

9.5 Initialization of Structures

9.6 An Example: Playing Poker

9.7 Unions

9.8 Bit Fields

9.9 An Example: Accessing Bits and Bytes

9.10 The ADT Stack

Summary

Exercises

Chapter 10

Structures and List Processing

10.1 Self-referential Structures

10.2 Linear Linked Lists

Storage Allocation

10.3 List Operations

10.4 Some List Processing Functions

Insertion

Deletion

10.5 Stacks

10.6 An Example: Polish Notation and Stack Evaluation

10.7 Queues

10.8 Binary Trees

Binary Tree Traversal

Creating Trees

10.9 General Linked Lists

Traversal

The Use of calloc() and Building Trees

Summary

Exercises

Chapter 1 1

Input/Output and the Operating System

1 1.1 The Output Function printfO

11.2 The Input FunctionscanfO

11.3 The FunctionsfprintfO, fscanf(),sprintfO,

and sscanf()

11.4 The Functionsfopen() and fcloseO

11.5 An Example: Double Spacing a File

11.6 Using Temporary Files and Graceful Functions

11.7 Accessing a File Randomly

11.8 File Descriptor Input/Output

11.9 File Access Permissions

11.10 Executing Commands from Within a C Program

11.11 Using Pipes from Within a C Program

11.12 Environment Variables

11.13 The C Compiler

11.14 Using the Profiler

11.15 Libraries

11.16 How to TimeCCode

11.17 The Use of make

11.18 The Use of touch

11.19 Other Useful Tools

Summary

Exercises

Chapter 12

Advanced Applications

12.1 Creating a Concurrent Process with fork()

12.2 Overlaying a Process: the exec... () Family

Using the spawn...() Family

12.3 Interprocess Communication Using pi pe()

12.4 Signals

1 2.5 An Example: The Dining Philosophers

1 2.6 Dynamic Allocation of Matrices

Why Arrays of Arrays Are Inadequate

Building Matrices with Arrays of Pointers

Adjusting the Subscript Range

Allocating All the Memory at Once

1 2.7 Returning the Status

Summary

Exercises

Chapter 13

Moving from C to C++

13.1 Output

13.2 Input

13.3 Functions

13.4 Classes and Abstract Data Types

13.5 Overloading

13.6 Constructors and Destructors

13.7 Object-oriented Programming and Inheritance

13.8 Polymorphism

13.9 Templates

13.10 C++ Exceptions

13.11 Benefits of Object-oriented Programming

Summary

Exercises

Chapter 14

Moving from C to Java

14.1 Output

14.2 Variables and Types

14.3 Classes and Abstract Data Types

14.4 Overloading

14.5 Construction and Destruction of Class Types

14.6 Object-oriented Programming and Inheritance

14.7 Polymorphism and Overriding Methods

14.8 Applets

14.9 Java Exceptions

14.10 Benefits of Java and OOP

Summary

Exercises

Appendix A

The Standard Library

A.1 Diagnostics:

A.2 Character Handling:

Testing a Character

Mapping a Character

A.3 Errors:

A.4 Floating Limits:

A.5 Integral Limits:

A.6 Localization:

A.7 Mathematics:

A.8 Nonlocal Jumps:

A.9 Signal Handling:

A. 10 Variable Arguments:

A. 11 Common Definitions:

A. 12 Input/Output:

Opening, Closing, and Conditioning a File

Accessing the File Position Indicator

Error Handling

Character Input/Output

Formatted Input/Output

Direct Input/Output

Removing or Renaming a File

A.13 General Utilities:

Dynamic Allocation of Memory

Searching and Sorting

Pseudo Random-Number Generator

Communicating with the Environment

Integer Arithmetic

String Conversion

Multibyte Character Functions

Multibyte String Functions

Leaving the Program

A.14 Memory and String Handling:

Memory-Handling Functions

String-Handling Functions

A.15 Date and Time:

Accessing the Clock

Accessing the Time

A.16 Miscellaneous

File Access

Using File Descriptors

Creating a Concurrent Process

Overlaying a Process

Interprocess Communication

Suspending Program Execution

Appendix B

Language Syntax

B.1 Prog ram

B.2 Function Definition

B.3 Declaration

B.4 Statement

B.5 Expression

B.6 Constant

B.7 String Literal

B.8 Preprocessor

Appendix C

ANSI C Compared to Traditional C

C.1 Types

C.2 Constants

C.3 Declarations

C.4 Initializations

C.5 Expressions

C.6 Functions

C.7 Conversions

C.8 Array Pointers

C.9 Structures and Unions

C.10 Preprocessor

C.11 Header Files

C.12 Miscellaneous

Appendix D

ASCII Character Codes

Appendix E

Operator Precedence and Associativity

Index

版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://blog.csdn.net/weixin_39622419/article/details/117104337

智能推荐

js-选项卡原理_选项卡js原理-程序员宅基地

文章浏览阅读90次。【代码】js-选项卡原理。_选项卡js原理

设计模式-原型模式(Prototype)-程序员宅基地

文章浏览阅读67次。原型模式是一种对象创建型模式,它采用复制原型对象的方法来创建对象的实例。它创建的实例,具有与原型一样的数据结构和值分为深度克隆和浅度克隆。浅度克隆:克隆对象的值类型(基本数据类型),克隆引用类型的地址;深度克隆:克隆对象的值类型,引用类型的对象也复制一份副本。UML图:具体代码:浅度复制:import java.util.List;/*..._prototype 设计模式

个性化政府云的探索-程序员宅基地

文章浏览阅读59次。入选国内首批云计算服务创新发展试点城市的北京、上海、深圳、杭州和无锡起到了很好的示范作用,不仅促进了当地产业的升级换代,而且为国内其他城市发展云计算产业提供了很好的借鉴。据了解,目前国内至少有20个城市确定将云计算作为重点发展的产业。这势必会形成新一轮的云计算基础设施建设的**。由于云计算基础设施建设具有投资规模大,运维成本高,投资回收周期长,地域辐射性强等诸多特点,各地在建...

STM32问题集之BOOT0和BOOT1的作用_stm32boot0和boot1作用-程序员宅基地

文章浏览阅读9.4k次,点赞2次,收藏20次。一、功能及目的 在每个STM32的芯片上都有两个管脚BOOT0和BOOT1,这两个管脚在芯片复位时的电平状态决定了芯片复位后从哪个区域开始执行程序。BOOT1=x BOOT0=0 // 从用户闪存启动,这是正常的工作模式。BOOT1=0 BOOT0=1 // 从系统存储器启动,这种模式启动的程序_stm32boot0和boot1作用

C语言函数递归调用-程序员宅基地

文章浏览阅读3.4k次,点赞2次,收藏22次。C语言函数递归调用_c语言函数递归调用

明日方舟抽卡模拟器wiki_明日方舟bilibili服-明日方舟bilibili服下载-程序员宅基地

文章浏览阅读410次。明日方舟bilibili服是一款天灾驾到战斗热血的创新二次元废土风塔防手游,精妙的二次元纸片人设计,为宅友们源源不断更新超多的纸片人老婆老公们,玩家将扮演废土正义一方“罗德岛”中的指挥官,与你身边的感染者们并肩作战。与同类塔防手游与众不同的几点,首先你可以在这抽卡轻松获得稀有,同时也可以在战斗体系和敌军走位机制看到不同。明日方舟bilibili服设定:1、起因不明并四处肆虐的天灾,席卷过的土地上出..._明日方舟抽卡模拟器

随便推点

Maven上传Jar到私服报错:ReasonPhrase: Repository version policy: SNAPSHOT does not allow version: xxx_repository version policy snapshot does not all-程序员宅基地

文章浏览阅读437次。Maven上传Jar到私服报错:ReasonPhrase: Repository version policy: SNAPSHOT does not allow version: xxx_repository version policy snapshot does not all

斐波那契数列、素数、质数和猴子吃桃问题_斐波那契日-程序员宅基地

文章浏览阅读1.2k次。斐波那契数列(Fibonacci Sequence)是由如下形式的一系列数字组成的:0, 1, 1, 2, 3, 5, 8, 13, 21, 34, …上述数字序列中反映出来的规律,就是下一个数字是该数字前面两个紧邻数字的和,具体如下所示:示例:比如上述斐波那契数列中的最后两个数,可以推导出34后面的数为21+34=55下面是一个更长一些的斐波那契数列:0, 1, 1, 2, 3, 5, 8, 13, 21, 34, 55, 89, 144, 233, 377, 610, 987, 1597, 2584,_斐波那契日

PHP必会面试题_//该层循环用来控制每轮 冒出一个数 需要比较的次数-程序员宅基地

文章浏览阅读363次。PHP必会面试题1. 基础篇1. 用 PHP 打印出前一天的时间格式是 2017-12-28 22:21:21? //>>1.当前时间减去一天的时间,然后再格式化echo date('Y-m-d H:i:s',time()-3600*24);//>>2.使用strtotime,可以将任何字符串时间转换成时间戳,仅针对英文echo date('Y-m-d H:i:s',str..._//该层循环用来控制每轮 冒出一个数 需要比较的次数

windows用mingw(g++)编译opencv,opencv_contrib,并install安装_opencv mingw contrib-程序员宅基地

文章浏览阅读1.3k次,点赞26次,收藏26次。windows下用mingw编译opencv貌似不支持cuda,选cuda会报错,我无法解决,所以没选cuda,下面两种编译方式支持。打开cmake gui程序,在下面两个框中分别输入opencv的源文件和编译目录,build-mingw为你创建的目录,可自定义命名。1、如果已经安装Qt,则Qt自带mingw编译器,从Qt安装目录找到编译器所在目录即可。1、如果已经安装Qt,则Qt自带cmake,从Qt安装目录找到cmake所在目录即可。2、若未安装Qt,则安装Mingw即可,参考我的另外一篇文章。_opencv mingw contrib

5个高质量简历模板网站,免费、免费、免费_hoso模板官网-程序员宅基地

文章浏览阅读10w+次,点赞42次,收藏309次。今天给大家推荐5个好用且免费的简历模板网站,简洁美观,非常值得收藏!1、菜鸟图库https://www.sucai999.com/search/word/0_242_0.html?v=NTYxMjky网站主要以设计类素材为主,办公类素材也很多,简历模板大部个偏简约风,各种版式都有,而且经常会更新。最重要的是全部都能免费下载。2、个人简历网https://www.gerenjianli.com/moban/这是一个专门提供简历模板的网站,里面有超多模板个类,找起来非常方便,风格也很多样,无须注册就能免费下载,_hoso模板官网

通过 TikTok 联盟提高销售额的 6 个步骤_tiktok联盟-程序员宅基地

文章浏览阅读142次。你听说过吗?该计划可让您以推广您的产品并在成功销售时支付佣金。它提供了新的营销渠道,使您的产品呈现在更广泛的受众面前并提高品牌知名度。此外,TikTok Shop联盟可以是一种经济高效的产品或服务营销方式。您只需在有人购买时付费,因此不存在在无效广告上浪费金钱的风险。这些诱人的好处是否足以让您想要开始您的TikTok Shop联盟活动?如果是这样,本指南适合您。_tiktok联盟