阿里-測(cè)試開(kāi)發(fā)面經(jīng)(七)
點(diǎn)擊藍(lán)字關(guān)注我們,獲取更多面經(jīng)



多線程通信的方法主要有以下三種:
1.全局變量
進(jìn)程中的線程間內(nèi)存共享,這是比較常用的通信方式和交互方式。
注:定義全局變量時(shí)最好使用volatile來(lái)定義,以防編譯器對(duì)此變量進(jìn)行優(yōu)化。
2.message消息機(jī)制
常用的message通信的接口主要有兩個(gè):postmessage和postthreadmessage,
postmessage為線程向主窗口發(fā)送消息。而postthreadmessage是任意兩個(gè)線程之間的通信接口。
2.1.postmessage()
函數(shù)原型:
b00l postmessage(hwnd hwnd,uint msg,wparam wparam,lparam lparam);
參數(shù):
hwnd:其窗口程序接收消息的窗口的句柄。可取有特定含義的兩個(gè)值:
hwnd.broadcast:消息被寄送到系統(tǒng)的所有頂層窗口,包括無(wú)效或不可見(jiàn)的非自身?yè)碛械拇翱凇⒈桓采w的窗口
和彈出式窗口。消息不被寄送到子窗口。
null:此函數(shù)的操作和調(diào)用參數(shù)dwthread設(shè)置為當(dāng)前線程的標(biāo)識(shí)符postthreadmessage函數(shù)一樣。
msg:指定被寄送的消息。
wparam:指定附加的消息特定的信息。
iparam:指定附加的消息特定的信息。
返回值:如果函數(shù)調(diào)用成功,返回非零值:如果函數(shù)調(diào)用失敗,返回值是零。
ms還提供了sendmessage方法進(jìn)行消息間通訊,sendmessage(),他和postmessage的區(qū)別是:
sendmessage是同步的,而postmessage是異步的。sendmessage必須等發(fā)送的消息執(zhí)行之后,才返回。
2.2.postthreadmessage()
postthreadmessage方法可以將消息發(fā)送到指定線程。
函數(shù)原型:bool postthreadmessage(dword idthread,uint msg,wparam wparam, lparam lparam);
參數(shù)除了threadid之外,基本和postmessage相同。
目標(biāo)線程通過(guò)getmessage()方法來(lái)接受消息。
注:使用這個(gè)方法時(shí),目標(biāo)線程必須已經(jīng)有自己的消息隊(duì)列。否則會(huì)返回error_invalid_thread_id錯(cuò)誤。可以用
peekmessage()給線程創(chuàng)建消息隊(duì)列。
3.cevent對(duì)象
cevent為mfc中的一個(gè)對(duì)象,可以通過(guò)對(duì)cevent的觸發(fā)狀態(tài)進(jìn)行改變,從而實(shí)現(xiàn)線程間的通信和同步。


某個(gè)表格存著 s_name subject score 三個(gè)字段,比如某一行是 張三 數(shù)學(xué) 76,現(xiàn)在要選取出所有科目成績(jī)都大于80分的學(xué)生名字
select s_name from table_name where s_name not in (select s_name from table_name where score <80)


//新建一個(gè)類(lèi)public class BinaryNode {public int value = 0;public BinaryNode left;public BinaryNode right;public BinaryNode(int value) {this.value = value;}}//生成二叉樹(shù)方法public class BinaryTreeUtils {public static void createBinaryTree(BinaryNode root, int[] array) {root.value = array.length > 0 ? array[0] : -1;for (int i = 1; i < array.length; i++) {insertBinaryTreeNode(root, array[i]);}}private static void insertBinaryTreeNode(BinaryNode root, int value) {if (root.value >= value) {if (root.left == null) {root.left = new BinaryNode(value);return;} else {insertBinaryTreeNode(root.left, value);}} else {if (root.right == null) {root.right = new BinaryNode(value);return;} else {insertBinaryTreeNode(root.right, value);}}}}//深度優(yōu)先遍歷public static void printBinaryTreeDepthFirst(BinaryNode root){Stack stack = new Stack();stack.push(root);while (!stack.isEmpty()){root = (BinaryNode) stack.pop();System.out.print(root.value + " ");if (root.right != null){stack.push(root.right);}if (root.left != null){stack.push(root.left);}}}


第一張表命名為kemu,第二張表命名為score:

kemu表

score表
一、left join
顧名思義,就是“左連接”,表1左連接表2,以左為主,表示以表1為主,關(guān)聯(lián)上表2的數(shù)據(jù),查出來(lái)的結(jié)果顯示左邊的所有數(shù)據(jù),然后右邊顯示的是和左邊有交集部分的數(shù)據(jù)。如下:
select * from kemu left join score on kemu.id = score.id
結(jié)果集:

二、right join
“右連接”,表1右連接表2,以右為主,表示以表2為主,關(guān)聯(lián)查詢(xún)表1的數(shù)據(jù),查出表2所有數(shù)據(jù)以及表1和表2有交集的數(shù)據(jù),如下:
select * from kemu right join score on kemu.id = score.id
結(jié)果集:

三、join
join,其實(shí)就是“inner join”,為了簡(jiǎn)寫(xiě)才寫(xiě)成join,兩個(gè)是表示一個(gè)的,內(nèi)連接,表示以?xún)蓚€(gè)表的交集為主,查出來(lái)是兩個(gè)表有交集的部分,其余沒(méi)有關(guān)聯(lián)就不額外顯示出來(lái),這個(gè)用的情況也是挺多的,如下
select * from kemu join score on kemu.id = score.id
結(jié)果集:



1.GET:一般用于信息獲取,使用URL傳遞參數(shù),對(duì)所發(fā)送信息的數(shù)量也有限制,一般在2000個(gè)字符
2.GET:傳送的數(shù)據(jù)量較小,不能大于2KB。post 傳送的數(shù)據(jù)量較大,一般被默認(rèn)為不受限制。但理論上,IIS4中最大量為80KB,IIS5中為100KB。用IIS過(guò)濾器的只接受get參數(shù),所以一般大型搜索引擎都是用get方式
3.GET:是從服務(wù)器上獲取數(shù)據(jù),post 是向服務(wù)器傳送數(shù)據(jù)。get 請(qǐng)求返回 request – URI 所指出的任意信息。
4.GET:是把參數(shù)數(shù)據(jù)隊(duì)列加到提交表單的ACTION屬性所指的URL中,值和表單內(nèi)各個(gè)字段一一對(duì)應(yīng),在URL中可以看到。post是通過(guò)HTTP post機(jī)制,將表單內(nèi)各個(gè)字段與其內(nèi)容放置在HTML HEADER內(nèi)一起傳送到ACTION屬性所指的URL地址,用戶(hù)看不到這個(gè)過(guò)程。
5.POST:一般用于修改服務(wù)器上的資源,對(duì)所發(fā)送的信息沒(méi)有限制。
6.GET方式需要使用Request.QueryString來(lái)取得變量的值,而POST方式通過(guò)Request.Form來(lái)獲取變量的值,也就是說(shuō)Get是通過(guò)地址欄來(lái)傳值,而Post是通過(guò)提交表單來(lái)傳值。
更多面經(jīng)
掃描二維碼
獲取更多面經(jīng)
扶搖就業(yè)
