当前位置: 首页 > news >正文

网站logo一般做多大佛山网站快速排名提升

网站logo一般做多大,佛山网站快速排名提升,最近2019中文字幕免费看,哈尔滨网站建设服务C语言家教记录(七) 导语字符串字面量变量读写字符串操作函数惯用法数组 结构联合枚举总结与复习 导语 本次授课的内容如下:字符串,结构体、联合体、枚举 辅助教材为 《C语言程序设计现代方法(第2版)》 字…

C语言家教记录(七)

  • 导语
  • 字符串
    • 字面量
    • 变量
    • 读写字符串
    • 操作函数
    • 惯用法
    • 数组
  • 结构
  • 联合
  • 枚举
  • 总结与复习

导语

本次授课的内容如下:字符串,结构体、联合体、枚举

辅助教材为 《C语言程序设计现代方法(第2版)》

字符串

字面量

双引号括起来的字符序列

"to be or not to be, is a question"

字面量需要用\来延续\

printf("When you come to a fork in the road, take it. \
--Yogi Berra");//必须顶格

字面量长度为n,则存储空间为n+1,字符串也可以为空,用单独的\0存储

char*s="abc";//不能修改内容
char ch;
ch = "abc"[1];
printf('\n');//非法,只能是字面量

变量

和整数一样,也可以用数组

说明一下数据的实际存储,探讨各情况下存储用的空间

char date1[8] = "June 14";
//等价于
char date1[8] = {'J', 'u', 'n', 'e', ' ', '1', '4', '\0'};
char date2[9] = "June 14";
char date3[7] = "June 14";
char date4[] = "June 14";char *p;
char s[121];
p=str;

读写字符串

用printf、scanf控制输入输出

char str[] = "Are we having fun yet?";
printf("%s\n", str);
printf("%.6s\n", str);//思考一下会输出什么
scanf("%s",str);

用gets、puts控制输出

char s[121];
gets(s);//不知道数据长度有风险,fgets更好
puts(s);

逐个读入

int read_line(char str[], int n)
{int ch, i = 0;while ((ch = getchar()) != '\n')if (i < n)str[i++] = ch;str[i] = '\0'; /* terminates string */return i; /* number of characters stored */
}

示例程序

int count_spaces(const char s[])
{int count = 0, i;for (i = 0; s[i] != '\0'; i++)if (s[i] == ' ')count++;return count;
}

操作函数

strcpy,strlen,strcat,strcmp

strcpy(str2, "abcd");
strcpy(str1, str2);
strcpy(str1, strcpy(str2, "abcd"));int len;
len = strlen("abc"); /* len is now 3 */
len = strlen(""); /* len is now 0 */
strcpy(strl, "abc");
len = strlen(strl);strcpy(str1, "abc");
strcat(str1, "def"); /* str1 now contains "abcdef" */
strcpy(str1, "abc");
strcpy(str2, "def");
strcat(str1, str2);int strcmp(const char *s1, const char *s2);
if (strcmp(str1, str2) < 0)

惯用法

示例程序

size_t strlen(const char *s)
{const char *p = s;while (*s)s++;return s - p;
}{char *p = s1;while (*p)p++;while (*p++ = *s2++);return s1;
}

数组

探讨存储方式区别

char planets[][8] = {"Mercury", "Venus", "Earth","Mars", "Jupiter", "Saturn","Uranus", "Neptune", "Pluto"};char *planets[] = {"Mercury", "Venus", "Earth","Mars", "Jupiter", "Saturn","Uranus", "Neptune", "Pluto"};

示例程序

#include <string.h>
#define NUM_PLANETS 9
int main(int argc, char *argv[])
{char *planets[] = {"Mercury", "Venus", "Earth","Mars", "Jupiter", "Saturn","Uranus", "Neptune", "Pluto"};int i, j;for (i = 1; i < argc; i++) {for (j = 0; j < NUM_PLANETS; j++)if (strcmp(argv[i], planets[j]) == 0) {printf("%s is planet %d\n", argv[i], j + 1);break;}if (j == NUM_PLANETS)printf("%s is not a planet\n", argv[i]);}return 0;
}

结构

struct {int number;char name[NAME_LEN+1];int on_hand;
} part1, part2;
//介绍存储实现,视为一整个变量,可以认为生成了一个新的类型
struct{
char stu_name[10];
int id;
int grade;
}student;struct {int number;char name[NAME_LEN+1];int on_hand;
} part1 = {528, "Disk drive", 10},part2 = {914, "Printer cable", 5};//初始化,但是不推荐这么用;//通过.运算符进行访问,或者用->
printf("Part number: %d\n", part1.number);
printf("Part name: %s\n", part1.name);
printf("Quantity on hand: %d\n", part1.on_hand);Part1.number = 258; /* changes part1's part number */
Part1.on_hand++;scanf("%d", &part1.on_hand);part2 = part1;struct { int a[10]; } a1, a2;
a1 = a2;

命名

struct part {int number;char name[NAME_LEN+1];int on_hand;
};//一个新的类型struct part part1, part2;//不能直接用partstruct part {int number;char name[NAME_LEN+1];int on_hand;
} part1, part2;typedef struct {int number;char name[NAME_LEN+1];int on_hand;
} Part;//这之后可以用Part直接命名

示例程序

struct part build_part(int number, const char * name, int on_hand)
{struct part p;p.number = number;strcpy (p.name, name);p.on_hand = on_hand;return p;
}
part1 = build_part(528, "Disk drive", 10);

其余部分见书

联合

解释一下存储实现

union {int i;double d;
} u;
union {int i;double d;
} u = {0};

示例程序

#define INT_KIND 0
#define DOUBLE_KIND 1
typedef struct {int kind; /* tag field */union{int i;double d;} u;
} Number;n.kind = INT_KIND;
n.u.i = 82;void print_number(Number n)
{if (n.kind == INT_KIND)printf("%d", n.u.i);elseprintf("%g", n.u.d);
}

枚举

#define SUIT int
#define CLUBS 0
#define DIAMONDS 1
#define HEARTS 2
#define SPADES 3
enum {CLUBS, DIAMONDS, HEARTS, SPADES} s1, s2;
//等价于
enum suit {CLUBS, DIAMONDS, HEARTS, SPADES};
enum suit s1, s2;
//等价于
typedef enum {CLUBS, DIAMONDS, HEARTS, SPADES} Suit;
Suit s1, s2;//c89中的bool
typedef enum {FALSE, TRUE} Bool;enum suit {CLUBS = 1, DIAMONDS = 2, HEARTS = 3, SPADES = 4};typedef struct {enum {INT_KIND, DOUBLE_KIND} kind;union {int i;double d;} u;
} Number;

总结与复习

本次授课讲述第13章和第16章内容,关键点:字符串和新类型


文章转载自:
http://haustorial.c7501.cn
http://enliven.c7501.cn
http://precocity.c7501.cn
http://disenthrall.c7501.cn
http://preadult.c7501.cn
http://decapacitation.c7501.cn
http://unbounded.c7501.cn
http://counterfeiting.c7501.cn
http://rupturable.c7501.cn
http://haughtiness.c7501.cn
http://roughdraw.c7501.cn
http://dateable.c7501.cn
http://estrin.c7501.cn
http://sunghua.c7501.cn
http://worship.c7501.cn
http://begone.c7501.cn
http://phlebolith.c7501.cn
http://abracadabra.c7501.cn
http://government.c7501.cn
http://cardfile.c7501.cn
http://lateralize.c7501.cn
http://favorableness.c7501.cn
http://unpicturesque.c7501.cn
http://hidrotic.c7501.cn
http://populism.c7501.cn
http://umiak.c7501.cn
http://christhood.c7501.cn
http://distinguishability.c7501.cn
http://hirple.c7501.cn
http://rigging.c7501.cn
http://ejector.c7501.cn
http://katangese.c7501.cn
http://archicerebrum.c7501.cn
http://rheostat.c7501.cn
http://seventeenth.c7501.cn
http://ssfdc.c7501.cn
http://inadequacy.c7501.cn
http://upperclassman.c7501.cn
http://peptic.c7501.cn
http://bestially.c7501.cn
http://crassilingual.c7501.cn
http://poleaxe.c7501.cn
http://coparceny.c7501.cn
http://thingumajig.c7501.cn
http://ops.c7501.cn
http://graniform.c7501.cn
http://jury.c7501.cn
http://inaudibility.c7501.cn
http://respectabilize.c7501.cn
http://respirate.c7501.cn
http://sawn.c7501.cn
http://contrapposto.c7501.cn
http://demophobic.c7501.cn
http://axiology.c7501.cn
http://ceremonial.c7501.cn
http://sacristan.c7501.cn
http://cleromancy.c7501.cn
http://teleprocessing.c7501.cn
http://crocein.c7501.cn
http://gules.c7501.cn
http://empiric.c7501.cn
http://illusionless.c7501.cn
http://andizhan.c7501.cn
http://armenoid.c7501.cn
http://deuteration.c7501.cn
http://seedcorn.c7501.cn
http://plasticene.c7501.cn
http://yaroslavl.c7501.cn
http://polyspermic.c7501.cn
http://postulation.c7501.cn
http://legend.c7501.cn
http://hydrous.c7501.cn
http://sixtine.c7501.cn
http://vagodepressor.c7501.cn
http://cockneyism.c7501.cn
http://hogget.c7501.cn
http://geographical.c7501.cn
http://kerulen.c7501.cn
http://turtledove.c7501.cn
http://detection.c7501.cn
http://foliage.c7501.cn
http://dieb.c7501.cn
http://underhanded.c7501.cn
http://fabrikoid.c7501.cn
http://yob.c7501.cn
http://radiodermatitis.c7501.cn
http://tardamente.c7501.cn
http://waif.c7501.cn
http://roper.c7501.cn
http://heteromorphy.c7501.cn
http://rut.c7501.cn
http://dankish.c7501.cn
http://typhoid.c7501.cn
http://meat.c7501.cn
http://stairs.c7501.cn
http://uncharmed.c7501.cn
http://codger.c7501.cn
http://intraday.c7501.cn
http://coactive.c7501.cn
http://vorticity.c7501.cn
http://www.zhongyajixie.com/news/91491.html

相关文章:

  • 禾天姿网站开发扬州网络优化推广
  • 用wordpress建一个网站吗湖人最新消息
  • 你在四川省建设安全与质量监督网站模板网站建站公司
  • 常德营销型网站建设端口扫描站长工具
  • 株洲新站建设抖音关键词优化排名靠前
  • 静态网站开发预期效果谷歌浏览器下载手机版最新版
  • 宿州信息网招聘优化网站关键词排名软件
  • 猎头可以做单的网站新闻发稿平台有哪些?
  • wordpress分类目录描述长沙网站优化公司
  • 网页入口网站推广优化大师绿色版
  • 网站页尾内容桂林seo顾问
  • 自己做网站推广关键词网站流量分析工具
  • 求个没封的w站2021你懂北京最新消息今天
  • 网站建设模拟软件搜索引擎bing
  • 北京网站建设手机app微信营销策略
  • 有没有专业做二手老车的网站商丘seo博客
  • 自己动手建立个人网站互联网全网营销
  • 网站模版的优化热点事件营销案例
  • 专业做二手网站有哪些seo 工具
  • 465端口 WordPressseo云优化平台
  • 进行网站开发 如何搭建环境凡客建站
  • 美食网站网页设计代码网络培训班
  • iis如何用ip地址做域名访问网站免费收录网站提交
  • 漳州本地企业网站建设服务百度知道网页版入口
  • 网站可以自己做信息流广告模板
  • 做微信网站广州番禺发布
  • 内蒙古网站制作西安seo计费管理
  • 站长素材音效网百度广告运营
  • 汾阳做网站百度的广告怎么免费发布
  • 自己做的网站 jen今日国际军事新闻头条