c語言匯總
A. c語言字元串信息分類匯總的程序誰幫我解決一下
#include
<stdio.h>
#include
<string.h>
main()
{
int
a=0,b=0,c=0,i;
char
str[100];
printf("請你輸入字元:");
gets(str);
for(i=0;i<strlen(str);i++)
{
if(str[i]>='a'&&str[i]<='z')
{
a++;/*統計小寫字母*/
}
else
if(str[i]>='A'&&str[i]<='Z')
{
b++;/*統計大寫字母*/
}
else
{
b++;/*統計其他字元的*/
}
}
printf("%d
%d
%d\n",a,b,c);
}
B. C++面試題匯總
某個文件中定義的靜態全局變數(或稱靜態局部變數)作用域是------本文件內
①:默認繼承許可權:
class的繼承按照private繼承處理,struct的繼承按照public繼承處理
②:成員的默認訪問許可權
class的成員默認是private許可權, struct默認是public許可權
註:C++有內置的宏__cplusplus -------有個習慣帶「__」表示內部變數,只供內部使用;不帶雙下劃線的,表示外部介面的變數(標識符)
C++函數的三種傳遞方式為:值傳遞。指針傳遞 和 引用傳遞
註:值傳遞和指針傳遞,本質上就是指針傳遞。
在A類中fun1是虛函數;B類中fun2是虛函數。
①:機制上:c是面向過程的(c也可以是面向對象發的程序); C++是面向對象,提供了類。C++的面向對象的程序比c容易。
②:使用方向:c適合代碼體積小的,效率高的場合,如嵌入式;C++更適合上層的,復雜的;Linux核心大部分是c寫的,因為他是系統軟體,效率要求極高
③:C++是c的超集;
④:C語言是結構化編程語言,C++是面向對象編程語言。
⑤:C++側重於對象而不是過程,側重於類的設計而不是邏輯設計。
C中struct主要提供的是自定義類型,和構造一種新的類型出來;
一致的地方:
不一致的地方:
C語言: 無Protection行為; 不能定義函數,但可以有函數指針;
C++: 有Procetion行為,默認是private; 可以定義函數。
註: 就是訪問許可權,struct對於外部是完全訪問的,C++是有訪問 許可權 設置的;
正確, sizeof 是編譯時運算符,編譯時就確定了 可以看成是和及其有關的常量
註:定義數組的時候,數組的長度必須是一個確定的常量;
形參:是在定義函數時指定的參數,在未調用時他們並不佔用內存中的存儲單元。只有在調用的時候才會被分配內存,調用結束後,形參所佔用的內存單元會被釋放
實參:即你調用函數時傳遞的參數;
重載: 同一個名字空間--- -函數名相同,參數列表不同 ; 注釋:理解成一個類裡面的多個同名函數
重寫/覆蓋: 不同名字空間-----用於繼承,子類重新定義父類中 函數名相同,參數列表也相同 虛函數 的方法
重定義/隱藏:重定義(隱藏)是指派生類的函數屏蔽了與其同名的基類函數,規則如下:
a 如果派生類的函數和基類的 函數同名,但是參數不同 ,此時,不管有無virtual,基類的函數被隱藏。
b 如果派生類的函數與基類 的函數同名,並且參數也相同 ,但是基類函數沒有vitual關鍵字,此時,基類的函數被隱藏。
①: 隱藏 實現 細節 ,使得代碼能夠模塊化;擴展代碼模塊, 實現代碼重寫
②: 介面重用 :為了使用多個派生類中某個派生類的屬性正確調用
用sizeof的方法:
定義一個指針P,列印出sizeof(P),如果結果是4,怎麼標識改操作系統是32位,如果列印結果是2,則標識是16位、。
虛函數 表 ,是在 編譯 期就建立了。各個虛函數被組織成一個虛函數的入口地址的數組(簡而言之,就是組成了一個存放虛函數地址的數組)
虛函數表 指針 是在 運行 時建立的,也就是構造函數被調用時進行初始化的。
封裝,繼承,多態 是什麼?怎那麼用?為什麼使用它?
封裝:將客觀事物抽象成類,每個類對自身的 數據 和 方法 實行 protection ; 注釋 : 保護內部成員
繼承:廣義的繼承有三種實現形式:
實現繼承:指使用基類的屬性和方法,而無需額外編碼的能力;
可視繼承:子窗體使用父窗體的外觀和實現代碼
介面繼承:僅使用屬性和方法,實現之後到子類實現
前兩種和後一種構成了功能復用的兩種方法
多態: 主要是為了抽象
只要是函數都會做類型檢查。
這是內聯函數跟宏觀比的優勢。
①:靜態存儲區域分配; 內存在編譯的時候就已經分配好了,這塊內存在程序的整個運行期間都存在。例如全局變數。
②:在展區創建;在執行函數時,函數內局部變數的存儲單元都可以在棧上創建,函數執行結束時,自動被釋放。效率高,但是內存容量有限。
③:從堆上分配:或者叫:動態內存分配。程序員自己負責在何時用free或delete釋放內存。
C語言中用帶參數的宏定義,C++中用inline
生命周期不同 空間 周期
局部變數 函數調用時創建,結束時銷毀。static除外
局部變數不具有外部鏈接,全局變數
全局變數 : 靜態數據區
局部變數: 放在棧區
malloc、free是C++/C語言標准庫,new、delete是C++運算符。
注意:new、delete不是庫函數;
malloc/free 無法 滿足 對象在創建的時候要自動 執行 構造函 數,對象消亡之前要自動執行 析構函數 。他們是庫函數,而不是運算符,不在編譯器的控制許可權內,。
new、delete 能完成內存的分配和釋放,已經初始化和清理工作。
判斷指針是否為空,如果空,則列印錯誤log,並且return,終止本函數。
不是,兩個不同類型的指針可以強制轉換。
動態申請;
知道運行時才知道一個對象需要多少存儲空間,不需要知道對象的生存周期有多長。
Debug調試版本,它包含調試信息,比如assert的適用,並且不作任何優化,便於程序員調試程序。
Release稱為發布版本,他往往時進行了各種優化,
析構函數時特殊的類成員函數,沒有返回類型,沒有參數,不能隨意調用,也沒有重載,只有在類對象的生命周期結束時,有系統自己調用。優勢方內存空間的作用。
虛函數是C++多態的一種表現,使用虛函數,我們可以靈活的進行動態綁定,當然是以一定的開銷為代價
(這里虛函數的適用還是不太懂,需要進一步學習,比如怎麼調用子類的一切啊)
導致文件描述符結構中指針指向的內存背重復釋放,進而導致一些不可預期的異常。
比如全局變數的初始化,就不是有main函數引起的。例如:
全局對象的構造函數,會在main函數之前執行。
多態,純虛函數,抽象類
內聯函數
虛函數的特點:如果希望派生類能夠重新定義基類的方法,則在基類中將該方法定義為虛方法,這樣可以啟用動態聯編。
內聯函數的特點:使用內聯函數的目的屎我了提高函數的運行俠侶。內聯函數的代碼不能過長,因為內聯函數省去調用函數的時間是以代碼膨脹為代價的。內聯函數不能包含循環語句。因為執行循環語句要比調用函數的開銷大。
函數模板的實例化是由編譯程序在處理函數嗲用時自動完成的,
類模板的實例化必須由程序員在程序中顯示的指定
函數名和參數列表
不能被重載的運算符:
①:不能改變C++內部數據類型(如int float 等)的運算符
②:不能重載「.」,因為.在類中對任何成員都有意義,已經成為標准用法
③:不能重載目前C++運算符集合中沒有的符號,如:@, 等。願意:一是難以理解,二是無法確定優先順序
④:對已經存在的運算符重載不能改變優先順序規則,否則將引起混亂。
有可能是派生類無法調用析構函數
模板可以說比較古老了,但是當前的泛型編程實質上就是模板編程。他體現了一種通用和泛化的思想。
STL有7中容器:
vector(零食進行存儲數據的訪問),list(經常進行數據的增刪改查),deque(隊列結構),map,multimap,set(構造棧形的數據使用),multiset.
容器是一種特定用途的類;
淺拷貝 知識拷貝了指針沒有拷貝資源
深拷貝進行了資源的拷貝
三元表達式「?:」問好後面的兩個操作數必須為同一個類型。否則會出問題。
總的來說,堆是C語言和操作系統的術語,是操作系統維護的一塊動態分配內存;自由存儲是C++中通過 new與delete動態分配和釋放對象的抽象概念。 他們並不是完全一樣。
從技術上來說,堆(heap)是C語言和操作系統的術語。堆是操作系統所維護的一塊特殊內存,它提供了動態分配的功能,當運行程序調用malloc()時就會從中分配,稍後調用free可把內存交還。而自由存儲是C++中通過new和delete動態分配和釋放對象的抽象概念,通過new來申請的內存區域可稱為自由存儲區。基本上,所有的C++編譯器默認使用堆來實現自由存儲,也即是預設的全局運算符new和delete也許會按照malloc和free的方式來被實現,這時藉由new運算符分配的對象,說它在堆上也對,說它在自由存儲區上也正確。
程序編譯的過程中就是將用戶的文本形式的源代碼(c/c++)轉化成計算機可以直接執行的機器代碼的過程。主要經過四個過程:預處理、編譯、匯編和鏈接。具體示例如下。
一個hello.c的c語言程序如下。
其編譯過程如下:
C. 怎麼用C語言實現多個文件進行匯總到一個文件功能
看你的匯總依據了。
如果不需要數據處理 只是單純性的集合起來
那麼可依次打開每個文件,然後寫入到一個新文件中。
如果需要數據處理
就需要先打開一個文件,提取並統計需要匯總的數據
再打開第二個,提取,並疊加到第一個的數據上
以此類推
最後一次性寫入。
這個要麻煩的多。
D. c語言問題
按照題目要求編寫的C語言程序如下
#include <stdio.h>
int main(){
int i;
double a,sum=0,posisum=0,negasum=0;
printf("請輸入任意10個數: ");
for(i=0;i<10;i++){
scanf("%lf",&a);
sum=sum+a;
if(a>0) posisum+=a;
else if(a<0) negasum+=a;
}
printf("正數和為:%f ",posisum);
printf("負數和為:%f ",negasum);
printf("10個數的總和為:%f ",sum);
return 0;
}
E. C語言 字元串命令 集錦
樓上的寫的我都看不懂,不過我可以推薦給你一些:
gets(char
*str)
從流中獲取字元串
putchar(ch[i])
列印一個字元
strlen(char
*str)
判斷字元串的長度
char
*strcpy(char
*destination,
const
char
*source)
拷貝串
char
*strcat(char
target,
const
char
*source)
將一個串的內容追加到另一個串上
char
*strncat(char
*destination,const
*source,size_t
n);
將字元穿追家n個字元。
size_t
strxfrm(char
*target,char
*source,size_t
n)
把一個字元穿轉移到另一個字元穿
int
streql(char
*str1,
char
*str2)
比較兩個字元穿是否相同
int
strieql(char
*str1,
char
*str2)
不區分大小寫比較兩個字元串是否相同
char
*strlwr(char
*str)
char
*strupr(char
*str)
將字元穿轉換為大寫或小寫
int
strcmp(const
char
*str1,const
*char
str2)
比較兩個字元串
我只能寫到這里了,手都酸了,要加分哦,呵呵
我有這方面的電子書,要的話,就加我QQ(474724984)吧
我傳給你。
F. 計算機二級C語言基本考點
計算機二級C語言基本考點匯總
為幫助同學們更好學習C語言基本知識,我特為同學們搜集以下C語言考試基本考點知識,歡迎閱讀!
【考點1】C程序
C語言程序結構有三種: 順序結構 , 循環結構(三個循環結構), 選擇結構(if 和 switch)
【考點2】main函數
每個C語言程序中main 函數是有且只有一個。讀程序都要從main()入口, 然後從最上面順序往下讀(碰到循環做循環,碰到選擇做選擇)。
【考點3】存儲形式
計算機的數據在電腦中是以二進制的形式保存。最低的存儲單元是bit(位),位是由為 0 或者1構成。 byte 是指位元組, 一個位元組 = 八個位。數據存放的位置就是它的地址。
【考點4】注釋
是對程序的說明,可出現在程序中任意合適的地方,注釋從“/*”開始到最近一個“*/”結束,其間任何內容都不會被計算機執行,注釋不可以嵌套。
【考點5】書寫格式
每條語句的後面必須有一個分號,分號是語句的一部分。一行內可寫多條語句,一個語句可寫在多行上。
【考點6】標識符
合法的用戶標識符考查:
合法的要求是由字母,數字,下劃線組成。有其它元素就錯了。
並且第一個必須為字母或則是下劃線。第一個為數字就錯了。
C語言標識符分如下3類
(1)關鍵字。它們在程序中有固定的含義,不能另作他用。如int、for、switch等。
(2)預定義標識符。預先定義並具有特定含義的標識符。如define、include等。
(3)用戶標識符。用戶根據需要定義的標識符,符合命名規則且不與關鍵字相同。
關鍵字不可以作為用戶標識符號。main define scanf printf 都不是關鍵字。迷惑你的地方If 是可以做為用戶標識符。因為If 中的第一個字母大寫了,所以不是關鍵字。
【考點7】實型數據
實型數據的合法形式:小數形式和指數形式。掌握判定指數形式合法性。
2.333e-1 就是合法的,且數據是2.333×10-1。
考試口訣:e 前e 後必有數,e 後必為整數。
【考點8】字元
字元數據的合法形式::
'1' 是字元佔一個位元組,"1"是字元串占兩個位元組(含有一個結束符號)。
'0' 的ASCII 數值表示為48,'a' 的ASCII 數值是97,'A'的ASCII 數值是65。
字元型和整數是近親:
char a = 65 ;
printf(“%c”, a); 得到的輸出結果:a
printf(“%d”, a); 得到的輸出結果:65
一般考試表示單個字元錯誤的形式:'65' "1"
字元是可以進行算術運算的,記住: '0'-0=48
大寫字母和小寫字母轉換的方法: 'A'+32='a' 相互之間一般是相差32。
【考點9】整型數據
整型一般是兩個位元組, 字元型是一個位元組,雙精度一般是4 個位元組:
考試時候一般會說,在16 位編譯系統,或者是32 位系統。碰到這種情況,不要去管,
一樣做題。掌握整型一般是兩個位元組, 字元型是一個位元組,雙精度一般是4 個位元組就可以了。
【考點10】轉義字元
轉義字元的考查:
在程序中 int a = 0x6d,是把一個十六進制的數給變數a 注意這里的0x 必須存在。
在程序中 int a = 06d, 是一個八進制的形式。
在轉義字元中, ’x6d’ 才是合法的,0 不能寫,並且x 是小寫。
‘141’ 是合法的, 0 是不能寫的。
‘108’是非法的,因為不可以出現8。
【考點11】算術運算
算術運算符一共有+、—、*、/、%這五個。%符號兩邊要求是整數。不是整數就錯了。
三種取整丟小數的情況:不是四捨五入是舍掉小數部分。
1、int a =1.6;
2、(int)a;
3、1/2; 3/2;
【考點12】強制類型轉換
將一個運算對象轉換成指定類型,格式為(類型名)表達式
一定是 (int)a 不是 int(a),注意類型上一定有括弧的。
注意(int)(a+b) 和(int)a+b 的區別。前是把a+b 轉型,後是把a 轉型再加b。
【考點13】賦值
是表達式就一定有數值。
賦值表達式:表達式數值是最左邊的數值,a=b=5;該表達式為5,常量不可以賦值。
復合賦值運算符:注意:a*=m+2 是 a=a*(m+2)
自加、自減表達式:假設a=5,++a(表達式的.值為6), a++(表達式的值為5);
j=a++;等價於j=a;a=a+1; 而j=++a;等價於a=a+1;j=a;。
考試口訣:++在前先加後用,++在後先用後加。
【考點14】逗號運算
逗號表達式:優先順序別最低; 表達式的數值逗號最右邊的那個表達式的數值。
(2,3,4)的表達式的數值就是4。
【考點15】數制轉換
一定要記住二進制 如何轉換成十進制。
八進制是沒有8 的,逢8 進1,018 的數值是非法的。
【考點16】位運算
會有一到二題考試題目。
C語言提供6種位運算符:按位求反~,按位左移<<,按位右移>>,按位與&,按位異或|,按位或^。
總的處理方法:幾乎所有的位運算的題目都要按這個流程來處理(先把十進制變成二進制再變成十進制)。
異或運算的規則:0異或1得到1,0異或0得到0,1異或1得到0。可記為“相同為0,不同為1”。
;G. C語言 字元串命令 集錦
樓上的寫的我都看不懂,不過我可以推薦給你一些:
gets(char *str)
從流中獲取字元串
putchar(ch[i])
列印一個字元
strlen(char *str)
判斷字元串的長度
char *strcpy(char *destination, const char *source)
拷貝串
char *strcat(char target, const char *source)
將一個串的內容追加到另一個串上
char *strncat(char *destination,const *source,size_t n);
將字元穿追家n個字元。
size_t strxfrm(char *target,char *source,size_t n)
把一個字元穿轉移到另一個字元穿
int streql(char *str1, char *str2)
比較兩個字元穿是否相同
int strieql(char *str1, char *str2)
不區分大小寫比較兩個字元串是否相同
char *strlwr(char *str)
char *strupr(char *str)
將字元穿轉換為大寫或小寫
int strcmp(const char *str1,const *char str2)
比較兩個字元串
我只能寫到這里了,手都酸了,要加分哦,呵呵
我有這方面的電子書,要的話,就加我QQ(474724984)吧
我傳給你。
H. c語言英語單詞彙總
就算你背下來也不一定能學好C語言,你這個放向不對。
I. c語言字元串信息分類匯總的程序誰能幫我解決一下
#include<stdio.h>
main()
{
char a[100];
int cap=0,little=0,others=0,i;
freopen("***.in","r",stdin);
/* ***是文件名,在存放該程序的目錄下建立名為「***.in」的文件並用記事本打開,在其中輸入字元串並運行程序*/
freopen("***.out","w",stdout);
/*運行完程序後用記事本打開該文件(***.out)即得結果*/
for(i=0;a[i]!='\0';i++)
{
if((65<=a[i])&&(a[i]<=90))cap++;
else if((97<=a[i])&&(a[i]<=122))little++;
else others++;
}
printf("Captain letters:%d\n",cap);
printf("Little letters:%d\n",little);
printf("The other chars:%d\n",others);
}
J. 怎麼用C語言實現多個文件進行匯總到一個文件功能
看你的匯總依據了。
如果不需要數據處理
只是單純性的集合起來
那麼可依次打開每個文件,然後寫入到一個新文件中。
如果需要數據處理
就需要先打開一個文件,提取並統計需要匯總的數據
再打開第二個,提取,並疊加到第一個的數據上
以此類推
最後一次性寫入。
這個要麻煩的多。