在线观看不卡亚洲电影_亚洲妓女99综合网_91青青青亚洲娱乐在线观看_日韩无码高清综合久久

鍍金池/ 問答/ 人工智能問答
帥到炸 回答

說一個(gè)簡單的辦法:在公司內(nèi)部注冊一個(gè)域名,搭一個(gè) http 服務(wù),數(shù)據(jù)存在是 mysql 數(shù)據(jù)庫里。每個(gè)項(xiàng)目實(shí)例定期將統(tǒng)計(jì)信息匯報(bào)到這個(gè) http 服務(wù)。再寫一個(gè)查詢頁面,從 mysql 里查出數(shù)據(jù)并展示。

貓館 回答

損失函數(shù)的選取,取決于你的模型
舉個(gè)例子,例如最常用的binary_crossentropy

    import theano.tensor as T
    cost = T.sum(-(real*T.log(outputs) + (1-real)*T.log(1-outputs)))

其中real是預(yù)設(shè)輸出對(duì)應(yīng)你的(1,0,0,1,0),outputs是實(shí)際輸出對(duì)應(yīng)你的(1,0,0,0,0)的轉(zhuǎn)置

柒喵 回答

redis通過一致性hash算法保證寫入時(shí)的服務(wù)器和讀取時(shí)的服務(wù)器在一臺(tái)來解決分布式環(huán)境問題。你的問題太過模糊,現(xiàn)在已經(jīng)遇到集群性能瓶頸了?

  1. redis集群服務(wù)器配置?
  2. redis集群服務(wù)器有多少臺(tái)?
神曲 回答

啥文件占滿了系統(tǒng)盤?aof嗎?改用rdb吧,rdb占用磁盤大小不可能超過內(nèi)存大小的。

另外,查下Redis配置文件的寫法,配置中是可以設(shè)置存儲(chǔ)文件路徑的。

蝶戀花 回答

如果對(duì)數(shù)據(jù)實(shí)時(shí)性要求不高,就做個(gè)從oracle字典表同步到緩存的后臺(tái)作業(yè),每隔5秒或10秒運(yùn)行一次。

還有一個(gè)思路,就是在oracle在做個(gè)字典表的觸發(fā)器,如果有數(shù)據(jù)更新的話,在觸發(fā)器中調(diào)用java程序,同步到緩存中。
oracle中調(diào)用java的方法,可以參考我以前寫的文章

痞性 回答

redis是多線程的,你會(huì)問如何確認(rèn),其實(shí)很簡單,用gdb確認(rèn)即可,我服務(wù)器上的剛好有部署redis,它的進(jìn)程pid為26716。

[root@rookie_centos myXxl]# gdb -p 26716
[Thread debugging using libthread_db enabled]
Loaded symbols for /lib64/libpthread.so.0
Reading symbols from /lib64/libc.so.6...(no debugging symbols found)...done.
Loaded symbols for /lib64/libc.so.6
Reading symbols from /lib64/ld-linux-x86-64.so.2...(no debugging symbols found)...done.
Loaded symbols for /lib64/ld-linux-x86-64.so.2
0x00007f6e8faa81c3 in epoll_wait () from /lib64/libc.so.6
Missing separate debuginfos, use: debuginfo-install glibc-2.12-1.209.el6_9.2.x86_64
(gdb) bt
#0  0x00007f6e8faa81c3 in epoll_wait () from /lib64/libc.so.6
#1  0x000000000042491e in aeApiPoll (eventLoop=0x7f6e894340a0, flags=11) at ae_epoll.c:112
#2  aeProcessEvents (eventLoop=0x7f6e894340a0, flags=11) at ae.c:404
#3  0x0000000000424d3b in aeMain (eventLoop=0x7f6e894340a0) at ae.c:464
#4  0x000000000042d902 in main (argc=<value optimized out>, argv=0x7ffe660d3dd8) at server.c:3865
(gdb) info threads
  4 Thread 0x7f6e893ff700 (LWP 26718)  0x00007f6e8fd5e68c in pthread_cond_wait@@GLIBC_2.3.2 () from /lib64/libpthread.so.0
  3 Thread 0x7f6e889fe700 (LWP 26719)  0x00007f6e8fd5e68c in pthread_cond_wait@@GLIBC_2.3.2 () from /lib64/libpthread.so.0
  2 Thread 0x7f6e87ffd700 (LWP 26720)  0x00007f6e8fd5e68c in pthread_cond_wait@@GLIBC_2.3.2 () from /lib64/libpthread.so.0
* 1 Thread 0x7f6e9060c740 (LWP 26716)  0x00007f6e8faa81c3 in epoll_wait () from /lib64/libc.so.6
(gdb) 

正如上面一樓所說redis采用的是reactor的并發(fā)模型,也就是主線程使用io復(fù)用對(duì)多個(gè)客戶端進(jìn)行監(jiān)聽,有請求過來時(shí),喚醒工作線程來做讀io操作讀取客戶的請求數(shù)據(jù),工作線程處理完請求向主線程注冊寫請求,客戶端io可寫時(shí)主線程喚醒工作線程,工作線程再進(jìn)行寫io操作把應(yīng)答發(fā)送給客戶端。主線程通過條件變量來喚醒工作線程,從上面gdb的輸出可以看出工作線程都是調(diào)用pthread_cond_wait后被掛起,在等待主線程的喚醒,主線程則調(diào)用epoll_wait這個(gè)高效的io復(fù)用函數(shù)在等待客戶端的請求。

乖乖瀦 回答

鏈表替換 node->newnode->node.pnext.pnext 把node.pnext 替換為newnode

原來是 ...->node->node.pnext->node.pnext.pnext->... 以下前后省略
第一句話 newnode.pnext = node.pnext.pnext
變成 ...->node->node.pnext->node.pnext.pnext->...和 newnode.pnext->node.pnext.pnext->...
第二句話 node.pnext = newnode
變成 ...->node->newnode->node.pnext.pnext->... 和 node.pnext->node.pnext.pnext->...
所以self.head是前面的鏈表,后面的鏈表被斷開了,完成了替換的目的

空痕 回答

想明白了,我們在建預(yù)測模型的時(shí)候,其實(shí)應(yīng)該全盤考慮各種feature(特征)以及feature crosses(特征組合/特征叉積),并給予系數(shù)wi。至于wi是否會(huì)被學(xué)習(xí)為0,要看后面的數(shù)據(jù)處理,不應(yīng)當(dāng)再建模的時(shí)候想當(dāng)然的就不考慮進(jìn)來(即想當(dāng)然wi=0)。這也是為什么,機(jī)器學(xué)習(xí)引入L1正則、L2正則來使一些系數(shù)降為0,來消除模型的復(fù)雜度,以避免overfitting。

哎呦喂 回答

在AOF持久化的過程中,其實(shí)上是分成兩個(gè)部分:
WRITE:根據(jù)條件,將 aof_buf 中的緩存寫入到 AOF 文件。
SAVE:根據(jù)條件,調(diào)用 fsync 或 fdatasync 函數(shù),將 AOF 文件保存到磁盤中。
具體可以參見:http://redisbook.readthedocs....

但具體為何要分成兩個(gè)部分,原因相當(dāng)于“把緩存數(shù)據(jù)寫入aof不就已經(jīng)實(shí)現(xiàn)了同步了嗎”,具體如下:
對(duì)于write函數(shù)而言,其只會(huì)更新內(nèi)存頁緩存,而臟頁的更新取決于os的統(tǒng)一調(diào)度;由于write函數(shù)并不會(huì)一直阻塞直到IO完成才返回,因此期間若時(shí)發(fā)生故障就會(huì)造成數(shù)據(jù)丟失問題(盡管時(shí)間窗很小);對(duì)事務(wù)及數(shù)據(jù)一致性要求高的服務(wù)來說(比如備份服務(wù)),需要通過同步IO原語來提供os級(jí)別的保證,比如AOF中使用的fsync,其目的就是保證文件所有已修改的內(nèi)容內(nèi)容已經(jīng)爭取同步到磁盤(因?yàn)槠鋾?huì)阻塞直到IO完成);簡單來說write不是同步的,fsync是同步且有明確結(jié)果的

順便多說一句,對(duì)于已被打開的文件執(zhí)行寫操作來說,應(yīng)先調(diào)用fflush函數(shù)將修改同步到內(nèi)核緩沖區(qū),然后再調(diào)用fsync函數(shù)執(zhí)行同步調(diào)用,這樣的同步實(shí)現(xiàn)最安全,這也是AOF的源碼實(shí)現(xiàn)方式

情已空 回答

這就是個(gè)背包問題,用動(dòng)態(tài)規(guī)劃來解決,嵌套兩個(gè)循環(huán),一個(gè)狀態(tài)轉(zhuǎn)移方程就能出結(jié)果,具體你可以看看這篇文章01背包問題,貼一下他的代碼:

#include<iostream>
#include<algorithm>
using namespace std;

int main()
{
    const int N = 6;                     //物品個(gè)數(shù)
    const int V = 10;                    //背包體積
    int C[N + 1] = { -1,5,6,5,1,19,7 };  //第i個(gè)物品的體積(下標(biāo)從1開始)
    int W[N + 1] = { -1,2,3,1,4,6,5 };   //第i個(gè)物品的價(jià)值
    int F[N + 1][V + 1] = { 0 };         //狀態(tài)

    for (int i = 1; i <= N; i++)  //對(duì)于第i個(gè)物品
        for (int v = 0; v <= V; v++)
        {
            F[i][v] = F[i - 1][v];  //第i個(gè)不放
            if (v - C[i] >= 0 && F[i][v] < F[i - 1][v - C[i]] + W[i])  //如果比它大,再放第i個(gè)
                F[i][v] = F[i - 1][v - C[i]] + W[i];
        }

    cout << "最大價(jià)值是:" << F[N][V] << endl;  //9

    return 0;
}

希望能幫助到你。

夢囈 回答

你這個(gè)問題我還是第一次遇到,你是如何設(shè)置成 nil 的?

可以嘗試一下: srem follow43007 ""

如果還不行,就全部讀出來,重寫這個(gè)key吧。

傲嬌范 回答

你這已經(jīng)是線性時(shí)間復(fù)雜度了,再低的話除非是對(duì)數(shù)時(shí)間

赱丅呿 回答

Redis把整個(gè)數(shù)據(jù)庫統(tǒng)統(tǒng)加載在內(nèi)存當(dāng)中進(jìn)行操作,每秒可以處理超過 10萬次讀寫操作.
redis的自身讀寫速度遠(yuǎn)大于程序并發(fā)請求.
快的原因是:多進(jìn)程比單進(jìn)程請求量更大

情皺 回答

根據(jù)你的需求,疑問一個(gè)問題,
無線大的數(shù)組為什么不直接用數(shù)據(jù)庫解決

大濕胸 回答

redis版本>=2.4可以填多個(gè)參數(shù),你應(yīng)該是版本比2.4小所以才不行
https://redis.io/commands/lpush/

生性 回答

可以考慮在相應(yīng)的組件里import這個(gè)js,不過Typescript默認(rèn)是不允許導(dǎo)入js的,要在tsconfig里配置allowjs

冷咖啡 回答

一行一行解釋源碼,估計(jì)也不太好理解;我們從另外一個(gè)角度來看這個(gè)問題。

返回的是動(dòng)態(tài)函數(shù)

首先看 bonusCombination 函數(shù)的返回語句是:return (new Function(str)).apply(null, [arr, fun])。這條語句的分解如下::

  • new Function(str) :含義是利用 str 字符串動(dòng)態(tài)構(gòu)造出函數(shù),我們暫且稱這個(gè)構(gòu)造出來的函數(shù)名為 strFn (即 var strFn = new Function(str)
  • 這樣就有 strFn.apply(null, [arr, fun]),轉(zhuǎn)換成我們平時(shí)可以理解的形式就是 strFn(arr, fun)

從這里我們可以看出,這個(gè) bonusCombination 的目的是動(dòng)態(tài)構(gòu)建一個(gè)函數(shù) strFn,該函數(shù)接受兩個(gè)入?yún)?arrfun —— 而這兩個(gè)入?yún)⒕褪俏覀儌鹘o bonusCombination 的入?yún)ⅲ?/p>

對(duì)應(yīng)你給的例子,這里的 arr 就是 [1,2,3,4],而 funnull

入?yún)?num 的作用,動(dòng)態(tài)創(chuàng)建函數(shù)體

我們知道 bonusCombination 還有一個(gè)入?yún)?,就?num,它的作用就是 鍛造 上述動(dòng)態(tài)函數(shù) strFn 的具體內(nèi)容,利用這個(gè) num 入?yún)碛绊懩且淮蠖巫址僮鳎@樣也就影響了動(dòng)態(tài)函數(shù)的具體內(nèi)容:

函數(shù)體內(nèi)容

對(duì)于閱讀這樣的函數(shù),要理解它的含義,最好的辦法就是枚舉。

比如我們讓 num2:那么動(dòng)態(tài)構(gòu)建的函數(shù) strFn 結(jié)構(gòu)體如下:

var strFn2 = function(arr, fun){
  var arr=arguments[0]; 
  var fun=arguments[1];  
  var ret=[]; 
  for (var a = 0; a < arr.length; a++) {
    for(var b = a + 1; b < arr.length; b++){
        var temp = [];
          temp.push(arr[a]); 
          temp.push(arr[b]); 
          if(fun){
            ret.push(fun(temp));
        } else {
            ret.push(temp); 
        }
    } 
  };
  return ret;
}

可見函數(shù)體內(nèi)包含 2 次循環(huán)(因?yàn)?num 值為 2),返回的 ret 就是結(jié)果值;

也就說調(diào)用 bonusCombination([1,2,3,4],2) 就相當(dāng)于調(diào)用 strFn2([1,2,3,4]),返回值就是你題中的 [[1,2],[1,3],[1,4],[2,3],[2,4],[3,4]] 。

同樣如果我們讓 num3:那么動(dòng)態(tài)構(gòu)建的函數(shù) strFn 結(jié)構(gòu)體如下:

var strFn3 = function(arr, fun){
  var arr=arguments[0]; 
  var fun=arguments[1];  
  var ret=[]; 
  for (var a = 0; a < arr.length; a++) {
    for(var b = a + 1; b < arr.length; b++){
      for(var c = b + 1; c < arr.length; c++) {
        var temp = [];
          temp.push(arr[a]); 
          temp.push(arr[b]); 
          temp.push(arr[c]);
          if(fun){
            ret.push(fun(temp));
        } else {
            ret.push(temp); 
        }
      }
    } 
  };
  return ret;
}

函數(shù)體內(nèi)包含 3 次循環(huán)(因?yàn)?num 值為 3);此時(shí)調(diào)用 bonusCombination([1,2,3,4],3) 就相當(dāng)于調(diào)用 strFn3([1,2,3,4]),返回值是 [[1,2,3],[1,2,4],[1,3,4],[2,3,4]];

你也可以自己試一下讓 num4 或者 1,寫出的函數(shù)體內(nèi)容是怎么樣的,你就能徹底明白這個(gè) bonusCombination 函數(shù)的作用了。

回答你的問題

問題1:看不懂為什么用字符串做變量,這個(gè)方法還有其他的功能嗎?
回答:字符串做變量就是為了動(dòng)態(tài)構(gòu)造函數(shù)體內(nèi)容,依據(jù) num 的不同值動(dòng)態(tài)生成不同的 strFn 函數(shù) —— 從這個(gè)角度上來講 bonusCombination 就是一個(gè) 工廠函數(shù);

該方法還有另外的功能,體現(xiàn)在入?yún)?fun 上,可以對(duì)每個(gè)結(jié)果元素調(diào)用 fun(temp),相當(dāng)于使用數(shù)組的 map 功能。

問題2:一開始為什么定義一個(gè) variable;
回答:主要是為動(dòng)態(tài)函數(shù)體提供足夠多的中間變量,沒啥具體含義,只要是符合 js 變量名稱就可以。這里使用 a、b... 這些變量名,估計(jì)是為了簡單起見,你可以用任何符合 js 變量名稱規(guī)范的字符串就行。

問題3:請一步一步來解釋
回答:讀懂上面兩小節(jié)的分析或者參考前一個(gè)回答,每一行解釋這里就不附上了。

其他

這種利用 Function 動(dòng)態(tài)函數(shù)構(gòu)造出來的功能函數(shù),性能堪憂;
你也知道,如果 arr 入?yún)?shù)組越長,num 越大,那么嵌套的循環(huán)體也就越多,性能就越差

這樣的代碼雖然能運(yùn)行,但質(zhì)量比較糟糕,還有很大的性能隱患,不能放在線上正式的產(chǎn)品中使用。這段代碼比較適合用來學(xué)習(xí) Function 的功能,以及 組合數(shù)學(xué) 的相關(guān)知識(shí)。

這種方式的編程屬于 元編程 范疇,可以參考我最近寫的文章 《【資源集合】 ES6 元編程(Proxy & Reflect & Symbol)》了解更多。后續(xù)有機(jī)會(huì),我看能否使用 Proxy & Reflect 來重寫這個(gè) bonusCombination 函數(shù)。

壞脾滊 回答

你可以給你遍歷這個(gè)列表的數(shù)組中每個(gè)對(duì)象添加一個(gè)屬性來綁定class。或者就像上面那樣,定義一個(gè)等長度的布爾值集合..