• <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>

            S.l.e!ep.¢%

            像打了激速一樣,以四倍的速度運轉,開心的工作
            簡單、開放、平等的公司文化;尊重個性、自由與個人價值;
            posts - 1098, comments - 335, trackbacks - 0, articles - 1
              C++博客 :: 首頁 :: 新隨筆 :: 聯系 :: 聚合  :: 管理

            require函數詳解(轉)

            Posted on 2010-06-20 12:53 S.l.e!ep.¢% 閱讀(1538) 評論(0)  編輯 收藏 引用 所屬分類: Lua
            簡介
            require函數像dofile一樣載入文件為一個Chunk并執行。但具有兩個好處:1. 按模式加載文件 2.不會重復載入相同的文件

            require和package.path的關系


            典型的package.path值如下(其中D:\Bin為lua.exe所在目錄):
            .\?.lua;D:\Bin\lua\?.lua;D:\Bin\lua\?\init.lua;D:\Bin\?.lua;D:\Bin\?\init.lua
            通常對我們有用的目錄是.\?.lua

            例如require("test")將載入.\test.lua

            require和package.loaded的關系

            如果沒有載入任何Chunk,典型的package.loaded是類似如下的一張表
            string??? table: 00375D48
            package?? table: 00373C30
            _G??????? table: 00371FD8
            os??????? table: 00375628
            table???? table: 00373198
            math????? table: 003763C8
            coroutine table: 003738A8
            debug???? table: 00376FA0
            io??????? table: 00374DC8


            當我們require("main")成功后,該表會變回
            string??? table: 00375D58
            package?? table: 00373C38
            _G??????? table: 00371FC0
            os??????? table: 00375638
            table???? table: 003731A0
            math????? table: 003763D8
            coroutine table: 003738B0
            debug???? table: 00376FB0
            io??????? table: 00374DD8
            main????? true???????????? <== 新增表項
            package.loaded["main"] = true

            require函數的偽代碼
            # function require(virname) do
            # ?? if not package.loaded[virname] then
            #???? return
            #?? end
            #
            #?? local anyfileloaded = false
            #?? patternpath = (replace '?' in package.path to virname)
            #?? foreach path in patternpath split by ';' do <== virname如果含有'.', 那么'.'會被替換為'\\'
            # ??? if ((chunk = loadfile(path)) ~= nil) then
            # ????? chunk()
            # ????? package.loaded[virname] = true??????????<== 可以手工設置 package.loaded[virname] = false來重復載入該文件
            # ????? anyfileloaded = true
            # ????? break
            # ??? end
            #?? end
            #
            # if not anyfileloaded then
            # ??? print error message
            #?? end
            # end

            載入父目錄文件
            值得注意的是當前目錄下的子目錄可以用require("subdir\\subdirfile")的方式載入,而父目錄卻不可以用 require("..\\pardirfile")的方式載入。
            原因是subdir\subdirfile被替換為.\subdir\subdirfile.lua;...
            而..\pardirfile被替換為.\\\\pardirfile.lua;...

            我們可以通過如下方式載入父目錄文件
            package.path = package.path ..
            ";..\\?.lua"
            require(pardirfile)

            注意這里
            package.path = package.path .. ";..\\?.lua"和 package.path = "..\\?.lua;" .. package.path;有些區別;前者最后匹配 ";..\\?.lua",后者首先匹配 ";..\\?.lua"; 至于那種方式好那就看各位的愛好了
            久久国产欧美日韩精品| 久久99久久成人免费播放| 精品无码人妻久久久久久| 久久久久久午夜成人影院| 久久久久99这里有精品10| 久久99精品免费一区二区| 一本色道久久88加勒比—综合| 久久人爽人人爽人人片AV| 亚洲日韩中文无码久久| 精品久久久无码21p发布| 欧美精品乱码99久久蜜桃| 久久精品国产亚洲av瑜伽| 久久久久婷婷| 亚洲午夜福利精品久久| 久久人妻无码中文字幕| 国产激情久久久久久熟女老人| 国产精品久久久久久久app| 久久99热这里只频精品6| 人妻无码久久一区二区三区免费| 色妞色综合久久夜夜| 久久91精品国产91久久小草| 91精品无码久久久久久五月天| 久久国产综合精品五月天| 久久精品免费一区二区| 狠狠色婷婷久久一区二区三区| 91久久精品电影| 欧美日韩精品久久免费| 国内精品九九久久久精品| 激情五月综合综合久久69| 精品国产99久久久久久麻豆| AV无码久久久久不卡网站下载| 人人狠狠综合久久亚洲婷婷| 亚洲精品视频久久久| 久久国产精品99久久久久久老狼| 久久久久噜噜噜亚洲熟女综合| 亚洲女久久久噜噜噜熟女| 国产精品午夜久久| 欧美精品久久久久久久自慰| 久久99热这里只有精品国产| 久久综合久久自在自线精品自 | 亚洲AV无码久久精品成人|