C语言常用转义字符

言语常用转义字符表

  昨天借了一样照《网络程序设计实验教程(java语言)》,然后看了第一回,一个Swing例子,于是也大家享用一下!

  关于数据的编码和解码,我道就例子而言已经供认得很了解了,两种办法做的。

转义字符

含义

ASCII码(16/10进制)

\o

空字符(NULL)

00H/0

\n

换行符(LF)

0AH/10

\r

回车符(CR)

0DH/13

\t

水平制表符(HT)

09H/9

\v

垂直制表(VT)

0B/11

\a

响铃(BEL)

07/7

\b

退格符(BS)

08H/8

\f

换页符(FF)

0CH/12

\’

单引号

27H/39

\”

双引号

22H/34

\\

反斜杠

5CH/92

\?

问号字符

3F/63

\ddd

任意字符

三位八进制

\xhh

任意字符

二位十六进制

图片 1

字符常量中运用单引号和反斜杠以及字符常量中行使对引号和倒斜杠时,都必须使转义字符表示,即当这些字符前增长反斜杠。
   以C程序中使转义字符\ d d d或者\ x h
h可以便宜灵活地代表任意字符。\ d d
d为斜杠后面和三员八上制数,该三位八向前制数的值即为相应的八迈入制A S C I
I码值。\ x后面和两各项十六上前制数,该少各十六前进制数为对承诺字符的十六进制A S
C I I码值。

  将该转为16上制来弄的

使转义字符时用留意以下问题:
1)
转义字符中不得不动用小写字母,每个转义字符只能当一个字符。
2) \v 垂直制表和\f
换页符对屏幕没有其余影响,但会潜移默化打印机执行响应操作。
3) 在C程序中,使用不可打印字符时,通常用转义字符表示

//utf8解码
        btnUTF8Decode = new JButton("UTF8\u89E3\u7801\u7801\u7ED3\u679C");
        btnUTF8Decode.addMouseListener(new MouseAdapter() {
            @Override
            public void mouseClicked(MouseEvent e) {
                String hexStr = tfBytes.getText();
                String[] strs = hexStr.split(" ");
                byte[] bytes = new byte[strs.length];
                for (int i=0;i<strs.length; i++){
                    bytes[i] = (byte) Integer.valueOf(strs[i],16).intValue();
                }
                String string = "";
                try {
                    string = new String(bytes,"UTF-8");
                } catch (UnsupportedEncodingException e2) {
                    // TODO: handle exception
                    e2.printStackTrace();
                }finally {
                    tfCharsUTF8.setText(string);
                }
            }
        });

注:
1,\v垂直制表和\f换页符对屏幕没有其余影响,但会潜移默化打印机执行响应操作。
2,\n其实应该受回车换行。换行只是更换一行,不转光标的横坐标;回车只是回到行首,不改变光标的纵坐标。
3,\t 光标上挪动四格或八格,可以于编译器里设置
4,\’ 于字符里(即单引号里)使用。在字符串里(即对引号里)不欲,只要用
‘ 即可。
5,\? 其实不必要。只要用 ? 就可了(在windows VC6 和tc2 中证明)。

 


//gbk解码
        btnGBKDecode = new JButton("GBK\u89E3\u7801\u7ED3\u679C");
        btnGBKDecode.addMouseListener(new MouseAdapter() {
            @Override
            public void mouseClicked(MouseEvent e) {
                String hexStr = tfBytes.getText().toString().trim();
                String[] strs = hexStr.split(" ");
                byte[] array = new byte[strs.length];
                for (int i=0; i<strs.length; i++){
                    array[i] = (byte) Integer.valueOf(strs[i],16).intValue();
                }
                Charset cs = Charset.forName("GBK");
                CharBuffer buffer = cs.decode(java.nio.ByteBuffer.wrap(array));
                tfCharsGBK.setText(buffer.toString());
            }
        });

格式控制入参考:

 


//UTF8编码
        btnUTF8Encode = new JButton("UTF8\u7F16\u7801\u7ED3\u679C");
        btnUTF8Encode.addMouseListener(new MouseAdapter() {
            @Override
            public void mouseClicked(MouseEvent e) {
                String str = tfChars.getText();
                String hexStr = "";
                try {
                    byte[] bytes = str.getBytes("UTF-8");
                    for (int i=0; i<bytes.length; i++){
                        hexStr += Integer.toHexString(bytes[i] & 0xFF).toUpperCase()+" ";
                    }
                } catch (UnsupportedEncodingException e2) {
                    // TODO: handle exception
                    e2.printStackTrace();
                }finally {
                    tfBytesUTF8.setText(hexStr);
                }
            }
        });

//编码GBK
        JButton btnGBKEncode = new JButton("GBK\u7F16\u7801\u7ED3\u679C");
        btnGBKEncode.addMouseListener(new MouseAdapter() {
            @Override
            public void mouseClicked(MouseEvent e) {
                String str = tfChars.getText().toString().trim();
                Charset cs = Charset.forName("GBK");
                java.nio.ByteBuffer buffer = cs.encode(str);
                String hexStr = "";
                while (buffer.remaining() > 0){
                    hexStr += Integer.toHexString(buffer.get() & 0xFF).toUpperCase() + " ";
                }
                tfBytesGBK.setText(hexStr);
            }
        }); 

对64个整数的输入输出,在POJ上的C++环境下(即VC++),64位整数是:
__int64
输入输出格式为”%I64d”.

当G++环境下, 64各项整数是
long long
输入输出格式为”%lld”.

域宽和精度的叙述

  M:域宽,即对应的输出项在输出设备上所占字符数

      若:实际多少涨幅>M,按实际上数据小幅输出。

        实际数目大幅度<M,左边补空。

  N:精度,说明出口的实型数之微数位数。

几乎触及说明:

    编译程序只是检查printf
函数的调用形式,不分析格式控制字符串,如果格式字符与输出项的色不兼容,不开展类型转换。(输出的屡屡为擅自)

    格式字符要用小写字母。

    格式控制字符串中好蕴涵转义字符。

    格式控制字符串中之普通字符则形容输出。

    输出项之参数除了常数、变量外还得是表达式、函数调用。

       
%g,%f和%e这三单格式用于打印浮点值。
%g格式用于打印那些未欲按列对同之浮点数特别发因此。其意图有第二:
一如既往,去丢该数尾多余的零碎(没有达到六位的累)
次,保留六各类中数字(多余六各项之)
%e格式用于打印浮点数时,一律显示地采用指数形式:例如:输出圆周率时凡:3.141593e+00
彼此的区别:
%g格式打印出底多次是凡6各类中数字
%e格式打印出些许数点后的6各中数字
%f禁止使用指数形式来表示浮点数。因此圆周率输出为:3.141593
(但注意它的精度要求:也是微数点后6各类中数字)
(8)%%格式用于打印一个%字符。
(9)%E和%G只是于出口时用特别写字母(E)代替了小写字母(e)

                输出正负号的技巧,例如:
printf(“%+d %+d %+d\n”,-5,0,5);
使以当中加个“+”号就是实行。作用是出口符号各(即,数之正负号)
若果非期望正数的前头出现‘+’号,可用下面的不二法门
如若以当中加个“ ”号(即:空格)就实行。例如:
打算:如果一个反复是匪负数,就以它们的前面插入一个空格。
int i;
for(i=-3;i<=3;i++)
printf(“% d\n”,i); //注意%跟d之间时有发生一个空格

           

sscanf()的施用技巧:
说字符串,很多效益都用正则表达式的文化,所以即便介绍一下无比简便易行的几栽用sscanf来诠释字符串
的用法。

  1. char str[100],str1[100],str2[100];
    gets(str);
    sscanf(str,”%s%s”,str1,str2);
    用读入的一整行字符串按空格,制表符或回车符分割成稀个字符串。
    2
    获取指定长度的字符串。如以下例中,取最好充分长为4字节的字符串。
    sscanf(“123456 “, “%4s”, str);

核心整型:两单字节,十六单bit(位)

11 11 11 11 11 11 11 11   等于
65535.

11 11 11 11 11 11 11 10    
等于 -2.

负数的首先个(符号个)为1。负数的补码怎么抱:原码取反加一。2底亚向前制数为:00
00 00 00 00 00 00 10,取反就等11 11 11 11 11 11 11
01,然后加1,二进制数逢二上同,所以就是得出-2 的亚迈入制代码。

生记号的整型数得据此 %d 输出。

无符号的整型数得为此 %u 输出。

计算机里存的数字还是亚迈入制数,最高位是符号位或数据位,可以由输出格式符来控制。

仲前进制数转换八前进制数:三只 1 应和一个 7

其次向前制数錾十六进制数:四位二进制对应一号十六进制,四单1
相应一个 f。

说明: 

格式字符:c   输出一个字符。

     s   输出一个字符串。

     e   以指数形式出口实型数。

     f    
以小数形式出口实型数。

     g   自动决定输出格式为e和f中比短的均等种植,不打印无效的碎片。

     %   输出%。

注意:对于只有精度往往,使用 %f
格式符输出时,仅前7号是有效数字,小数6各类。

   对于对精度往往,使用 %lf
格式符输出时,前16员是卓有成效数字,小数6位。

长修正符

  l:对整型指定长整型long

      例:%ld , %lx , %lo ,
%lu

    对实型指定双精度double

           例:%lf

   
h:只用于整型的格式字符修正为short

           例:%hd , %hx , %ho ,
%hu

格式输出字符:printf

动用:向终极输出若干个类型任意的数额。

形式:printf
(格式控制符,输出列表)

说明:

格式控制符:%  格式说明引导合。

      -  指定左对共同输出。

      0  指定空位填零。

      m.n
指定输出域宽度与精度。

      l.h 输出长度的修正。

     格式字符   指定输出的数据类型。

说明:

格式字符:指定输出项的数据类型和出口格式。

     d  有记号十进制整数。

     o  无符号八上制数。

     x  无符号十六上前制数。(小写的x格式中用小写字母a,b,c,d,e,f来代表10及15里边的多次,大写的X则就此小写的ABCDEF来代表10交15以内的反复)

     u  不带来符号的十进制整数。

发表评论

电子邮件地址不会被公开。 必填项已用*标注

网站地图xml地图