• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>

            xyjzsh

            猜猜執行結果

            static const char *msg[] = {"Sunday", "Monday", "Tuesday", "Wednesday", "Thursday", "Friday", "Saturday"};
            char *get_a_day(int idx)
            {
             static char buf[20];
             strcpy(buf, msg[idx]);
             return buf;
            }

            int main()
            {
             char *day0 = get_a_day(0);
             char *day1 = get_a_day(1);
             printf("%s %s\n", day0, day1);
             return 0;
            }

            結果是什么?

            posted @ 2011-07-20 13:52 呆人 閱讀(214) | 評論 (0)編輯 收藏

            error C3872: “0x3000”: 此字符不允許在標識符中使用——快速處理方法

            在從別處拷貝代碼到IDE時經常出現這類問題。出現問題的原因是:存在中文符號,一般為全角下的中文空格。
            為了快速出來這里錯誤,可以先把要拷貝的代碼拷貝到word中,用查找替換工具,將所有的全角下的空格,替換為英文下的半角空格。

            在vs2008中可以直接用它自帶的查找替換功能。

            posted @ 2011-05-17 14:52 呆人 閱讀(1531) | 評論 (0)編輯 收藏

            matlab生成dll后在vc中脫離matlab環境執行

            在沒有安裝matlab的機器上,要想運行matlab的dll要必須安裝MCR環境。
            在安裝了matlab的機器上,在 MATLAB\R2010b\toolbox\compiler\deploy\win32下面有MCR 的安裝程序。
            在安裝了MCR的機器上,就可以運行使用了matlab的dll的VC的可執行文件。

            posted @ 2011-05-16 16:05 呆人 閱讀(448) | 評論 (0)編輯 收藏

            matlab生成dll后在vc中脫離matlab環境執行

            在沒有安裝matlab的機器上,要想運行matlab的dll要必須安裝MCR環境。
            在安裝了matlab的機器上,在 MATLAB\R2010b\toolbox\compiler\deploy\win32下面有MCR 的安裝程序。
            在安裝了MCR的機器上,就可以運行使用了matlab的dll的VC的可執行文件。

            posted @ 2011-05-16 16:05 呆人 閱讀(1581) | 評論 (0)編輯 收藏

            vs2008中調用matlab生成的dll

            matlab版本為:matlab7.11.0(R2010b)
            vs2008

            1.在matlab中生成dll

            在m文件中實現如下功能:
            獲得N個魔方矩陣的秩。m文件的內容如下:
            function r = mrank(n)

            r = zeros(n,1);
            for k=1:n
                r(k) = rank(magic(k));
            end

            將上述內容保存為:mrank.m


            在matlab的command 窗口鍵入:
            >> mcc -B csharedlib:mrank mrank.m %該命令將在后面做說明

            在matlab7.0中執行上述命令后生成下面幾個文件:
            mrank.exp    mrank.exports   mrank.h   mrank.lib  mrank.c     mrank.dll  

            在vs2008中使用m文件的函數功能。
            首先配置vs2008的環境
            1.工具——> 選項——>項目和解決方案——>VC++目錄
            (1) 選擇“可執行文件”下拉框,添加:C:\Program Files\MATLAB\R2010b\bin\win32(注意:當前的Mathlab安裝在C:\Program Files下面)
            (2)選擇“包含文件”下拉框,添加:C:\Program Files\MATLAB\R2010b\extern\include
            (3)選擇“引用文件”下拉框,添加:C:\Program Files\MATLAB\R2010b\extern\lib
            (4)選擇“庫文件”下拉框,添加:C:\Program Files\MATLAB\R2010b\extern\lib\win32\microsoft
            上述環境只需要配置一次

            對于每一個工程,做下面的設置
            項目——>屬性——>連接器——>輸入
            選擇:附加依賴項:添加:
            libmex.lib
            libmx.lib
            libmat.lib
            mclmcrrt.lib

            將mrank.h  mrank.lib  mrank.dll拷貝到當前目錄下
            cpp文件中中的內容如下:
            #include "stdafx.h"
            #include<stdlib.h>
            #include"matrix.h"
            #include"mrank.h"
            #include "mclmcrrt.h"
            #pragma comment(lib,"mrank.lib")

            int main()
            {
              mxArray *N(NULL),*R(NULL);
             int n =12;

             mrankInitialize();//初始化動態鏈接庫
             N = mxCreateDoubleScalar(n);//用n來初始化生成的數組,其實標量就是一個1*1的數組
             mlfMrank(1,&R,N);//執行m文件的主要功能
             
             size_t num = mxGetM(R);//R的行的個數
             double *res = new double[num];
             memset(res,0,sizeof(double)*num);

             memcpy(res,mxGetPr(R),sizeof(double)*num);

             for(int i=0;i<num;++i)
              printf("%f\n",res[i]);

             delete[] res;
             mxDestroyArray(N);
             mxDestroyArray(R);
             
             mrankTerminate();//終止動態數據連接
            return 0;
            }

            上述cpp文件使用了Matlab編譯m文件生成的dll,在cpp中通過mxArray這個數據結構來和dll中的方法進行信息交換。
            這樣就在cpp中調用了matlab中的m文件實現的方法。

            mcc命令說明:
            http://www.cnblogs.com/juneja/archive/2008/10/31/1323423.html

            posted @ 2011-05-12 17:28 呆人 閱讀(4588) | 評論 (0)編輯 收藏

            返回值為函數指針的寫法

            下面方法的作用是:通過key的類型返回對應的哈希函數的指針

            static int (*hashFunction(int keyClass))(const void*,int)
            {
            /*內容省略*/
            }

            函數的名字是:hashFunction,該函數為只有1個int型參數為。
            該函數的返回值為一個函數指針,函數有2個參數,第一個類型為const void*,第二個為int,返回值為int 。

            posted @ 2011-04-26 15:36 呆人 閱讀(704) | 評論 (0)編輯 收藏

            c語言中模擬動態綁定

            struct本身不能支持動態綁定,為了實現統一接口,我們希望實現動態綁定。
            例如在不同的操作系統下,對文件的操作是不同,但是我們希望統一結構,有如下結構
            struct OSFile
            {
                PIOMethod pMethods;
               /*
               其他信息
              */
            };

            struct WinOSFile
            {
            PIOMethod pMethods;
            ..........
            };

            struct UnixOSFile
            {
            PIOMethod pMethods;
            ..........
            };

            有如下方法:
            void UniAPI(OSFile *file);
            為了實現動態綁定,做法是在調用該方法之前,將WinOSFile或者UnixOSFile的pMethods賦給OSFile的pMethods從而實現動態綁定。

            posted @ 2011-04-26 15:30 呆人 閱讀(521) | 評論 (0)編輯 收藏

            按位使用數據以及union

            例如:
            typedef union tagData
            {
               long x:2;
               long y:4;
               long data;
            }data_item,*pdata_item;

            上述是一個聯合體,聯合體的對象用的空間是類型中占用內存最大的哪個,例如上例中data_item變量占用4個字節。
            long x:2;
            表示x占用2bit
            long y:4;
            表示y占用4bit
            long data;
            data占用4byte
            所以上述union占用4byte空間。
            long s=sizeof(data_item);
            s=4;

            因為x,y,data公用內存空間。
            從低位開始,即
            x占用空間的低2bit,即0-1
            y占用空間2~5bit
            x,y都是可以是有符號的,相對最高位表示符號位。
            例如,
            item_data t={0};
            (1) t.data = 2;
            2表示成二進制位10.
            所以t.x 的值為-2;
            (2) t.data = 3;
            3表示成二進制位11
            所以t.x的值為-1
            (3) t.data =1;
            此時t.x的值為1

            t.y的取值的道理同t.x;
            對于t.y來說第5位表示正負號。



            posted @ 2011-03-15 17:34 呆人 閱讀(572) | 評論 (0)編輯 收藏

            宏定義中字符串連接操作

            宏定義中字符串連接操作

            關于記號粘貼操作符(token paste operator): ##

            1. 簡單的說,“##”是一種分隔連接方式,它的作用是先分隔,然后進行強制連接

               其中,分隔的作用類似于空格。我們知道在普通的宏定義中,預處理器一般把空格
               解釋成分段標志
            ,對于每一段和前面比較,相同的就被替換。但是這樣做的結果是,
               被替換段之間存在一些空格。如果我們不希望出現這些空格,就可以通過添加一些
               ##來替代空格

               另外一些分隔標志是,包括操作符,比如 +, -, *, /, [,], …,所以盡管下面的
               宏定義沒有空格,但是依然表達有意義的定義: define add(a, b)  a+b

               而其強制連接的作用是,去掉和前面的字符串之間的空格,而把兩者連接起來。

            2. 舉列 – 試比較下述幾個宏定義的區別

               #define A1(name, type)  type name_##type##_type 或
               #define A2(name, type)  type name##_##type##_type

               A1(a1, int);  /* 等價于: int name_int_type; */
               A2(a1, int);  /* 等價于: int a1_int_type;   */

               解釋:
                    1) 在第一個宏定義中,”name”和第一個”_”之間,以及第2個”_”和第二個
               ”type”之間沒有被分隔,所以預處理器會把name_##type##_type解釋成3段:
               “name_”、“type”、以及“_type”,這中間只有“type”是在宏前面出現過
                的,所以它可以被宏替換。

                    2) 而在第二個宏定義中,“name”和第一個“_”之間也被分隔了,所以
               預處理器會把name##_##type##_type解釋成4段:“name”、“_”、“type”
               以及“_type”,這其間,就有兩個可以被宏替換了。

                    3) A1和A2的定義也可以如下:
                       #define A1(name, type)  type name_  ##type ##_type  
                                                  <##前面隨意加上一些空格>
                       #define A2(name, type)  type name ##_ ##type ##_type

                結果是## 會把前面的空格去掉完成強連接,得到和上面結果相同的宏定義

            3. 其他相關 – 單獨的一個 #

               至于單獨一個#,則表示 對這個變量替換后,再加雙引號引起來。比如

                  #define  __stringify_1(x)   #x
            那么
                  __stringify_1(linux)   <==>  ”linux”

            所以,對于MODULE_DEVICE_TABLE

                 1) #define MODULE_DEVICE_TABLE(type,name)                        
                         MODULE_GENERIC_TABLE(type##_device,name)
                 2) #define MODULE_GENERIC_TABLE(gtype,name)                      
                         extern const struct gtype##_id __mod_##gtype##_table     
                         __attribute__ ((unused, alias(__stringify(name))))

            得到  
                  MODULE_DEVICE_TABLE(usb, products)  
                                         /*notes: struct usb_device_id products; */
             <==> MODULE_GENERIC_TABLE(usb_device,products)
             <==> extern const struct usb_device_id __mod_usb_device_table     
                         __attribute__ ((unused, alias(“products”)))   

            注意到alias attribute需要一個雙引號,所以在這里使用了__stringify(name)來
            給name加上雙引號。另外,還注意到一個外部變量”__mod_usb_device_table”被alias
            到了本驅動專用的由用戶自定義的變量products<usb_device_id類型>。這個外部變量
            是如何使用的,更多的信息請參看《probe()過程分析》。

            4. 分析方法和驗證方式 – 編寫一個簡單的C程序

               用宏定義一個變量,同時用直接方式定義一個相同的變量,編譯報告重復定義;
               用宏定義一個變量,直接使用該宏定義的變量名稱,編譯通過且運行結果正確;

            posted @ 2011-03-15 13:49 呆人 閱讀(4538) | 評論 (0)編輯 收藏

            虛擬指針的問題——memset相關


            class Node
            {
              
            public:
            Node(
            void){}
            ~Node(void){}
            virtual bool IsLeafNode()=0;

            }
            ;
            class InternalNode:public Node
            {
            public:
            InternalNode()
            {}
            virtual ~InternalNode(void){}
            virtual bool IsLeafNode(){return false;}
            }
            ;

            class LeafNode:public Node
            {
            public:
            LeafNode()
            {}
            virtual ~LeafNode(){}
            virtual bool IsLeafNode(){return true;}
            }
            ;


            定義以上的繼承結構:LeafNode和InternalNode繼承自Node
            有一個虛方法IsLeaf來判斷是否為葉子節點。
            下面有這樣的測試代碼:
            test()
            {
               Node *node = new InternalNode();
               memset(node,0,sizeof(InternalNode));
               node->IsLeafNode();
            }
            上述代碼編譯正常,而運行時出錯!
            出現上述問題的原因是:
            對于有虛函數的類,每一個類有一個虛函數表,而每一個對象中會有一個指針指向這個虛函數表。
            當   Node *node = new InternalNode();時編譯器會把一個指針知道InternalNode的虛函數表
            但是memset(node,0,sizeof(InternalNode));卻把這個指針設成了。
            所以在調用的時候出現了運行時錯誤!

            posted @ 2011-03-14 15:46 呆人 閱讀(445) | 評論 (0)編輯 收藏

            僅列出標題
            共6頁: 1 2 3 4 5 6 
            <2025年5月>
            27282930123
            45678910
            11121314151617
            18192021222324
            25262728293031
            1234567

            導航

            統計

            常用鏈接

            留言簿(1)

            隨筆分類

            隨筆檔案

            搜索

            最新評論

            閱讀排行榜

            評論排行榜

            亚洲国产精品综合久久网络| 亚洲人成网亚洲欧洲无码久久| 亚洲AV日韩AV天堂久久| 天天爽天天狠久久久综合麻豆| 久久精品国产免费观看| 亚洲第一永久AV网站久久精品男人的天堂AV| 亚洲国产精品久久久久婷婷老年| 狠狠久久综合伊人不卡| 99精品国产99久久久久久97| 好久久免费视频高清| 欧美国产成人久久精品| 久久久久久久综合日本亚洲| 国产香蕉97碰碰久久人人| 久久久久久精品久久久久| 99久久国产综合精品成人影院| 久久亚洲精品无码aⅴ大香| 国产精品免费久久久久影院| 亚洲国产精品无码久久一线| 国产成人无码精品久久久免费| 久久乐国产综合亚洲精品| 麻豆精品久久久一区二区| 亚洲欧洲精品成人久久奇米网| 伊人丁香狠狠色综合久久| 久久AV高清无码| 久久久久青草线蕉综合超碰| 久久久久亚洲av成人无码电影| 久久久久亚洲AV无码网站| 久久精品国产亚洲AV影院| 久久精品国产福利国产琪琪| 91久久精一区二区三区大全| 18禁黄久久久AAA片| 日本欧美国产精品第一页久久| 日本精品久久久久中文字幕8| 亚洲午夜久久久久妓女影院 | 久久精品国产精品亚洲毛片 | 99久久精品日本一区二区免费| 亚洲成av人片不卡无码久久 | 色综合久久中文字幕综合网| 精品欧美一区二区三区久久久| 激情久久久久久久久久| 久久综合伊人77777|