-
當(dāng)前位置:首頁 > 創(chuàng)意學(xué)院 > 技術(shù) > 專題列表 > 正文
character的定義(char定義的是什么)
大家好!今天讓創(chuàng)意嶺的小編來大家介紹下關(guān)于character的定義的問題,以下是小編對(duì)此問題的歸納整理,讓我們一起來看看吧。
ChatGPT國內(nèi)免費(fèi)在線使用,一鍵生成原創(chuàng)文章、方案、文案、工作計(jì)劃、工作報(bào)告、論文、代碼、作文、做題和對(duì)話答疑等等
只需要輸入關(guān)鍵詞,就能返回你想要的內(nèi)容,越精準(zhǔn),寫出的就越詳細(xì),有微信小程序端、在線網(wǎng)頁版、PC客戶端
官網(wǎng):https://ai.de1919.com
本文目錄:
一、c語言中char的用法是什么意思
C語言是計(jì)算機(jī)軟件領(lǐng)域非常經(jīng)典的編程語言,C語言中char的作用有哪些你了解嗎。下面我就跟你們?cè)敿?xì)介紹下c語言中char的用法,希望對(duì)你們有用。
c語言中char的用法:c語言中char的用法簡(jiǎn)介
字符型(char)用于儲(chǔ)存字符(character),如英文字母或標(biāo)點(diǎn)。嚴(yán)格來說,char 其實(shí)也是整數(shù)類型(integer type),因?yàn)?char 類型儲(chǔ)存的實(shí)際上是整數(shù),而不是字符。計(jì)算機(jī)使用特定的整數(shù)編碼來表示特定的字符。美國普遍使用的編碼是 ASCII(American Standard Code for Information Interchange 美國信息交換標(biāo)準(zhǔn)編碼)。例如:ASCII 使用 65 來代表大寫字母 A,因此存儲(chǔ)字母 A 實(shí)際上存儲(chǔ)的是整數(shù)65。注意:許多IBM大型機(jī)使用另一種編碼--EBCDIC(Extended Binary-Coded Decimal Interchange Code 擴(kuò)充的二進(jìn)制編碼的十進(jìn)制交換碼);不同國家的計(jì)算機(jī)使用的編碼可能完全不同。
ASCII 的范圍是 0 到 127,故而 7 位(bit)就足以表示全部 ASCII。char 一般占用 8 位內(nèi)存單元,表示ASCII綽綽有余。許多系統(tǒng)都提供擴(kuò)展ASCII(Extended ASCII),并且所需空間仍然在 8 位以內(nèi)。注意,不同的系統(tǒng)提供的擴(kuò)展 ASCII 的編碼方式可能有所不同!
許多字符集超出了 8 位所能表示的范圍(例如漢字字符集),使用這種字符集作為基本字符集的系統(tǒng)中,char 可能是 16 位的,甚至可能是 32 位的??傊?,C 保證 char 占用空間的大小足以儲(chǔ)存系統(tǒng)所用的基本字符集的編碼。C 語言定義一個(gè)字節(jié)(byte)的位數(shù)為 char 的位數(shù),所以一個(gè)字節(jié)可能是 16 位,也可能是 32 位,而不僅僅限于 8 位。
c語言中char的用法: 聲明字符型變量
字符型變量的聲明方式和 其它 類型變量的聲明方式一樣:
char good;
char better, best;
以上代碼聲明了三個(gè)字符型變量:good、better,和 best。
c語言中char的用法:字符常量與初始化
我們可以使用以下語句來初始化字符型變量:
charch = 'A';
這個(gè)語句把ch的值初始化為 A 的編碼值。在這個(gè)語句中,'A' 是字符常量。C 語言中,使用單引號(hào)把字符引起來就構(gòu)成字符常量。我們來看另外一個(gè)例子:
char fail; /* 聲明一個(gè)字符型變量 */
fail = 'F'; /* 正確 */
fail = "F"; /* 錯(cuò)!"F" 是字符串字面量 */
把字符用雙引號(hào)引起來構(gòu)成字符串字面量,所以第三個(gè)語句是錯(cuò)誤的。我們會(huì)在后續(xù)的教程中討論字符串,現(xiàn)在暫且把它放下。
因?yàn)樽址麑?shí)質(zhì)上是以數(shù)字的形式存儲(chǔ)的,所以我們可以直接使用數(shù)字來初始化字符變量,或者給字符變量賦值:
char ch = 65; /* 不好的風(fēng)格 */
在 ASCII 中,A 的編碼是 65,所以對(duì)于使用 ASCII 的系統(tǒng)來說,這個(gè)語句等同于 char ch = 'A';。使用非 ASCII 的系統(tǒng)中,65 代表的不一定是 A,而有可能是其它任何字符,所以使用數(shù)字來初始化字符變量,或者給字符變量賦值是一種不好的風(fēng)格,因?yàn)橐浦残蕴盍?但是,使用字符常量(例如 'A')來初始化字符變量,或者給字符變量賦值,字符變量得到的一定是我們所期待的字符的編碼值。例如:
charch = 'A';
無論在使用任何編碼的系統(tǒng)中,ch都能夠得到字符 A 所對(duì)應(yīng)的編碼值。這是因?yàn)榫幾g器會(huì)自動(dòng)把 'A' 轉(zhuǎn)化成 A 所對(duì)應(yīng)的編碼值。因此,我們應(yīng)該使用字符常量來初始化字符變量,或者給字符變量賦值;而不要用數(shù)字。
有趣的是,C 使用int類型來處理字符常量,而不是 char 類型。例如,在使用32位int的ASCII 系統(tǒng)中,以下代碼
charch = 'C';
'C' 的編碼值 67 被存儲(chǔ)于 32 位的內(nèi)存單元中;不過ch仍然存儲(chǔ)于 8 位的內(nèi)存單元中,只是它的值變成了 67。因此,我們可以定義形如 'good' 的古怪字符常量。因?yàn)槊總€(gè)字符的編碼值占用 8 位的內(nèi)存單元,所以這個(gè)常量剛好可以存儲(chǔ)于 32 位的內(nèi)存單元。然而,用這種字符常量初始化字符變量,或者給字符變量賦值的話,導(dǎo)致的結(jié)果是,字符變量只能得到字符常量的最后 8 位。也就是說,以下代碼
charch = 'good';
ch得到的是 'd' 的值。
以后,在沒有特殊說明的情況下,我們討論的都是 ASCII。
ASCII值
控制字符 ASCII值控制字符 ASCII值控制字符 ASCII值控制字符
0 NUL 32 (space) 64 @ 96 `
1 SOH 33 ! 65 A 97 a
2 STX 34 " 66 B 98 b
3 ETX 35 # 67 C 99 c
4 EOT 36 ?$ 68 D 100 d
5 ENQ 37 % 69 E 101 e
6 ACK 38 & 70 F 102 f
7 BEL 39 ' 71 G 103 g
8 BS 40 ( 72 H 104 h
9 HT 41 ) 73 I 105 i
10 LF 42 * 74 J 106 j
11 VT 43 + 75 K 107 k
12 FF 44 , 76 L 108 l
13 CR 45 - 77 M 109 m
14 SO 46 . 78 N 110 n
15 SI 47 / 79 O 111 o
16 DLE 48 0 80 P 112 p
17 DC1 49 1 81 Q 113 q
18 DC2 50 2 82 R 114 r
19 DC3 51 3 83 S 115 s
20 DC4 52 4 84 T 116 t
21 NAK 53 5 85 U 117 u
22 SYN 54 6 86 V 118 v
23 ETB 55 7 87 W 119 w
24 CAN 56 8 88 X 120 x
25 EM 57 9 89 Y 121 y
26 SUB 58 : 90 Z 122 z
27 ESC 59 ; 91 [ 123 {
28 FS 60 < 92 \ 124 |
29 GS 61 = 93 ] 125 }
30 RS 62 > 94 ^ 126 ~
31 US 63 ? 95 _ 127 DEL
NUL 空字符 VT 垂直制表 SYN 同步
SOH 標(biāo)題開始 FF 走紙控制 ETB 信息組傳送結(jié)束
STX 正文開始 CR 回車 CAN 作廢
ETX 正文結(jié)束 SO 移位輸出 EM 媒介結(jié)束 End of Medium
EOT 傳輸結(jié)束 SI 移位輸入 SUB 換置
ENQ 詢問字符 DLE Data Link Escape ESC Escape
ACK 確認(rèn) DC1 設(shè)備控制1 FS 文件分隔符
BEL 響鈴 DC2 設(shè)備控制2 GS 組分隔符
BS 退格 DC3 設(shè)備控制3 RS 記錄分隔符
HT 橫向制表 DC4 設(shè)備控制4 US 單元分隔符
LF 換行 NAK 否定 DEL 刪除
c語言中char的用法:不可打印字符(Nonprinting Characters)
有些 ASCII 字符是不可打印的。例如退格、另起一行、警報(bào)等。C 語言提供了兩種 方法 來表示這種不可打印字符。
第一種方法是使用 ASCII 編碼。例如,ASCII 編碼中,7 用于表示警報(bào):
char beep = 7;
第二種方法是使用特殊符號(hào)序列,也就是所謂的轉(zhuǎn)義字符escape sequences)。參見下表:(
轉(zhuǎn)義字符含義
\a 警報(bào)( Alert (ANSI C) )
\b 退格(Backspace)
\f 換頁(Form feed)
換行(Newline)
回車(Carriage return)
\t 水平制表符(Horizontal tab)
\v 垂直制表符(Vertical tab)
\\ 反斜桿( Backslash (\) )
\' 單引號(hào)( Single quote (') )
\" 雙引號(hào)( Double quote (") )
\? 問號(hào)( Question mark (?) )
\0oo 八進(jìn)制數(shù)( Octal value (o 代表一個(gè)八進(jìn)制數(shù)字) )
\xhh十六進(jìn)制數(shù)( Hexadecimal value (h 代表一個(gè)十六進(jìn)制數(shù)字) )
給變量賦值的時(shí)候,轉(zhuǎn)義字符必須使用單引號(hào)引住。例如:
charnl = ' ';
下面我們?cè)敿?xì)學(xué)習(xí)每個(gè)轉(zhuǎn)移字符的含義。
\a(警報(bào))是 ANSI C89 添加的,用于產(chǎn)生可聽或者可視的警報(bào)。\a 產(chǎn)生的效果取決于硬件。一般來說,輸出 \a 會(huì)產(chǎn)生鳴響。但是在某些系統(tǒng),輸出 \a 不會(huì)產(chǎn)生任何效果,或者僅僅顯示一個(gè)特殊字符。標(biāo)準(zhǔn)明確指出,\a 不應(yīng)該改變當(dāng)前活躍位置(active position)。所謂活躍位置,是指顯示設(shè)備( 顯示器 、打字機(jī)、打印機(jī)等等)顯示下一個(gè)字符的位置。以顯示器為例,活躍位置就是指光標(biāo)所處的位置,輸出 \a 不會(huì)導(dǎo)致光標(biāo)移動(dòng)位置。
\b、\f、、、\t,以及 \v 都是輸出設(shè)備控制符。退格符(\b)使當(dāng)前行的活躍位置后退一個(gè)位置。換頁符(\f)使活躍位置跳到下一頁的開端。注:換頁符可用于控制打印機(jī)換頁,但不會(huì)導(dǎo)致 PC 機(jī)的顯示屏換頁。換行符()使活躍位置跳到下一行的開端?;剀嚪?)使活躍位置返回當(dāng)前行的開端。水平制表符(\t)使活躍位置移動(dòng)若干個(gè)位置(通常是8個(gè))。垂直制表符(\v)使活躍位置換若干行。注:\v可用于控制打印機(jī)換若干行,但是不會(huì)導(dǎo)致PC機(jī)的顯示屏換行。
\\、\',以及 \" 使我們可以把 \,' 和 " 用作字符常量。如果要打印以下 句子 :
"\ is called 'backslash'."
我們需要使用如下語句:
printf("\"\\ is called \'backslash\'.\"");
\0oo 和 \xhh是ASCII碼的兩種特殊表示形式。如果想用八進(jìn)制ASCII碼表示字符,可以在八進(jìn)制數(shù)前面加上 \ ,然后用單引號(hào)引起來。例如:
beep = '\007'; /* \007 代表 \a */
打頭的那些0可以省略,也就是說,寫成 '\07' 或者 '\7' 都一樣。無論有沒有打頭的0 ,7 都會(huì)被當(dāng)成八進(jìn)制數(shù)處理。
從 C89 開始,C提供了用十六進(jìn)制表示字符常量的方法:在反斜桿后面寫一個(gè) x ,然后再寫 1 到 3 個(gè)十六進(jìn)制數(shù)字。例如:
nl = '\xa'; /* \xa代表 */
注意:使用ASCII碼時(shí),要注意區(qū)分?jǐn)?shù)字4的ASCII碼是52 ,'4' 代表字符 4 ,而不是數(shù)字4。此外,盡管 ' ' 和 '\xa' ,'\a' 和 '\007' 是等價(jià)的,但是我們應(yīng)該盡可能使用 ' ' 和 '\a' ,而不要用 '\xa' 和 '\007' 。這是因?yàn)榍罢咭锥⒈阌谟洃?,而且移植性更高。而后者只?duì)使用ASCII碼的系統(tǒng)有效。和數(shù)字字符。例如:字符
c語言中char的用法:字符輸出
printf函數(shù)使用 %c 表示輸出字符。因?yàn)樽址且?1 字節(jié)整數(shù)的形式存取的,所以,如果使用 %d 的話,輸出的會(huì)是整數(shù)。例如:
/* 這個(gè)程序輸出字符以及字符的整數(shù)編碼 */
#include
int main(void)
{
charch;
printf("Please enter a character. ");
scanf("%c", &ch); /* 由用戶輸入一個(gè)字符 */
printf("The code for %c is %d. ", ch, ch);
return 0;
}
請(qǐng)各位自行編譯執(zhí)行此程序,查看其執(zhí)行結(jié)果。輸入字符后記得要按回車鍵。
printf函數(shù)輸出ch的值兩次,第一次以字符的形式輸出(因?yàn)楦袷较薅ǚ麨?%c),第二次以十進(jìn)制整數(shù)的形式輸出(因?yàn)楦袷较薅ǚ?%d)。注意:格式限定符只是用于指定數(shù)據(jù)的輸出形式,而不是用來指定數(shù)據(jù)怎么存儲(chǔ)。
c語言中char的用法:字符類型的符號(hào)
某些編譯器中,char 默認(rèn)是有符號(hào)的(signed)。對(duì)于這類型的編譯器來說,char 的表示范圍通常是 -128 到 127 。而另外一些編譯器中,char 默認(rèn)是無符號(hào)的(unsigned)。對(duì)于這類型的編譯器來說,char 的表示范圍通常是 0 到 255 。一般來說,編譯器的使用說明會(huì)注明它默認(rèn)把 char 當(dāng)作有符號(hào)的還是無符號(hào)的。
從 C89 開始,我們可以使用關(guān)鍵字 signed 和 unsigned 來修飾 char 。這么一來,無論編譯器默認(rèn) char 是有符號(hào)的也好,無符號(hào)的也罷,我們都可以用 signed char 表示有符號(hào) char ,也可以用 unsigned char 表示無符號(hào) char 。
猜你喜歡:
1. c語言中邏輯或的用法
2. C語言程序中什么是函數(shù)
3. c語言中%s的用法
4. c語言中fprintf的用法
5. c語言中switch的用法
二、以下正確的字符串常量是什么?
答案為D。
D是一個(gè)空字符串,僅有字符串結(jié)束標(biāo)志的字符串。
A中第一個(gè)字符是'\',即字符,而第二個(gè)字符''中的斜杠表示開始某個(gè)轉(zhuǎn)義字符,其后必須還有有效的和它能組成轉(zhuǎn)義字符的其它內(nèi)容,但現(xiàn)在沒有,所以錯(cuò)。
擴(kuò)展資料:
與指針的關(guān)系:
在程序中,字符串常量會(huì)生成一個(gè)“指向字符的常量指針”。當(dāng)一個(gè)字符串常量出現(xiàn)于一個(gè)表達(dá)式中時(shí),表達(dá)式所使用的值就是這些字符所存儲(chǔ)的地址,而不是這些字符本身。
可以把字符串常量賦值給一個(gè)“指向字符 的指針”,例如:char *a = "123" ; a = "abc";,后者指向這些字符所存儲(chǔ)的地址。
不能把字符串常量賦值給一個(gè)字符數(shù)組,因?yàn)樽址A康闹苯又凳且粋€(gè)指針,而不是這些字符本身。例如:char a;a = "a";就是錯(cuò)誤的,報(bào)錯(cuò)結(jié)果:invalid conversion from 'const char*' to 'char'。
例如:char a="love",的意思就是用字符串“l(fā)ove”來初始化字符數(shù)組a的內(nèi)存空間,而數(shù)組的首地址也就是“l(fā)ove”字符串的地址。
參考資料來源:百度百科-字符串常量
三、Fortran編程里面的定義變量的character*80是什么意思?
定義一個(gè)字符串,長(zhǎng)度是80
比較現(xiàn)代的寫法是
character(len=80)
四、nvarchar和varchar,char,nchar有什么區(qū)別?
nchar(n)
包含 n 個(gè)字符的固定長(zhǎng)度 Unicode 字符數(shù)據(jù)。n 的值必須介于 1 與 4,000 之間。存儲(chǔ)大小為 n 字節(jié)的兩倍。nchar 在 SQL-92 中的同義詞為 national char 和 national character。
nvarchar(n)
包含 n 個(gè)字符的可變長(zhǎng)度 Unicode 字符數(shù)據(jù)。n 的值必須介于 1 與 4,000 之間。字節(jié)的存儲(chǔ)大小是所輸入字符個(gè)數(shù)的兩倍。所輸入的數(shù)據(jù)字符長(zhǎng)度可以為零。nvarchar 在 SQL-92 中的同義詞為 national char varying 和 national character varying。注釋如果沒有在數(shù)據(jù)定義或變量聲明語句中指定 n,則默認(rèn)長(zhǎng)度為 1。如果沒有使用 CAST 函數(shù)指定 n,則默認(rèn)長(zhǎng)度為 30。
如果希望列中所有數(shù)據(jù)項(xiàng)的大小接近一致,則使用 nchar。
如果希望列中數(shù)據(jù)項(xiàng)的大小差異很大,則使用 nvarchar。
使用 nchar 或 nvarchar 的對(duì)象被賦予數(shù)據(jù)庫的默認(rèn)排序規(guī)則,除非使用 COLLATE 子句賦予特定的排序規(guī)則。
SET ANSI_PADDING OFF 不適用于 nchar 或 nvarchar。SET ANSI_PADDING ON 永遠(yuǎn)適用于 nchar 和 nvarchar。
二、char 和 varchar
固定長(zhǎng)度 (char) 或可變長(zhǎng)度 (varchar) 字符數(shù)據(jù)類型。char[(n)]
長(zhǎng)度為 n 個(gè)字節(jié)的固定長(zhǎng)度且非 Unicode 的字符數(shù)據(jù)。n 必須是一個(gè)介于 1 和 8,000 之間的數(shù)值。存儲(chǔ)大小為 n 個(gè)字節(jié)。char 在 SQL-92 中的同義詞為 character。
varchar[(n)]
長(zhǎng)度為 n 個(gè)字節(jié)的可變長(zhǎng)度且非 Unicode 的字符數(shù)據(jù)。n 必須是一個(gè)介于 1 和 8,000 之間的數(shù)值。存儲(chǔ)大小為輸入數(shù)據(jù)的字節(jié)的實(shí)際長(zhǎng)度,而不是 n 個(gè)字節(jié)。所輸入的數(shù)據(jù)字符長(zhǎng)度可以為零。varchar 在 SQL-92 中的同義詞為 char varying 或 character varying。注釋如果沒有在數(shù)據(jù)定義或變量聲明語句中指定 n,則默認(rèn)長(zhǎng)度為 1。如果沒有使用 CAST 函數(shù)指定 n,則默認(rèn)長(zhǎng)度為 30。
將為使用 char 或 varchar 的對(duì)象被指派數(shù)據(jù)庫的默認(rèn)排序規(guī)則,除非用 COLLATE 子句另外指派了特定的排序規(guī)則。該排序規(guī)則控制用于存儲(chǔ)字符數(shù)據(jù)的代碼頁。
支持多語言的站點(diǎn)應(yīng)考慮使用 Unicode nchar 或 nvarchar 數(shù)據(jù)類型以盡量減少字符轉(zhuǎn)換問題。如果使用 char 或 varchar:
如果希望列中的數(shù)據(jù)值大小接近一致,請(qǐng)使用 char。
如果希望列中的數(shù)據(jù)值大小顯著不同,請(qǐng)使用 varchar。
如果執(zhí)行 CREATE TABLE 或 ALTER TABLE 時(shí) SET ANSI_PADDING 為 OFF,則一個(gè)定義為 NULL 的 char 列將被作為 varchar 處理。
當(dāng)排序規(guī)則代碼頁使用雙字節(jié)字符時(shí),存儲(chǔ)大小仍然為 n 個(gè)字節(jié)。根據(jù)字符串的不同,n 個(gè)字節(jié)的存儲(chǔ)大小可能小于 n 個(gè)字符。
以上就是關(guān)于character的定義相關(guān)問題的回答。希望能幫到你,如有更多相關(guān)問題,您也可以聯(lián)系我們的客服進(jìn)行咨詢,客服也會(huì)為您講解更多精彩的知識(shí)和內(nèi)容。
推薦閱讀:
chatGPT海外手機(jī)號(hào)(海外手機(jī)號(hào)查詢)