鍍金池/ 問(wèn)答/ C++問(wèn)答
青瓷 回答

找到原因了,還需要重寫GetContextMenuHandler接口。

virtual CefRefPtr<CefContextMenuHandler> SimpleHandler::GetContextMenuHandler() 
        OVERRIDE {
    return this;
}
歆久 回答

在資源文件夾下建三個(gè)文件夾, 分別對(duì)應(yīng)放置各自的application.properties文件

src/main/resources/dev/application.properties
src/main/resources/test/application.properties
src/main/resources/pro/application.properties

在pom.xml里先定義三個(gè)profile

    <profiles>
        <profile>
            <!-- 本地開發(fā)環(huán)境 -->
            <id>dev</id>
            <properties>
                <profiles.active>dev</profiles.active>
                <modifier></modifier>
            </properties>
            <activation>
                <activeByDefault>true</activeByDefault>       <!-- 默認(rèn)的,不加參數(shù)時(shí)執(zhí)行這個(gè)profile -->         
            </activation>
        </profile>
        <profile>
            <!-- 測(cè)試環(huán)境 -->
            <id>test</id>
            <properties>
                <profiles.active>test</profiles.active>
                <modifier>-test</modifier>        
            </properties>
        </profile>
        <profile>
            <!-- 生產(chǎn)環(huán)境 -->
            <id>pro</id>
            <properties>
                <profiles.active>pro</profiles.active>                
                <modifier>-pro</modifier>                
            </properties>
        </profile>
    </profiles>

在build的標(biāo)簽下, 先排除全部,再添加當(dāng)前通過(guò)-P參數(shù)激活的profile:

    <build>
        <resources>
            <resource>
                <directory>src/main/resources</directory>
                <!-- 資源根目錄排除各環(huán)境的配置,防止在生成目錄中多余其它目錄 -->
                <excludes>
                    <exclude>test/*</exclude>
                    <exclude>pro/*</exclude>
                    <exclude>dev/*</exclude>
                </excludes>
            </resource>
            <resource>
                <directory>src/main/resources/${profiles.active}</directory>
            </resource>
        </resources>

最后,編譯時(shí)加-P參數(shù)即可, 如:

mvn -Ppro package
怪痞 回答

就是調(diào)用MapCell的operator()獲取到一個(gè)MapGrid然后進(jìn)行拷貝初始化。

解夏 回答
  1. cpu在做密集的計(jì)算才會(huì)導(dǎo)致100%,最常見的例子就執(zhí)行的循環(huán)次數(shù)過(guò)多,要不就是那種死循環(huán)。
  2. 回到你的代碼上來(lái),你這個(gè)函數(shù)沒(méi)有邏輯問(wèn)題,但是存在性能問(wèn)題,你的外層map元素個(gè)數(shù)到達(dá)10萬(wàn)乃至百萬(wàn)時(shí),循環(huán)需要執(zhí)行很多次才能退出。
  3. 優(yōu)化的方式:要嘛增加修改查詢條件,加一個(gè)userid,查詢只需要做兩次map的find操作;要嘛修改存數(shù)據(jù)結(jié)構(gòu)提高查詢效率。
維他命 回答

1.剛買的這臺(tái)機(jī)器磁盤還用分區(qū)嗎?
不需要,直接使用即可

2.如果要分區(qū),大概要怎么來(lái)分區(qū)呢?
忽略

3.如果不用分區(qū),對(duì)以后磁盤擴(kuò)容會(huì)有什么影響嗎?
一般服務(wù)器無(wú)非就是一些日志,一般40G也夠用了,如果你服務(wù)器需要存儲(chǔ)大量文件,建議你使用OSS文件存儲(chǔ);
當(dāng)然阿里云的服務(wù)器你也是可以之后購(gòu)買磁盤進(jìn)行擴(kuò)容,沒(méi)有任何壓力。

赱丅呿 回答

看起來(lái)是個(gè)小問(wèn)題,組件文件里從 @angular/formsFormControlimport 進(jìn)來(lái)就好了。

青黛色 回答

書上也許有錯(cuò)誤的地方。你理解也有不準(zhǔn)確的地方。其實(shí)你都可以自己實(shí)驗(yàn)得到。

tell單獨(dú)用,指的是整個(gè)數(shù)組。但放入一些表達(dá)式中時(shí),會(huì)被隱式轉(zhuǎn)換為第一個(gè)元素的指針。

cout << sizeof(tell) << endl; // 輸出20,即整個(gè)數(shù)組的大小
cout << sizeof(tell + 1) << endl; // 輸出4或8,即一個(gè)指針的大小(32位或64位的指針大小不同)
cout << tell << endl; // 輸出一個(gè)地址
cout << tell + 1 << endl; // 比上一個(gè)地址大2,即1個(gè)short的大小

&tell沒(méi)有懸念,指的是指向整個(gè)數(shù)組的指針。

cout << &tell << endl; // 輸出一個(gè)地址
cout << &tell + 2 << endl; // 比上一個(gè)地址大40

至于short (*)[20],沒(méi)見過(guò)這樣的寫法。

淡墨 回答

你要看這個(gè)時(shí)候子組件是否加載完成

離魂曲 回答
  1. 復(fù)制代碼
  2. 新建文本文檔
  3. 擴(kuò)展名改為.bat或.cmd
  4. 粘帖代碼
  5. 保存
  6. 雙擊運(yùn)行
  7. 或cmd輸入路徑運(yùn)行
初心 回答

此tree非彼tree

每一次遞歸的時(shí)候 這個(gè)tree的指向是不同的

薄荷糖 回答

不同段位各組成一個(gè)隊(duì)列,每次進(jìn)來(lái)取出兩個(gè)人,滿足條件就對(duì)戰(zhàn);隊(duì)列為空,從相鄰隊(duì)列里面去??;系統(tǒng)定時(shí)清理沒(méi)有匹配到的

維她命 回答

析構(gòu)函數(shù)忘定義了

落殤 回答

如果你用&,掩碼mask就必須滿足 $$ 2^n - 1 $$

環(huán)形緩沖區(qū)實(shí)際上用的是取余操作來(lái)保證不爆炸的。如果你用正常的取余%,那么對(duì)mask沒(méi)有要求。如果用按位與&的話,只有mask滿足上述條件時(shí),所有二進(jìn)制位都為1,才能與取余等價(jià)。

別傷我 回答
//testgo.h
#ifdef __cplusplus
extern "C"{
#endif
extern long getaddr();
extern int calladdr(long addr);
#ifdef __cplusplus
}
#endif
//testgo.cpp
#include <stdio.h>
#include "testgo.h"

typedef int(*pfun)();

int testfunc(){
    return 123654;
}

long getaddr() {
    return (long)testfunc;
}

int calladdr(long addr){
    return ((pfun)addr)();
}
//test.go
package main

// #include "testgo.h"
// #cgo LDFLAGS: ${SRCDIR}/testgo.so -lstdc++
import "C"
import "fmt"

func main() {
    addr := C.getaddr()
    fmt.Println("addr is", addr)
    fmt.Println("call ret:", C.calladdr(addr))
}

g++ -shared -fPIC testgo.cpp -o testgo.so
go run test.go

通過(guò)getaddr取得testfunc的函數(shù)地址,再通過(guò)calladdr調(diào)用地址對(duì)應(yīng)的函數(shù),你看看是不是你想要的

夏夕 回答

感謝 @felix 指教,為了清晰起見,我自答一下:

  1. 這個(gè)行為是 C++ 標(biāo)準(zhǔn)的,還是 g++ 特有的?

    這種行為是 C++ 標(biāo)準(zhǔn)的。參考:

    http://zh.cppreference.com/w/...

    之中【內(nèi)建的成員訪問(wèn)運(yùn)算符】,第四種用法:

    expr -> pseudo-destructor

    expr 是一個(gè)標(biāo)量類型,pseudo-destructor 為一個(gè) ~ 之后跟著代表與 expr 相同類型的類型名,所構(gòu)成的函數(shù)調(diào)用表達(dá)式被稱為偽析構(gòu)函數(shù)調(diào)用。它不接受任何參數(shù),返回 void,且除了對(duì)開頭的 expr 求值之外不實(shí)施任何操作。允許進(jìn)行偽析構(gòu)函數(shù)調(diào)用,使得編寫代碼而無(wú)需了解某個(gè)給定類型是否存在析構(gòu)函數(shù)成為可能。

    上面敘述中的類型名(type name)對(duì)當(dāng)前語(yǔ)法來(lái)說(shuō),可以指 typedef 或者 using(type alias)聲明的名字,而不指類型本身。舉例說(shuō)明:

    int main() {
        typedef int Int;
        int* p = new int(10);
        p->~Int(); // ok, do nothing
        // p->~int(); error: expected identifier before ‘int’
        return 0;
    }
  2. 應(yīng)該怎樣闡述 data_->~T() 的行為?

    當(dāng) T 是標(biāo)量類型(可有 cv 限定的算術(shù)、指針、指向成員指針、枚舉或 std::nullptr_t 類型)時(shí),它表示偽析構(gòu)函數(shù)調(diào)用,即除了對(duì) data_ 取值不做任何事。

    當(dāng) T 不是標(biāo)量類型時(shí),它顯式調(diào)用了 data_ 的析構(gòu)函數(shù)。

這種行為讓 data_->~T() 的調(diào)用變得很理想。

情未了 回答

使用char *p,會(huì)導(dǎo)致一個(gè)問(wèn)題,看getp,*p的類型是char,而malloc返回值的類型是void*,類型不一致;若改成char **p??梢詮念愋偷慕嵌认胂?。

使勁操 回答

不可以。請(qǐng)使用:

test(p.get());
爆扎 回答

對(duì)于倉(cāng)庫(kù)中沒(méi)有的文件,git commit file 不能提交