C語言學習筆記--運算符與表達式(7521字爆肝)

上午好,本來想上午改簡歷下午學習c語言的,但想了一下上午精力充沛還是用來學習比較好,雖然現在失業了,但住在我姨家有吃有住的,再次感謝我姨,我要抓緊時間修改簡歷,然后找個工作搬出去,不能一直在我姨家住著啊。努力吧,先找個相對輕松的不加班工作過度著也可以。今天把第三章的學習輸出完,然后我會把這一章的內容整理到一篇文章中,我學的內容是C語言編程寶典里的,手機端看著很方便,有興趣的可以自己搜索去看看非廣告,軟件商看到了記得給我打錢嘿嘿。ok,聊天結束,開始今天的學習。

3.6變量賦初值(理解)

在程序中常常需要對變量賦初值,以便使用變量。語言程序中可有多種方法為變量提供初值。本小節先介紹在作變量定義的同時給變量賦初值的方法。這種方法稱為初始化。在變量定義中賦初值的一般形式為:類型說明符 變量1=值1,變量2=值2,。。。;

例如:

int a=3;

int b,c=5;

float x=3.2,y=3f,z=0.75;

char ch1='g',ch2='p';

應注意,在定義中不允許連續賦值,如a=b=c=5是不合法的。

#include <stdio.h>int main()
{int a = 3,b,c = 5;b = a+c;printf("a=%d,b=%d,c=%d\n",a,b,c);return 0;
}

?運行結果:

?3.7 各類數值型數據之間的混合運算(理解)

變量的數據類型是可以轉換的。轉換的方法有兩種,一種是自動轉換,一種是強制轉換。自動轉換發生在不同數據類型的量混合運算時,由編譯系統自動完成。自動轉換遵循以下規則:

1)若參與運算量的類型不同,則先轉換成同一類型,然后進行運算。

2)轉換按數據長度增加的方向進行,以保證精度不降低。如int型和long型運算時,先把int量轉成long型后再進行運算。

3)所有的浮點運算都是以雙精度進行的,即使僅含float單精度量運算的表達式,也要先轉換成double型,再作運算。

4)char型和short型參與運算時,必須先轉換成int型。

5)在賦值運算中,賦值號兩邊量的數據類型不同時,賦值號右邊量的類型將轉換為左邊量的類型。如果右邊量的數據類型長度左邊長時,將丟失一部分數據,這樣會降低精度,丟失的部分按四舍五入向前舍入。

下圖表示了類型自動轉換的規則。

?

例3.12 求圓面積

#include <stdio.h>int main()
{float PI = 3.14159;int s,r = 5;s = r*r*PI;printf("s=%d\n",s);return 0;
}

?運行結果:

?本例程序中,PI為實型;s,r為整型。在執行s=r*r*PI語句時,r和PI都轉換成double型計算,結果也為double型。但由于s為整型,故賦值結果仍為整型,舍去了小數部分。

強制類型轉換

強制類型轉換是通過類型轉換運算來實現的。

其一般形式為:

(類型說明符)(表達式)

其功能是把表達式的運算結果強制轉換成類型說明符所表示的類型。

例如:

(float)a 把a轉換為實型

(int) (x+y) 把x+y的結果轉換為整型

在使用強制轉換時應注意以下問題:

1)類型說明符和表達式都必須加括號(單個變量可以不加括號),如把(int)(x+y)寫成(int)x+y則成了把x轉換成int型之后再與y相加了。

2)無論是強制轉換或是自動轉換,都只是為了本次運算的需要而對變量的數據長度進行的臨時性轉換,而不改變數據說明時對該變量定義的類型。

#include <stdio.h>int main()
{float f = 5.75;printf("(int)f=%d,f=%f\n",(int)f,f);return 0;
}

?運行結果:

?本例表明,f雖然強制轉為int型,但只在運算中起作用,是臨時的,而f本身的類型并不改變。因此,(int)f的值為5(刪去了小數)而f的值仍為5.75

?3.8算術運算符和算術表達式(掌握)

C語言中運算符和表達式數量之多,在高級語言中是少見的。正是豐富的運算符和表達式使C語言功能十分完善。這也是C語言的主要特點之一。

C語言的運算符不僅具有不同的優先級,而且還有一個特點,就是它的結合性。在表達式中,各運算量參與運算的先后順序不僅要遵守運算符優先級別的規定,還要受運算符結合性的制約,以便確定是自左向右進行運算還是自右向左進行運算。這種結合性是其他高級語言的運算符所沒有的,因此也增加了C語言的復雜性。

?3.8.1 C運算符簡介(考點)

其實我一直不太懂這個考點是什么意思,可能就是c語言考試的考點吧,對我來說,了解掌握了就行

運算符優先級是C語言掌握的重難點,也是必考點。

C語言的運算符可分為以下幾類:

1.算術運算符:用于各類數值運算。包括加(+)、減(-)、乘(*)、除(/)、求余(或稱模運算,%)、自增(++)、自減(--)共七種。

2.關系運算符:用于比較運算。包括大于(>)、小于(<)、等于(==)、大于等于(>=)、小于等于(<=)和不等于(!=)六種。

3.邏輯運算符:用于邏輯運算。包括與(&&)、或(||)、非(!)三種。

4.位操作運算符:參與運算的量,按二進制位進行運算。包括位與(&)、位或(|)、位非(~)、位異或(^)、左移(<<)、右移(>>)六種。

5.賦值運算符:用于賦值運算,分為簡單賦值(=)、復合算術賦值(+=,-=,*=,/=,%=)和復合位運算賦值(&=,|=,^=,>>=,<<=)三類共十一種。

6.條件運算符:這是一個三目運算符,用于條件求值(?:)。

7.逗號運算符:用于把若干表達式組合成一個表達式(,)。

8.指針運算符:用于取內容(*)和取地址(&)二種運算。

9.求字節數運算符:用于計算數據類型所占的字節數(sizeof)。

10.特殊運算符:有括號(),下標[],成員(->, .)等幾種。

3.8.2 算術運算符和算術表達式

1.基本的算術運算符(掌握)

(1)加法運算符“+”:加法運算符為雙目運算符,即應有兩個量參與加法運算。如a+b,4+8等。具有右結合性。

(2)減法運算符“-”:減法運算符為雙目運算符。但“-”也可作負值運算符,此時為單目運算,如-x,-5等具有左結合性。

(3)乘法運算符“*”:雙目運算,具有左結合性。

(4)除法運算符“/”:雙目運算具有左結合性。參與運算量均為整型時,結果也為整型,舍去小數。如果運算量中有一個是實型,則結果為雙精度實型。

(5)求余運算符(模運算符)“%”:雙目運算,具有左結合性。要求參與運算的量均為整型。求余運算的結果等于兩數相除后的余數。

#include <stdio.h>int main()
{printf("\n\n%d,%d\n",20/7,-20/7);printf("%f,%f\n",20.0/7,-20.0/7);return 0;
}

?運行結果:

?本例中,20/7,-20/7的結果均為整型,小數全部舍去。而20.0/7和-20.0/7由于有實數參與運算,因此結果也為實型。

(1)重點掌握除法“/”,當兩側都為整型時,結果也為整型。如10/3=3而不是3.3...這是新手常犯錯誤。

(2)求余運算符“%”;兩側必須為整型,其他類型錯誤。為常考點。

#include <stdio.h>int main()
{printf("%d\n",100%3);return 0;
}

?運行結果:

出結果的時候我有點蒙,但一想到是“%”取余,就明白了。?

本例輸出100除以3所得的余數為1。、

2.算術表達式和運算符的優先級和結合性(理解)

表達式是由常量、變量、函數和運算符組合起來的式子。一個表達式有一個值及其類型,它們等于計算表達式所得結果的值和類型。表達式求值按運算符的優先級和結合性規定的順序進行。單個的常量、變量、函數可以看作是表達式的特例。

算術表達式是由算術運算符和括號連接起來的式子。

(1)算術表達式:用算術運算符和括號將運算對象(也稱操作數)連接起來的、符合C語法規則的式子。

以下是算術表達式的例子:

a+b

(a*2)/c

(x+r)*8-(a+b)/7

++I

sin(x)+sin(y)

(++i)-(j++)+(k--)

(2)運算符的優先級(考點):C語言中,運算符的運算優先級共分為15級。1級最高,15級最低。在表達式中,優先級較高的先于優先級較低的進行運算。而在一個運算量兩側的運算符優先級相同時,則按運算符的結合性所規定的結合方向處理。

(3)運算符的結合性:C語言中各運算符的結合性分為兩種,即左結合性(自左向右)和右結合性(自右向左)。例如算術運算符的結合性是自左至右,即先左后右。如有表達式x-y+z則y應先與“-”號結合,執行x-y運算,然后再執行+z的運算。這種自左至右的結合方向就稱為“左結合性”。而自右至左的結合方向就稱為“右結合性”。最典型的右結合性運算符是賦值運算符。如x=y=z,由于“=”的右結合性,應先執行y=z再執行x=(y=z)運算。C語言運算符中有不少為右結合性,應注意區別,以避免理解錯誤。

3.強制類型轉換運算符(理解)

其一般形式為:

(類型說明符)(表達式)

其功能是把表達式的運算結果強制轉換成類型說明符所表示的類型。

例如:

(float)a 把a裝換為實型

(int)(x+y) 把x+y的結果轉換為整型

4.自增、自減運算符(重點考點)

自增1,自減1運算符:自增1運算符記為“++”,其功能是使變量的值自增1。

自減1運算符記為“--”,其功能是使變量值自減1。

自增1,自減1運算符均為單目運算,都具有右結合性。可有以下幾種形式:

++i? ? ? ? ?i自增1后再參與其它運算。

--i? ? ? ? ? i自減1后再參與其他運算。

i++? ? ? ? i參與運算后,i的值再自增1。

i--? ? ? ? i參與運算后,i的值再自減1。

在理解和使用上容易出錯的是i++和i--。特別是當它們出在較復雜的表達式或語句中時,常常難于弄清,因此應仔細分析。

#include <stdio.h>int main()
{int i = 8;printf("%d\n",++i);printf("%d\n",--i);printf("%d\n",i++);printf("%d\n",i--);printf("%d\n",-i++);printf("%d\n",-i--);return 0;
}

?運行結果:

?

?i的初值為8,第2行i加1后輸出故為9;第三行減1后輸出故為8;第四行輸出i為8之后再加1(為9);第5行輸出i為9之后再減1(為8);第6行輸出-8之后再加1(為9),第7行輸出-9之后再減1(為8)。

例3.17

#include <stdio.h>int main()
{int i = 5,j = 5,p,q;p=(i++)+(i++)+(i++);q=(++j)+(++j)+(++j);printf("%d,%d,%d,%d",p,q,i,j);return 0;
}

?運行結果:

?提示:此程序由于涉及到連續++,其結果在不同的編譯器有可能不同,目前已有[18,21,8,8][18,22,8,8][15,24,8,8]三種結果。在實際使用過程中,要避免此用法

很神奇,我在手機編譯軟件上的結果是[18,21,8,8]。先學到這一步吧,至于編譯器怎么做的,讓我以后再去探究。

這個程序中,對p=(i++)+(i++)+(i++)應理解為三個i相加,故p值為15。然后i再自增1三次相當于加3故i的最后值為8。而對于q的值則不然,q=(++j)+(++j)+(++j)應理解為j先自增1,再參與運算,由于j自增1三次后值為8,三個8相加的和為24,j的最后值仍為8;ps(手機軟件里的也有錯誤的,想要學好,真的要自己用心)

3.9 賦值運算符和賦值表達式(理解)

1.賦值運算符(理解)

簡單賦值運算符和表達式:簡單賦值運算符記為“=”。由“=”連接的式子稱為賦值表達式。其一般形式為:

變量=表達式

例如:

x=a+b

w=sin(a)+sin(b)

y=i+++--j? ? ? ? // 這個我的理解是y=(i++)+(--j)

賦值表達式的功能是計算表達式的值再賦予左邊的變量。賦值運算符具有右結合性。因此

a=b=c=5

可理解為

a=(b=(c=5))

在其它高級語言中,賦值構成了一個語句,稱為賦值語句。而在C中,把“=”定義為運算符,從而組成賦值表達式。凡是表達式可以出現的地方均可出現賦值表達式。

例如,式子:

x=(a=5)+(b=8)

是合法的。它的意義是把5賦予a,8賦予b,再把a,b相加,和賦予x,故x應等于13。

在C語言中也可以組成賦值語句,按照C語言規定,任何表達式在其末尾加上分號就構成為語句。因此如

x=8;

a=b=c=5;

都是賦值語句,在前面各例中我們已大量使用過了。

// 前面3.6章變量賦初值說定義中不允許連續賦值,這里又可以。我本以為是它寫錯了,正在罵它,后來仔細一看,定義中不允許連續賦值,原來我才是小丑。我試過了,定義的時候會報錯,調用的時候賦值不會報錯,重點在“定義”兩個字!

2.類型轉換(理解)

如果賦值運算符兩邊的數據類型不相同,系統將自動進行類型轉換,即把賦值號右邊的類型換成左邊的類型。具體規定如下:

1)實型賦予整型,舍去小數部分。前面的例子已經說明了這種情況。

2)整型賦予實型,數值不變,但將以浮點形式存放,即增加小數部分(小數部分的值為0)。

3)字符型賦予整型,由于字符型為一個字節,而整型為兩個字節,故將字符的ASCLL碼值放到整型量的低八位中,高八位為0。整型賦予字符型,只把低八位賦予字符量。

例3.18

#include <stdio.h>int main()
{int a,b = 322;float x,y=8.88;char c1='k',c2;a=y;x=b;a=c1;c2=b;printf("%d,%f,%d,%c",a,x,a,c2);return 0;
}

?本例表明了上述賦值運算中類型轉換的規則。a為整型,賦予實型量y值8.88后只取整數8。x為實型,賦予整型量b值322,后增加了小數部分。字符型量c1賦予a變為整型,整型量b賦予c2后取其低八位成為字符型(b的低八位為01000010,即十進制66,按ASCLL碼對應于字符B)。

3復合的賦值運算符(理解)

?在賦值符“=”之前加上其它二目運算符可構成復合賦值符。如+=,-=,*=,/=,%=,<<=,>>=,&=,^=,|=。

構成復合賦值表達式的一般形式為:

變量 雙目運算符=表達式

它等效于

變量=變量 運算符 表達式

例如:

a+=5 等價于a=a+5

x*=y+7 等價于x=x*(y+7)

r%=p 等價于r=r%p

復合賦值符這種寫法,對初學者可能不習慣,但十分有利于編譯處理,能提高編譯效率并產生質量較高的目標代碼。

3.10 逗號運算符和逗號表達式(理解)

在c語言中逗號“,”也是一種運算符,稱為逗號運算符。其功能是把兩個表達式連接起來組成一個表達式,稱為逗號表達式。

其一般形式為:

表達式1,表達式2

其求值過程是分別求兩個表達式的值,并以表達式2的值作為整個逗號表達式的值。

例3.19

#include <stdio.h>int main()
{int a=2,b=4,c=6,x,y;// 如果不加外層大括號,y=(x=a+b),(b+c);// 那么因為'='的優先級大于',',那么就會取第一個值y=((x=a+b),(b+c));printf("y=%d,x=%d",y,x);return 0;
}

?運行結果:

?

?本例中,y等于整個逗號表達式的值,也就是表達式2的值,x是第一個表達式的值。對于逗號表達式還要說明兩點:

1)逗號表達式一般形式中的表達式1和表達式2也可以又是逗號表達式。

例如:

表達式1,(表達式2,表達式3)

形成了嵌套情形。因此可以把逗號表達式擴展為以下形式:

表達式1,表達式2,...表達式n

整個逗號表達式的值等于表達式n的值。

2)程序中使用逗號表達式,通常是要分別求逗號表達式內各表達式的值,并不一定要求整個逗號表達式的值。

并不是在所有出現逗號的地方都組成逗號表達式,如在變量說明中,函數參數表中逗號只是用作各變量之間的間隔符。

3.11小結

3.11.1 C的數據類型

基本類型,構造類型,指針類型,空類型

3.11.2 基本類型的分類及特點

3.11.3 常量后綴

L或l? ? ? ? 長整型

U或u? ? ? ? 無符號數

F或f? ? ? ? 浮點數

3.11.4 常量類型

整數,長整數,無符號數,浮點數,字符,字符串,符號常數,轉義字符。

3.11.5 數據類型轉換

(1)自動轉換:在不同類型數據的混合運算中,由系統自動實現轉換,由少字節類型向多字節類型轉換。不同類型的量相互賦值時也由系統自動進行轉換,把賦值號右邊的類型轉換為左邊的類型。

(2)強制轉換:由強制轉換運算符完成轉換。

3.11.6 運算符優先級和結合性

一般而言,單目運算符優先級較高,賦值運算符優先級低。算術運算符優先級較高,關系和邏輯運算符優先級較低。多數運算符具有左結合性,單目運算符、三目運算符、賦值運算符具有右結合性。

3.11.7 表達式

表達式是由運算符連接常量、變量、函數所組成的式子。每個表達式都有一個值和類型。表達式求值按運算符的優先級和結合性所規定的順序進行。

總于完成了,寫了一下午加上晚上,大概有5個小時的時間。明天把這一整章節的內容合并一下,我自己看著都感覺好長,屏幕前的你呢?會不會覺得很長呢?可以的話可以給我留言,希望得到你們的建議,我每次打開博客都滿懷期待的希望有人可以給我留言反饋。可到現在一個也沒有(哭)還有很感謝給我點贊收藏加關注的粉絲朋友們,感謝你們的鼓勵,我會繼續輸出下去。讓我們一起變得越來越好吧!越來越好是多好呢?我也不知道,好是沒有盡頭的對嗎朋友。就像我的名字頸部者(本來我是想取進步者的,但好像注冊的時候被用了,然后我的頸椎不太好,所以我就改成了頸部者,用來提醒自己要保護頸椎,注意自己的坐姿,看到這里的朋友一定要注意自己的身體健康哦,我真的很后悔大學時候在床上買的那個懶人靠枕,以及我平常的壞習慣。我最疼的時候在床上躺著翻身都疼的要死,輕輕一動就疼的厲害,沒有疼痛的人真的很難感受這種痛苦,大家引以為戒吧)

我的各種網名名字一直是進步著之類的,感覺這樣是挺好的,但好像沒有盡頭一樣,像我這種普通人,什么都進步,全方面的發展好像就是全面平庸,合適的職業和人生目標我都沒有找到,但我的人生價值觀就是傳遞愛,友愛、敬愛、喜愛、等等愛~。首先愛我的女粉絲嘿嘿,今晚隨機親一口我的女粉絲嘿嘿嘿,反正我現在沒有女朋友,沒事,我心安理得。

心事分享完畢,接下來休息一下眼睛,拉伸一下身體就改簡歷啦,不會wps的頁面布局操作真是麻煩,網上的模板都要錢,潮了。

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/diannao/13569.shtml
繁體地址,請注明出處:http://hk.pswp.cn/diannao/13569.shtml
英文地址,請注明出處:http://en.pswp.cn/diannao/13569.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

【回憶版】數據科學思維與大數據智能分析 2024考試

填空&#xff08;18分&#xff09;18個 1.對數變換對大數值的范圍進行壓縮&#xff0c;對小數值的范圍進行擴展 2.提取出大量高頻率項與低頻率項相關聯的虛假模式&#xff0c;即交叉支持&#xff08;cross-support&#xff09;模式 3.信息論中&#xff08;&#xff09; 4.幾種…

[數據集][目標檢測]彈簧上料檢測數據集VOC+YOLO格式142張2類別

數據集格式&#xff1a;Pascal VOC格式YOLO格式(不包含分割路徑的txt文件&#xff0c;僅僅包含jpg圖片以及對應的VOC格式xml文件和yolo格式txt文件) 圖片數量(jpg文件個數)&#xff1a;142 標注數量(xml文件個數)&#xff1a;142 標注數量(txt文件個數)&#xff1a;142 標注類別…

yolov8訓練自己數據集時出現loss值為nan。

具體原因目前暫未尋找到。 解決辦法 將參數amp改成False即可。 相關資料&#xff1a; https://zhuanlan.zhihu.com/p/165152789 https://github.com/ultralytics/ultralytics/issues/1148

【BUG】Edge|聯想電腦 Bing 搜索報錯“Ref A: 亂碼、 Ref B:亂碼、Ref C: 日期” 的解決辦法

文章目錄 省流版前言解決辦法 詳細解釋版前言問題描述與排查過程解決辦法與總結 省流版 前言 我也不清楚咋滴了&#xff0c;Bing 搜索突然偶爾報錯&#xff1a; 換了代理關了插件都報錯。 參考&#xff1a; 我在用bing搜索時出現了如下代碼&#xff0c;導致bing無法使用&am…

nginx proxy_set_header詳解

proxy_set_header 是 Nginx 配置中的一個重要指令&#xff0c;特別是在使用 Nginx 作為反向代理時。該指令允許你修改由 Nginx 傳遞給代理后端的請求頭。這對于確保后端應用程序能夠接收到正確的客戶端信息&#xff08;如 IP 地址、主機名等&#xff09;以及控制緩存行為等場景…

1 計算機硬件-CPU-校驗碼-存儲系統-輸入輸出設備-總線結構

計算機硬件 考情分析&#xff1a;趨勢很小&#xff0c;22年考過&#xff0c;根據趨勢以后考的可能較小 基本組成&#xff1a;運算器&#xff0c;控制器&#xff0c;儲存器&#xff0c;輸入設備&#xff0c;輸出設備運算器和控制器也統稱為中央處理單元&#xff08;CPU&#xf…

【算法訓練 day37 檸檬水找零、長度最小的子數組、用最少數量的箭引爆氣球】

目錄 一、檸檬水找零-LeetCode 860思路實現代碼個人問題總結 二、根據身高重建隊列-LeetCode 406思路實現代碼個人問題總結 三.用最少數量的箭引爆氣球-LeeCode 406思路實現代碼個人問題總結 一、檸檬水找零-LeetCode 860 Leecode鏈接: leetcode 860 文章鏈接: 代碼隨想錄 視頻…

解鎖Nginx跨域謎題:3步打造安全高效的CORS策略

Nginx作為一款強大的Web服務器和反向代理服務器&#xff0c;經常被用于處理跨域資源共享&#xff08;CORS&#xff0c;Cross-Origin Resource Sharing&#xff09;策略&#xff0c;以允許或限制不同源之間的資源請求。CORS是一種安全策略&#xff0c;用于決定Web瀏覽器是否應允…

深度學習——圖像分類(CNN)—測試模型

測試模型 1.導入必要的庫2.加載測試數據集3.假設CSV文件中的圖像文件名是完整的路徑4.隨機選擇一張圖片進行展示5.加載圖像6.使用模型進行預測7.設置模型的預測結果8.計算準確率9.指定test文件夾路徑10.讀取名為image_path的圖片11.加載圖像12.檢查圖像是否為空 訓練的模型是上…

eNSP學習——OSPF單區域配置

目錄 相關命令 實驗背景 實驗目的 實驗步驟 實驗拓撲 實驗編址 實驗步驟 1、基礎配置 2、部署單區域OSPF網絡 3、檢查OSPF單區域的配置結果 OSPF——開放式最短路徑優先 基于鏈路狀態的協議&#xff0c;具有收斂快、路由無環、擴展性好等優點&#xff1b; 相關命令 […

【JAVA基礎之內部類】匿名內部類

&#x1f525;作者主頁&#xff1a;小林同學的學習筆錄 &#x1f525;小林同學的專欄&#xff1a;JAVA之基礎專欄 目錄 1.內部類 1.1 概述 1.1.1 什么是內部類 1.1.2 什么時候使用內部類 1.2 內部類的分類 1.3 成員內部類 1.3.1 獲取成員內部類對象的兩種方式 1.3.2 經典面試…

用C語言把一棵普通二叉樹安排得明明白白

1. 樹的相關術語 結點的度&#xff1a;一個結點含有的子樹的個數稱為該結點的度&#xff1b; 如上圖&#xff1a;A的為6 葉結點或終端結點&#xff1a;度為0的結點稱為葉結點&#xff1b; 如上圖&#xff1a;B、C、H、I...等結點為葉結點 非終端結點或分支結點&#xff1a;度不…

【Linux】-Tomcat安裝部署[12]

目錄 簡介 安裝 安裝部署JDK環境 解壓并安裝Tomcat 簡介 Tomcat是由Apache開發的一個Servlet容器&#xff0c;實現了對Servlet和JSP的支持&#xff0c;并提供了作為Web服務器的一些特有功能&#xff0c;如Tomcat管理和控制平臺、安全域管理和Tomcat閥等。 簡單來說&#…

使用 mysql-binlog-connector 監聽處理 MySQLBinlog 文件

1. 需求概述 業務開發中經常需要根據一些數據變更實現相對應的操作。例如&#xff0c;一些用戶注銷自己的賬戶&#xff0c;系統可以給用戶自動發短信確認&#xff0c;這時有兩種解決方案&#xff0c;一種是耦合到業務系統中&#xff0c;當用戶執行注銷操作的時候&#xff0c;執…

【軟件工程】【23.10】p2

關鍵字&#xff1a; 軟件復用技術、過程途徑、特定需求是文檔核心、數據字典條目、高內聚低耦合獨立性、數據流圖映射模塊結構圖、UML依賴、用例圖關系、RUB迭代、程序規格說明等價類劃分、有效性測試的目標、噴泉模型面向對象、軟件驗證過程、CMMI

算法提高之程序自動分析

算法提高之程序自動分析 核心思想&#xff1a;并查集 離散化 因為不是每個數都會用到 所以離散化一下**(不需要保留順序)**對于每一個值為1的等式 優先處理之后處理值為0的等式時 若ab已經連在一起 即為矛盾 #include <iostream>#include <cstring>#include &l…

【Linux】Centos7安裝RabbitMQ

【Linux】Centos7安裝RabbitMQ 下載 從 rabbitmq 的 GitHub 倉庫下載 https://github.com/rabbitmq/rabbitmq-server/releases rabbitmq 是 erlang 語言編寫的&#xff0c;需要先安裝 erlang https://github.com/rabbitmq/erlang-rpm/releases 安裝 使用rz命令上傳 erlang 和 …

Polar 網站被黑

Polar 網站被黑 開題&#xff0c;挺好看的前端&#xff0c;可惜啥也沒有。 信息搜集一波&#xff0c;掃目錄出現幾個敏感目錄&#xff0c;但是沒什么用。 繼續搜集&#xff0c;在返回包中發現了HINT F5XDAXZQNZSV6ZRRNZSF63JTF4base32解碼后是一個路由/n0_0ne_f1nd_m3/&#x…

數據倉庫實驗四:聚類分析實驗

目錄 一、實驗目的二、實驗內容和要求三、實驗步驟1、建立數據表2、建立數據源視圖3、建立挖掘結構Student.dmm4、部署項目并瀏覽結果5、挖掘模型預測 四、實驗結果分析五、實驗總結體會 一、實驗目的 通過本實驗&#xff0c;進一步理解基于劃分的、基于層次的、基于密度的聚類…

Easy-poi 和 EasyExcel 選型

目錄 共同點地址如何選 共同點 easy-poi 和 easyexcel 都是基于 apache poi 進行二次開發的&#xff0c;底層都是依賴的 apache poi使用簡單&#xff0c;都可以通過簡單的注解實現excel文件的導入導出 地址 esay poi 是一個開源的 excel,word 處理框架。鏈接 easy excel 是…