Time of Update: 2018-12-06
如果試圖直接使用C++的成員函數作為回呼函數將發生錯誤,甚至編譯就不能通過。其錯誤是普通的C++成員函數都隱含了一個傳遞函數作為參數,亦即“this”指標,C++通過傳遞this指標給其成員函數從而實現程式函數可以訪問C++的資料成員。這也可以理解為什麼C++類的多個執行個體可以共用成員函數卻-有不同的資料成員。由於this指標的作用,使得將一個CALL-BACK型的成員函數作為回呼函數安裝時就會因為隱含的this指標使得函數參數個數不匹配,從而導致回呼函數安裝失敗。要解決這一問題的關鍵就是不讓
Time of Update: 2018-12-06
節選自:http://www.cnblogs.com/hlxs/archive/2011/08/17/2142820.html有十二個乒乓球形狀、大小相同,其中只有一個重量與其它十一個不同,現在要求用一部沒有砝碼的天秤稱三次,將那個重量異常的球找出來,並且知道它比其它十一個球較重還是較輕。 一:天平兩邊先各6個球由於兩邊的重量肯定不等,不用稱都知道天平肯定不能平衡,白白浪費一次,難道你自認為牛B到用2次就能得出結論,顯然你不會這樣認為,排除。 二:天平兩邊先各5個球
Time of Update: 2018-12-06
1.內嵌函式是個靜態行為,而虛函數是個動態行為,他們之間是有矛盾的。 2.我們之所以能看到一些象內嵌函式的虛函數,是因為某個函數是否是內嵌函式不是由我們說的算,而是由編譯器決定的。我們只能向編譯器建議,某個函數可以是內嵌函式(inline關鍵字),但是編譯器有自己的判斷法則。所以可能出現這樣的情況: 2.1 我們用inline聲明的函數卻沒有inline 2.2 我們沒有用inline聲明的函數卻是inline 2.3
Time of Update: 2018-12-06
建立一個新進程的方法只有由某個已存在的進程調用fork()或vfork(),當然某些進程如init等是作為系統啟動的一部風而被核心建立的。1.fork函數介紹#include sys/types.h>#include unistd.h>pid_t fork (void
Time of Update: 2018-12-06
1.遊標的概念遊標是指向查詢結果集的一個指標,它是一個通過定義語句與一條Select語句相關聯的一組SQL語句。遊標包含兩方面的內容:●遊標結果集:執行其中的Select語句所得到的結果集;●遊標位置:一個指向遊標結果集內的某一條記錄的指標利用遊標可以單獨操縱結果集中的每一行。遊標在定義以後存在兩種狀態:關閉和開啟。當遊標關閉時,其查詢結果集不存在;只有當遊標開啟時,才能按行讀取或修改結果集中的資料。2.使用遊標一個應用程式可以使用兩種類型的遊標:前端(客戶)遊標和後端(伺服器)遊標,它們是兩個
Time of Update: 2018-12-06
Web伺服器壓力測試工具http load使用教程命令列工具http_load看上去和apache的ab很相似,用來做網站的壓力測試。其主要用法為:1.http_load -parallel 5 -fetches 1000 urls.txt2.http_load -rate 2 -seconds 300 urls.txt例子只是個參考,參數其實可以自由組合,參數之間的選擇並沒有什麼限制。比如你寫成http_load -parallel 5 -seconds 300
Time of Update: 2018-12-06
error C2713: Only one form of exception handling permitted per function錯誤的我的處理方式:(C++)當我在一個函數中同時使用try-catch try-finally的嵌套使用時,會提示上面的錯誤,錯誤的意思大概是,不允許在一個函數中出現兩種異常的處理方式,我想是不是不能嵌套使用啊,於是我就在一個函數中同時使用這兩個,但是不嵌套使用了,錯誤依然是上面的。現在我沒辦法了,只能在不在一個函數中同時使用了,我就用了一種折中的方案,
Time of Update: 2018-12-06
KeepAlive的原理 在HTTP1.0和HTTP1.1協議中都有對KeepAlive的支援。其中HTTP1.0需要在request中增加”Connection: keep-alive“ header才能夠支援,而HTTP1.1預設支援。HTTP1.0 KeepAlive支援的資料互動流程如下: a)Client發出request,其中該request的HTTP版本號碼為1.0。同是在request中包含一個header:”Connection: keep-alive“。
Time of Update: 2018-12-06
對於出現異常時,不能釋放堆記憶體的問題:例如:#include <iostream> 02using namespace std; 03class normal_pointer_example 04{ 05public: 06 normal_pointer_example(){cout<<"建構函式執行!\n";} 07 ~normal_pointer_example(){cout<<"解構函式執行!\n";} 08}; 09class
Time of Update: 2018-12-06
歸併排序(Merge Sort)是利用"歸併"技術來進行排序。歸併是指將若干個已排序的子檔案合并成一個有序的檔案。1、演算法基本思路 設兩個有序的子檔案(相當於輸入堆)放在同一向量中相鄰的位置上:R[low..m],R[m+1..high],先將它們合并到一個局部的暫存向量R1(相當於輸出堆)中,待合并完成後將R1複製回R[low..high]中。(1)合并過程
Time of Update: 2018-12-06
下面是一個實現3*3維數組的乘法!#include<iostream>#include<vector>using namespace std;int k=0;vector<int> c;void array(int a[],int n,int b[]){ for(int i=0;i<n*n;) { for(int
Time of Update: 2018-12-06
BUG品質分析,通過分詞,得到了大量的關鍵詞,但是存在很多垃圾資料,譬如大量的停止此 和數字,因此進行過濾是必不可少的呢。#-*- coding: utf-8 -*-import osimport sysdef func_filter(stopword,bugkey,keyword):if not os.path.isfile(stopword) or not os.path.isfile(bugkey):print "ERROR : The file , stopword or bugkey
Time of Update: 2018-12-06
二維數組和指標⑴ 用指標表示二維數組元素。要用指標處理二維數組,首先要解決從儲存的角度對二維數組的認識問題。我們知道,一個二維數組在電腦中儲存時,是按照先行後列的順序依次儲存的,當把每一行看作一個整體,即視為一個大的數組元素時,這個儲存的二維數組也就變成了一個一維數組了。而每個大數組元素對應二維數組的一行,我們就稱之為行數組元素,顯然每個行數組元素都是一個一維數組下面我們討論指標和二維數組元素的對應關係,清楚了二者之間的關係,就能用指標處理二維數組了。設p是指向數組a的指標變數,若有:p=a[0
Time of Update: 2018-12-06
#include <windows.h>#include <iostream>using std::cout; using std::endl;int main(){ char *str[]={"Welcome","to","Fortemedia","Nanjing"}; char **p=str+1; //p指向str[1] str[0]=(*p++)+2; //p指向str[2]
Time of Update: 2018-12-06
1。where 1=0; 這個條件始終為false,結果不會返回任何資料,只有表結構,可用於快速建表;2。where 1>0;始終為true,返回所有資料記錄;3。where 1<0; 和1 一樣另外表結構的意思如下:表結構就是定義一個表的欄位、類型、主鍵、外鍵、索引,這些基本的屬性群組成了資料庫的表結構例如:create table student (id int primarykey,name varchar,sex varchar,age
Time of Update: 2018-12-06
#include<iostream>#include<set>using namespace std;void up_and_down(int i){ cout<<i<<" "<<&i<<endl; if(i<4) up_and_down(i+1); cout<<i<<" "<<&i<<endl;}int main(){ up_and_
Time of Update: 2018-12-06
/****assert.h - define the assert macro****/#include <crtdefs.h>//移除可能的assert定義,確保assert未定義//但據測試,“後面”的#defines會覆蓋之前的#defines//這裡考慮周全,值得學習!#undef assert//如果定義了NDEBUG,那麼關閉assert宏//在Release模式下,會自動定義NDEBUG,這樣就取消了assert斷言,即定義為一個no-op#ifdef
Time of Update: 2018-12-06
typedef常見用法1.常規變數類型定義例如:typedef unsigned char uchar描述:uchar等價於unsigned char類型定義 uchar c聲明等於unsigned char c聲明2.數群組類型定義例如: typedef int array[2];描述: array等價於 int [2]定義; array a聲明等價於int a[2]聲明擴充: typedef int array[M][N];描述: array等價於 int
Time of Update: 2018-12-06
package weibo4j.examples;import weibo4j.Status;import weibo4j.Weibo; public class UpdateStatus { /** * 發布一條微博資訊 * @param args */ public static void main(String[] args) { System.setProperty("weibo4j.oauth.consumerKey",
Time of Update: 2018-12-06
1. 指標和iterator都支援與整數進行+,-運算,而且其含義都是從當前位置向前或者向後移動n個位置2. 指標和iterator都支援減法運算,指標-指標得到的是兩個指標之間的距離,迭代器-迭代器得到的是兩個迭代器之間的距離3. 通過指標或者iterator都能夠修改其指向的元素通過上面這幾點看,兩者真的很像,但是兩者也有著下面的幾個不同地方1. cout操作符可以直接輸出指標的值,但是對迭代器進行在操作的時候會報錯。通過看報錯資訊和標頭檔知道