社区
C语言
帖子详情
char c='\72'中的'\72'怎么解释
J513930673
2011-02-08 09:44:26
char c='\72';
printf("%c\n",c);
运行后显示的是 “ :”
可否解释一下为什么么?
...全文
2196
15
打赏
收藏
char c='\72'中的'\72'怎么解释
char c='\72'; printf("%c\n",c); 运行后显示的是 “ :” 可否解释一下为什么么?
复制链接
扫一扫
分享
转发到动态
举报
写回复
配置赞助广告
用AI写文章
15 条
回复
切换为时间正序
请发表友善的回复…
发表回复
打赏红包
AnYidan
2011-02-09
打赏
举报
回复
八进制数!
顶
yukiwang313
2011-02-09
打赏
举报
回复
[Quote=引用 2 楼 lactoferrin 的回复:]
这里的72是八进制的,10进制就是58,再去查ascii码表就清楚了
[/Quote]]
++
ningweidong
2011-02-09
打赏
举报
回复
查acsii表
wizard_tiger
2011-02-09
打赏
举报
回复
\72表示八进制按ASCII码转换可转换1~3位。
\x72表示十六进制按ASCII码转换可转换1~2位。
ischarles
2011-02-08
打赏
举报
回复
请看printf函数的说明:
http://resin.csoft.net/cgi-bin/man.cgi?section=3&topic=printf
其中有一句
\num Write an 8-bit character whose ASCII value is the 1-, 2-, or 3-digit
octal number
(八进制数) num.
因此\72中的72表示ASCII码中八进制为72的那个符号,
查表
后的结果就是冒号
C33ssss666
2011-02-08
打赏
举报
回复
那个表要怎么看 感觉不对啊 你怎么看出来那个是八进制的啊 \ 在ASCII里是控制字符啊 与八进制怎么对上号啊
goolloo
2011-02-08
打赏
举报
回复
[Quote=引用 2 楼 lactoferrin 的回复:]
这里的72是八进制的,10进制就是58,再去查ascii码表就清楚了
[/Quote]
怎么知道是八进制的?
J513930673
2011-02-08
打赏
举报
回复
我知道是八进制啊!但是是怎么看出来的呢?我就想知道是不是用“\..”时,“..”就是表示一个八进制
good778899
2011-02-08
打赏
举报
回复
":"ASCII码,10进制是58;58换成8进制就是72;有'\'代表转义字符
我的职业是看店铺的
2011-02-08
打赏
举报
回复
ASCII码表 http://www.96yx.com/tool/ASC2.htm
原来是八进制的,呵呵 明白了,高手就是不一样
cranium
2011-02-08
打赏
举报
回复
\72是八进制的。
http://www.asciitable.com/
masmaster
2011-02-08
打赏
举报
回复
八进制
Lactoferrin
2011-02-08
打赏
举报
回复
这里的72是八进制的,10进制就是58,再去查ascii码表就清楚了
我的职业是看店铺的
2011-02-08
打赏
举报
回复
查了ascii 码表 和unicode编码 还是不知道
顶下 看楼下解释
编译原理实验报告 语法分析 语义分析 词法分析 详细的源程序
附录c 编译程序实验 实验目的:用c语言对一个简单语言的子集编制一个一遍扫描的编译程序,以加深对编译原理的理解,掌握编译程序的实现方法和技术。 语法分析 C2.1 实验目的 编制一个递归下降分析程序,实现对词法分析程序所提供的单词序列的语法检查和结构分析. C2.2 实验要求 利用C语言编制递归下降分析程序,并对简单语言进行语法分析. C2.2.1待分析的简单语言的语法 实验目的 通过上机实习,加深对语法制导翻译原理的理解,掌握将语法分析所识别的语法成分变换为
中
间代码的语义翻译方法. 实验要求 采用递归下降语法制导翻译法,对算术表达式、赋值语句进行语义分析并生成四元式序列。 实验的输入和输出 输入是语法分析提供的正确的单词串,输出为三地址指令形式的四元式序列。 例如:对于语句串 begin a:=2+3*4;x:=(a+b)/c end# 输出的三地址指令如下: (1) t1=3*4 (2) t2=2+t1 (3) a=t2 (4) t3=a+b (5) t4=t3/c (6) x=t4 算法思想 1设置语义过程 (1) emit(
char
*result,
char
*arg1,
char
*op,
char
*ag2) 该函数功能是生成一个三地址语句送到四元式表
中
。 四元式表的结构如下: struct {
char
result[8];
char
ag1[8];
char
op[8];
char
ag2[8]; }quad[20]; (2)
char
*newtemp() 该函数回送一个新的临时变量名,临时变量名产生的顺序为T1,T2,….
Char
*newtemp(void) {
char
*p;
char
m[8]; p=(
char
*)malloc(8); k++; itoa(k,m,10); strcpy(p+1,m); p[0]=’t’; return(p); } (2)主程序示意图如图c.10所示。 (2) 函数lrparser在原来语法分析的基础上插入相应的语义动作:将输入串翻译成四元式序列。在实验
中
我们只对表达式、赋值语句进行翻译。 语义分析程序的C语言程序框架 int lrparser() { int schain=0; kk=0; if(syn=1) { 读下一个单词符号; schain=yucu; /调用语句串分析函数进行分析/ if(syn=6) { 读下一个单词符号; if(syn=0 && (kk==0)) 输出(“success”); } else { if(kk!=1 ) 输出 ‘缺end’ 错误;kk=1;} else{输出’begin’错误;kk=1;} } return(schain); int yucu() { int schain=0; schain=statement();/调用语句分析函数进行分析/ while(syn=26) {读下一个单词符号; schain=statement(); /调用语句分析函数进行分析/ } return(schain); } int statement() {
char
tt[8],eplace[8]; int schain=0; {switch(syn) {case 10: strcpy(tt,token); scanner(); if(syn=18) {读下一个单词符号; strcpy(eplace,expression()); emit(tt,eplace,””,””); schain=0; } else {输出’缺少赋值号’的错误;kk=1; } return(schain); break; } }
char
*expression(void) {
char
*tp,*ep2,*eplace,*tt; tp=(
char
*)malloc(12);/分配空间/ ep2=(
char
*)malloc(12); eplace=(
char
*)malloc(12); tt =(
char
)malloc(12); strcpy(eplace,term ());/调用term分析产生表达式计算的第一项eplace/ while(syn=13 or 14) { 操作符 tt= ‘+’或者‘—’; 读下一个单词符号; strcpy(ep2,term());/调用term分析产生表达式计算的第二项ep2/ strcpy(tp,newtemp());/调用newtemp产生临时变量tp存储计算结果/ emit(tp,eplace,tt,ep2);/生成四元式送入四元式表/ strcpy(eplace,tp); } return(eplace); }
char
*term(void)/仿照函数expression编写/
char
*factor(void) {
char
*fplace; fplace=(
char
*)malloc(12); strcpy(fplace, “ ”); if(syn=10) {strcpy(fplace,,token);/将标识符token的值赋给fplace/ 读下一个单词符号; } else if(syn=11) {itoa(sum,fplace,10); 读下一个单词符号; } else if (syn=27) {读下一个单词符号; fplace=expression();/调用expression分析返回表达式的值/ if(syn=28) 读下一个单词符号; else{输出‘}’错误;kk=1; } } else{输出‘(’错误;kk=1; } return(fplace); }
char
c = 1
char
c = "1"
char
c = '1'
char
c = 1 表示ASCII码=1的字符
char
c = "1" 语法错误
char
c = '1' 表示1这个字符 #include int main() {
char
a=1,b='1'; printf("%c %c\n",a,b);// 输出ASCII为1的字符和字符'1' return 0; } ASCII第一次以规范标准的型态发表是在1967
C语言
中
char
c=0和c='\0'的区别
2019独角兽企业重金招聘Python工程师标准>>> ...
C语言
char
类型数据的易错题
一.截断与整型提升 int main() {
char
a = -1; signed
char
b = -1; unsigned
char
c = -1; printf("%d\t%d\t%d\t", a, b, c); return 0; } 输出结果:-1,-1,255
解释
: 1.
char
a=-1;-1的补码为11111111111111111111111111111111,
char
类型的将整型a截断存储为一个字节11111111,打印时是按整型进行打印的,要发生整型提升,按其
对
char
x='abcd'的
解释
问题:
char
x='abcd';
x=?
答案是:x=d;
为什么呢?
详解:
char
x='abcd'
中
的'abcd'被存储为一个int型的整数,这个整数的值是:
一个int数值 :(97<<8<<8<<8)+(98<<8<<8)+(99<<8)+100);
其
中
97是'a'的ASCII码;
其
中
98是'b'的ASCII码;
其
中
99是'c'的ASCII
C语言
70,014
社区成员
243,263
社区内容
发帖
与我相关
我的任务
C语言
C语言相关问题讨论
复制链接
扫一扫
分享
社区描述
C语言相关问题讨论
社区管理员
加入社区
获取链接或二维码
近7日
近30日
至今
加载中
查看更多榜单
社区公告
暂无公告
试试用AI创作助手写篇文章吧
+ 用AI写文章