青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

posts - 5, comments - 10, trackbacks - 0, articles - 0
  C++博客 :: 首頁 :: 新隨筆 :: 聯(lián)系 :: 聚合  :: 管理

2014年7月6日

作者:flysnwoxg
c++編譯器模板解析確實(shí)很強(qiáng)大。基本上可以把編譯器看做是一個虛擬機(jī),c++模板源代碼就是被執(zhí)行的腳本代碼。
基本上你可以在編譯期實(shí)現(xiàn)任何算法。
下面是一個按照從小到大,然后從大到小對數(shù)值對排序的程序,程序使用了冒泡排序,排序在編譯期完成。
例如程序的原始輸入為: ((5,6),(1,5),(3,4))
將被從小到大排序?yàn)?nbsp; ((1,5),(3,4),(5,6))
然后被從大到小排序?yàn)?nbsp; ((5,6),(3,4),(1,5))


//author:flysnowxg 
#include "stdio.h"
//用模板表示類型,模板的實(shí)例化表示對象(如pait_t<1,2> 表示(1,2)這樣的兩個值的對象)
template<int _first,int _second>
struct pair_t{
    static const int first=_first;
    static const int second=_second;
    static void print(){printf("%d %d",first,second);}
};

//計算兩個不同的pair_t類型的實(shí)例的小于關(guān)系
template <typename T1,typename T2
struct  less_t{
    static const int first_le=T1::first<T2::first;
    static const int first_eq=T1::first==T2::first;
    static const int second_le=(first_eq&&(T1::second<T2::second));
    static const int result=first_le || second_le;
};

//計算兩個不同的pair_t類型的實(shí)例的大于關(guān)系
template <typename T1,typename T2
struct  greate_t{
    static const int result=!less_t<T1,T2>::result;
};

struct null_t;
//類型列表
template <typename T1,typename T2struct list_t;
template <typename T>
struct list_t<T,null_t>{
    typedef T value;
    typedef null_t next;
};
template <typename T1,typename T2,typename T3>
struct list_t<T1,list_t<T2,T3> >
{
    typedef T1 value;
    typedef list_t<T2,T3next
};
#define list_t1(e1list_t<e1,null_t>
#define list_t2(e1,e2list_t<e1,list_t1(e2)>
#define list_t3(e1,e2,e3list_t<e1,list_t2(e2,e3)>
#define list_t4(e1,e2,e3,e4list_t<e1,list_t3(e2,e3,e4)>
#define list_t5(e1,e2,e3,e4,e5list_t<e1,list_t4(e2,e3,e4,e5)>
#define list_t6(e1,e2,e3,e4,e5,e6list_t<e1,list_t5(e2,e3,e4,e5,e6)>
#define list_t7(e1,e2,e3,e4,e5,e6,e7list_t<e1,list_t6(e2,e3,e4,e5,e6,e7)>
#define list_t8(e1,e2,e3,e4,e5,e6,e7,e8list_t<e1,list_t7(e2,e3,e4,e5,e6,e7,e8)>
#define list_t9(e1,e2,e3,e4,e5,e6,e7,e8,e9list_t<e1,list_t8(e2,e3,e4,e5,e6,e7,e8,e9)>
#define list_t10(e1,e2,e3,e4,e5,e6,e7,e8,e9,e10list_t<e1,list_t9(e2,e3,e4,e5,e6,e7,e8,e9,e10)>

//遞歸打印類型列表中每個類型的值
template<typename Tstruct print_t;
template<typename T>
struct print_t<list_t<T,null_t>>
{
    typedef typename T result;
    static void print(){
        printf("\nelem::");
        result::print();
    }
};
template<typename T1,typename T2>
struct print_t<list_t<T1,T2>>
{
    typedef typename T1 result;
    static void print(){
        printf("\nelem::");
        result::print();
        print_t<T2>::print();
    }
};

//冒泡排序算法
template<typename T,template <typename,typenameclass CompareTstruct sort_t;
template<typename T,template <typename,typenameclass CompareT>
struct sort_t<list_t<T,null_t> ,CompareT>{
    typedef list_t<T,null_tsort_head;
    typedef T least_elem;
    typedef null_t remainder;
    typedef list_t<T,null_tresult;
};
template<typename T1,typename T2,template <typename,typenameclass CompareT>
struct sort_t<list_t<T1,T2>,CompareT>{
    template<bool _b_swapstruct swap_t{
        typedef list_t<T1,T2result;
    };
    template<> struct swap_t<false>{
        typedef list_t<typename T2::value,list_t<T1,typename T2::next> > result;
    };
    static const int order=!CompareT<T1,T2::value>::result;
    typedef typename swap_t<order>::result sort_head;//假如CompareT是less_t,將開頭兩個元素中大的放前面,小的放后面
    typedef typename sort_t<typename sort_head::next,CompareT>::least_elem least_elem;//假如CompareT是less_t,獲取列表中最小的元素
    typedef list_t<typename sort_head::value,typename sort_t<typename sort_head::next,CompareT>::remainderremainder;//去掉末尾那個最小元素
    typedef list_t<least_elem,typename sort_t<remainder,CompareT>::resultresult;//將最小元素和剩余已經(jīng)排好序的元素鏈表組成一個新鏈表
}; 
int main(int argccharargv[])
{
    typedef pair_t<50,6> e1_t;
    typedef pair_t<9,10> e2_t;
    typedef pair_t<1,2> e3_t;
    typedef pair_t<7,8> e4_t;
    typedef pair_t<3,4> e5_t;
    typedef pair_t<-6,4> e6_t;

    typedef list_t6(e1_t,e2_t,e3_t,e4_t,e5_t,e6_tdate_t;
    printf("原始數(shù)據(jù):");
    print_t<date_t>::print();

    typedef sort_t<date_t,less_t>::result data_ta;
    printf("\n\n從小到大:");
    print_t<data_ta>::print();

    typedef sort_t<date_t,greate_t>::result data_tb;
    printf("\n\n從大到小:");
    print_t<data_tb>::print();
 
最后的輸出:
原始數(shù)據(jù):
elem::50 6
elem::9 10
elem::1 2
elem::7 8
elem::3 4
elem::-6 4
從小到大:
elem::-6 4
elem::1 2
elem::3 4
elem::7 8
elem::9 10
elem::50 6
從大到小:
elem::50 6
elem::9 10
elem::7 8
elem::3 4
elem::1 2
elem::-6 4

posted @ 2014-07-06 16:47 flysnowxg 閱讀(2612) | 評論 (1)編輯 收藏

2013年11月28日

lisp是一種神奇的語言,scheme是lisp的一種方言。
tinyscheme是一個scheme語言的解釋器實(shí)現(xiàn),而這是我大幅修改并加了注釋后的tinyscheme(基于tinyscheme1.41)
代碼地址:http://flysnowxg.googlecode.com/svn/tinyscheme_note
原始代碼: http://tinyscheme.sourceforge.net/home.html
tinyscheme據(jù)說是實(shí)現(xiàn)的r5rs標(biāo)準(zhǔn)(應(yīng)當(dāng)是實(shí)現(xiàn)了一部分,因?yàn)槟J狡ヅ浜驼Z法定義的那部分顯然沒實(shí)現(xiàn))
tinyscheme代碼很簡短而且實(shí)現(xiàn)的語言功能還算比較完整,如果想研究一個lisp解釋器的實(shí)現(xiàn),tinyscheme是值得研究的
tinyscheme實(shí)現(xiàn)了lambda、宏、延續(xù)、異常、gc這些重要的語言機(jī)制,還實(shí)現(xiàn)了許多庫函數(shù),整個原版代碼大約有6500行左右,但是原版代碼有很多的宏定義和很多冗余的代碼,代碼分類也很混亂,可讀性不算特別好,在閱讀過程中我對這個代碼進(jìn)行了大量的修改,清除了大量冗余代碼,重新組織了代碼結(jié)構(gòu),主要的實(shí)現(xiàn)文件scheme.c被我從5000行改到只有3400行。所有代碼加起來也只有4500行了,功能損失也不太多
修改一些bug,比如像‘延續(xù)’的實(shí)現(xiàn),原版像下面這樣的代碼中, “(r 1)”這一句是沒法運(yùn)行的
(define r 0)
(let ((x 1))
 (set! x
  (+ x
   (call/cc (lambda (c) (set! r c) (+ 44 (c 1)))))
 )
 (display x))
(r 1)

有興趣的可以看一看!

posted @ 2013-11-28 17:55 flysnowxg 閱讀(2696) | 評論 (0)編輯 收藏

2013年9月2日

這是我用c++寫的一個簡單的腳本語言,非常簡短,不到3000行代碼


sil語言(simple interpretative lanuage)是一個簡單的腳本語言,只是一個玩具,目的是演示用簡短的代碼去創(chuàng)建一個可用的腳本語言
這樣一個玩具會是怎么樣的呢?
sil的設(shè)計目標(biāo):
1 . 非常容易將sil解釋器嵌入到c++代碼中
2 . 非常容易用c++代碼來擴(kuò)展sil的函數(shù)調(diào)用,使得c++和sil腳本非常容易交互
3 . 成為一個有簡潔語法的動態(tài)語言,有容易使用的語法
4 . 擁有一個語言一般都應(yīng)當(dāng)擁有的語法

sil語法的完整定義可參考《sil語法說明》。
sil語言是動態(tài)類型的,編譯時不會檢查函數(shù)的參數(shù)個數(shù),參數(shù)類型是否合適,甚至不會檢查函數(shù)定義是否存在,只有到了運(yùn)行時才會查找函數(shù),檢查參數(shù)個數(shù)是否匹配。
對于內(nèi)置函數(shù)還會檢查參數(shù)類型是否匹配,如果不匹配會試著進(jìn)行參數(shù)類型轉(zhuǎn)換
對于用戶定義函數(shù),不會進(jìn)行參數(shù)類型匹配的檢查
第一節(jié) 語法:
1. 類型:
 sil暫時支持整形,浮點(diǎn)型,字符串三種數(shù)據(jù)類型,暫時不支持?jǐn)?shù)組,也不支持自定義類型(這兩點(diǎn)是比較嚴(yán)重的缺點(diǎn))
 sil是弱類型的,變量不會和類型綁定
 變量定義像是這樣的:
 var vi=1; //定義一個值為整數(shù)1的變量vi
 var vf=1.0;//定義一個值為浮點(diǎn)數(shù)1.0的變量vf
 var vs="1.0";//定義一個值為字符串"1.0"的字符串vs
 
2. 函數(shù)
 sil是弱類型的,所以定義函數(shù)時不需要聲明形參的類型,支持return語句
 函數(shù)像這樣定義:
 function myfun(str)
 {
  print(str);
  return 0;
  print("after return\n");
 }
 函數(shù)像這樣調(diào)用:myfun("hello sil");
 
3. 分支
 sil支持if else 語句,
 像這樣:
 var i=read();
 if(i==1) print("a");
 else if(i==2)
 {
  print("b");
 }
 else print("c");
 
4. 循環(huán)
 sil支持while和for循環(huán),支持continue,break語句
 while像這樣:
 var i=1;
 while(true)
 {
  print("hello sil\n");
  i=i+1;
  if(i>5) break;
  if(i<3) continue;
  print("after continue\n");
 }
 for循環(huán)像這樣
 for(var i=0;i<5;i=i+1) print(i+"\n");

5. 基本運(yùn)算符
 比較運(yùn)算支持 == != > <
 算術(shù)運(yùn)算支持 + - * / % ,還支持一元 -
 邏輯運(yùn)算支持 !  && ||
 支持括號 ( ) 改變求值順序
 算符優(yōu)先級和c中一樣
 
5. 內(nèi)置函數(shù)
 sil類內(nèi)置函數(shù)是非常少的,詳見函數(shù)說明,以下列出兩個比較重要的。
 eval 可對一個字符串形式的sil代碼求值
 例如 eval("for(var i=0;i<5;i=i+1)print(i);");
 load 可以加載一個sil代碼文件,代碼文件中亦可遞歸調(diào)用load函數(shù)
 
6. c++嵌入和擴(kuò)展
 寥寥數(shù)行代碼即可將sil嵌入到c++中
 一個c函數(shù)只要形參和返回值類型是int float string,簡單調(diào)用一個register_function即可將函數(shù)注冊到sil中,腳本即可方便的調(diào)用這些擴(kuò)展函數(shù)
 extern工程中的代碼示例了如何對sil提供文件讀寫函數(shù)的支持
 
第二節(jié) 源代碼
 這是一個用vs2008創(chuàng)建的工程,由于使用了shared_ptr,如果給vs2005引入shared_ptr的支持亦可在vs2005下編譯通過
 src目錄下是sil語言用c++實(shí)現(xiàn)的內(nèi)核
 consle目錄下是sil語言的命令行解釋器
 extern目錄下是一個例子,演示了如何擴(kuò)展sil的內(nèi)置函數(shù)
 lib目錄下是用sil寫的庫代碼和一些測試代碼,但是現(xiàn)在只有簡單的測試代碼(里面有一個開平方根和求圓周率的有意思的例子)
 doc目錄下是文檔
 bin目錄下是可執(zhí)行文件
 
第三節(jié) 函數(shù)說明
 to_int 將一個值轉(zhuǎn)換為int類型,例如:to_int("123");
 to_float 將一個值轉(zhuǎn)換為float類型,例如:to_float(2);
 to_string 將一個值轉(zhuǎn)換為string類型,例如:to_string(254);
 strlen 求字符串的長度,例如:strlen("hello");
 substr 截取字符串的的一部分,例如:substr("hello",1,3);
 eval 可以求值一個字符串形式的表達(dá)式,例如:  var code="1+2*3";eval(code);
 load 可以加載并執(zhí)行一個sil代碼的文件,例如: load("../lib/math_test.sil");
 exit 終止腳本的執(zhí)行,例如:print("hello");exit();print("world");
 print 打印一個值,例如:print("hello world"+3);
 read 可以從控制臺讀取一個字符串,例如:var tmp=read();print(tmp);
 bat 可以執(zhí)行一個windows命令,例如:bat("dir");
 list_function 打印已經(jīng)定義的內(nèi)置函數(shù)和腳本函數(shù),例如:list_funciton();
 list_asm_code 打印編譯出的代碼,例如:list_asm_code();
 set_sil 可以設(shè)置解釋器的一些開關(guān),例如:set_sil("",0);
 help 顯示幫助信息,例如:help();

posted @ 2013-09-02 15:45 flysnowxg 閱讀(3377) | 評論 (9)編輯 收藏

2012年5月17日

什么時候動筆?

posted @ 2012-05-17 22:25 flysnowxg 閱讀(403) | 評論 (0)編輯 收藏

2012年4月29日

!

posted @ 2012-04-29 17:32 flysnowxg 閱讀(309) | 評論 (0)編輯 收藏

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            国产精品视频午夜| 国产在线欧美日韩| 这里只有精品视频| 欧美电影免费观看高清完整版| 久久久噜久噜久久综合| 久久久久久久久久看片| 久久深夜福利免费观看| 欧美+亚洲+精品+三区| 亚洲第一在线综合网站| 久久久www免费人成黑人精品| 久久精精品视频| 欧美电影免费观看高清| 亚洲开发第一视频在线播放| 宅男精品导航| 久久久国产一区二区| 欧美电影资源| 国产日韩欧美另类| 亚洲日本中文| 欧美一区二区三区四区在线| 欧美成人视屏| 亚洲午夜一区| 欧美成人精品1314www| 国产乱码精品一区二区三区五月婷| 国产亚洲毛片在线| 一本久道久久久| 久久这里有精品视频| 日韩一本二本av| 久久久噜噜噜久久人人看| 欧美色偷偷大香| 亚洲国产欧美日韩精品| 欧美亚洲免费电影| 亚洲精选视频在线| 久久这里只有精品视频首页| 国产精品久久久91| 日韩一级大片| 美女主播一区| 久久激情视频| 国产精品亚洲成人| 亚洲一区在线观看免费观看电影高清| 麻豆91精品91久久久的内涵| 亚洲视频一区二区| 欧美日韩国产999| 亚洲精品乱码久久久久| 久久不见久久见免费视频1| 亚洲乱码国产乱码精品精98午夜| 一本久道久久综合婷婷鲸鱼| 国产精品色午夜在线观看| 亚洲日本中文字幕区| 久久精精品视频| 夜夜嗨av色综合久久久综合网| 久久躁日日躁aaaaxxxx| 国产一区二区三区丝袜| 欧美一区二区三区免费看| 99亚洲视频| 欧美日韩在线综合| 亚洲新中文字幕| 亚洲九九九在线观看| 欧美国产精品| 在线亚洲观看| 99av国产精品欲麻豆| 欧美精品在线免费| 亚洲精一区二区三区| 亚洲激情另类| 欧美精品久久久久久久| 一本大道av伊人久久综合| 亚洲麻豆一区| 国产精品国内视频| 欧美一区二区三区精品| 欧美在线播放一区二区| 狠狠色狠狠色综合日日五| 欧美+日本+国产+在线a∨观看| 欧美亚洲日本网站| 国产精品一区二区黑丝| 亚洲欧美激情一区二区| 一区二区三区四区蜜桃| 国产精品成人一区二区艾草| 亚洲一区中文| 亚洲综合欧美| 激情婷婷亚洲| 欧美成人午夜激情| 欧美激情精品久久久久久免费印度| 亚洲日本精品国产第一区| 亚洲欧洲视频| 国产精品免费网站| 久久久人成影片一区二区三区观看| 久久久久久**毛片大全| 亚洲经典视频在线观看| 久久综合九九| 怡红院av一区二区三区| 久热国产精品| 欧美日韩国产在线播放| 亚洲一区图片| 久久久久国色av免费看影院| 亚洲欧洲另类| 亚洲欧美精品中文字幕在线| 在线成人免费观看| 日韩亚洲欧美中文三级| 国内成人精品2018免费看| 亚洲成人在线网站| 国产精品视频在线观看| 欧美二区在线看| 国产精品综合| 亚洲日本成人女熟在线观看| 国产伦精品一区二区三区照片91| 欧美成人国产| 国产欧美高清| 99综合视频| 亚洲国产欧美一区二区三区久久| 亚洲视频中文字幕| 日韩视频久久| 久久综合色婷婷| 久久精品国产一区二区电影| 欧美日韩高清在线| 欧美第一黄色网| 国内精品免费午夜毛片| 在线亚洲激情| 99国内精品久久| 麻豆精品91| 久久久久久亚洲精品中文字幕| 欧美日韩在线观看一区二区三区| 欧美成人午夜激情视频| 精品电影在线观看| 久久se精品一区精品二区| 亚洲专区国产精品| 欧美屁股在线| 亚洲欧洲在线视频| 亚洲欧洲偷拍精品| 玖玖玖免费嫩草在线影院一区| 欧美亚洲在线| 国产精品夜夜夜| 宅男在线国产精品| 亚洲免费综合| 国产精品久久久久av| 一二三区精品| 午夜精品美女自拍福到在线| 国产精品久久九九| 午夜精品国产精品大乳美女| 欧美一区二区三区视频免费播放| 国产精品成人午夜| 亚洲欧美日韩一区二区在线| 亚洲欧美日韩国产成人| 国产精品高清在线| 亚洲婷婷在线| 久久精品日韩一区二区三区| 国产精品天天摸av网| 亚洲欧美久久久| 久久久一区二区| 在线不卡中文字幕播放| 男人插女人欧美| 亚洲美女在线视频| 欧美一区网站| 激情欧美一区二区| 欧美成年人视频网站| 亚洲国产成人久久综合| 99精品国产热久久91蜜凸| 亚洲人精品午夜| 欧美日韩国产综合网| 日韩亚洲一区二区| 亚洲欧美成aⅴ人在线观看| 国产精品久久久久久久久久尿 | 鲁大师成人一区二区三区| 1024精品一区二区三区| 欧美不卡在线| 亚洲欧美激情一区二区| 欧美+亚洲+精品+三区| 亚洲色诱最新| 国内外成人免费激情在线视频网站 | 在线看国产日韩| 欧美日韩成人综合| 欧美一区午夜精品| 亚洲片区在线| 久久久999精品免费| 日韩一级黄色片| 好看的亚洲午夜视频在线| 欧美激情在线有限公司| 午夜老司机精品| 亚洲人成久久| 久久午夜精品| 亚洲欧美日韩精品久久久久| 在线播放日韩| 国产精品永久免费| 欧美激情精品久久久久久蜜臀| 午夜精品一区二区三区在线播放 | 99国产精品久久久久久久成人热| 欧美在线免费视屏| 亚洲精品乱码久久久久久蜜桃91| 国产精品成人在线| 美女日韩在线中文字幕| 亚洲欧美不卡| av不卡免费看| 亚洲第一综合天堂另类专| 欧美亚洲色图校园春色| 日韩一级在线观看| 亚洲国产婷婷香蕉久久久久久99| 国产精品亚洲不卡a| 欧美视频日韩视频| 欧美精品在线观看| 欧美精品国产| 欧美黄色aa电影| 麻豆精品一区二区av白丝在线|