當前位置: 首頁>>代碼示例>>Java>>正文


Java BytesUtil.readLong方法代碼示例

本文整理匯總了Java中org.apache.kylin.common.util.BytesUtil.readLong方法的典型用法代碼示例。如果您正苦於以下問題:Java BytesUtil.readLong方法的具體用法?Java BytesUtil.readLong怎麽用?Java BytesUtil.readLong使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在org.apache.kylin.common.util.BytesUtil的用法示例。


在下文中一共展示了BytesUtil.readLong方法的11個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Java代碼示例。

示例1: decode

import org.apache.kylin.common.util.BytesUtil; //導入方法依賴的package包/類
@Override
public String decode(byte[] bytes, int offset, int len) {
    if (isNull(bytes, offset, len)) {
        return null;
    }

    long integer = BytesUtil.readLong(bytes, offset, len) - CAP[fixedLen];

    //only take useful bytes
    integer = integer & MASK[fixedLen];
    boolean positive = (integer & ((0x80L) << ((fixedLen - 1) << 3))) == 0;
    if (!positive) {
        integer |= (~MASK[fixedLen]);
    }

    return String.valueOf(integer);
}
 
開發者ID:apache,項目名稱:kylin,代碼行數:18,代碼來源:IntegerDimEnc.java

示例2: getFirstValue

import org.apache.kylin.common.util.BytesUtil; //導入方法依賴的package包/類
public byte[] getFirstValue() {
    int nodeOffset = headSize;
    ByteArrayOutputStream bytes = new ByteArrayOutputStream();
    while (true) {
        int valueLen = BytesUtil.readUnsigned(trieBytes, nodeOffset + firstByteOffset - 1, 1);
        bytes.write(trieBytes, nodeOffset + firstByteOffset, valueLen);
        if (checkFlag(nodeOffset, BIT_IS_END_OF_VALUE)) {
            break;
        }
        nodeOffset = headSize + (int) (BytesUtil.readLong(trieBytes, nodeOffset, sizeChildOffset) & childOffsetMask);
        if (nodeOffset == headSize) {
            break;
        }
    }
    return bytes.toByteArray();
}
 
開發者ID:apache,項目名稱:kylin,代碼行數:17,代碼來源:AppendDictSlice.java

示例3: decode

import org.apache.kylin.common.util.BytesUtil; //導入方法依賴的package包/類
@Override
public String decode(byte[] bytes, int offset, int len) {
    if (isNull(bytes, offset, len)) {
        return null;
    }

    int x = (int) BytesUtil.readLong(bytes, offset, len);
    if (x >= ALLOWED_VALUES.length) {
        throw new IllegalStateException();
    }

    return ALLOWED_VALUES[x];
}
 
開發者ID:apache,項目名稱:kylin,代碼行數:14,代碼來源:BooleanDimEnc.java

示例4: decode

import org.apache.kylin.common.util.BytesUtil; //導入方法依賴的package包/類
@Override
public String decode(byte[] bytes, int offset, int len) {
    if (isNull(bytes, offset, len)) {
        return null;
    }

    long code = BytesUtil.readLong(bytes, offset, fixedLen);
    if (code < 0)
        throw new IllegalArgumentException();

    return codec.codeToValue(code);
}
 
開發者ID:apache,項目名稱:kylin,代碼行數:13,代碼來源:AbstractDateDimEnc.java

示例5: decode

import org.apache.kylin.common.util.BytesUtil; //導入方法依賴的package包/類
@Override
public String decode(byte[] bytes, int offset, int len) {
    if (isNull(bytes, offset, len)) {
        return null;
    }

    long integer = BytesUtil.readLong(bytes, offset, len);
    return String.valueOf(integer);
}
 
開發者ID:apache,項目名稱:kylin,代碼行數:10,代碼來源:IntDimEnc.java

示例6: lookupSeqNoFromValue

import org.apache.kylin.common.util.BytesUtil; //導入方法依賴的package包/類
/**
 * returns a code point from [0, nValues), preserving order of value
 *
 * @param n            -- the offset of current node
 * @param inp          -- input value bytes to lookup
 * @param o            -- offset in the input value bytes matched so far
 * @param inpEnd       -- end of input
 * @param roundingFlag -- =0: return -1 if not found
 *                     -- <0: return closest smaller if not found, return -1
 *                     -- >0: return closest bigger if not found, return nValues
 */
private int lookupSeqNoFromValue(int n, byte[] inp, int o, int inpEnd, int roundingFlag) {
    while (true) {
        // match the current node
        int p = n + firstByteOffset; // start of node's value
        int end = p + BytesUtil.readUnsigned(trieBytes, p - 1, 1); // end of node's value
        for (; p < end && o < inpEnd; p++, o++) { // note matching start from [0]
            if (trieBytes[p] != inp[o]) {
                return -1; // mismatch
            }
        }

        // node completely matched, is input all consumed?
        boolean isEndOfValue = checkFlag(n, BIT_IS_END_OF_VALUE);
        if (o == inpEnd) {
            return p == end && isEndOfValue ? BytesUtil.readUnsigned(trieBytes, end, sizeOfId) : -1;
        }

        // find a child to continue
        int c = headSize + (int) (BytesUtil.readLong(trieBytes, n, sizeChildOffset) & childOffsetMask);
        if (c == headSize) // has no children
            return -1;
        byte inpByte = inp[o];
        int comp;
        while (true) {
            p = c + firstByteOffset;
            comp = BytesUtil.compareByteUnsigned(trieBytes[p], inpByte);
            if (comp == 0) { // continue in the matching child, reset n and loop again
                n = c;
                break;
            } else if (comp < 0) { // try next child
                if (checkFlag(c, BIT_IS_LAST_CHILD))
                    return -1;
                c = p + BytesUtil.readUnsigned(trieBytes, p - 1, 1) + (checkFlag(c, BIT_IS_END_OF_VALUE) ? sizeOfId : 0);
            } else { // children are ordered by their first value byte
                return -1;
            }
        }
    }
}
 
開發者ID:apache,項目名稱:kylin,代碼行數:51,代碼來源:AppendDictSlice.java

示例7: rebuildTrieTreeR

import org.apache.kylin.common.util.BytesUtil; //導入方法依賴的package包/類
private AppendDictNode rebuildTrieTreeR(int n, AppendDictNode parent) {
    AppendDictNode root = null;
    while (true) {
        int p = n + firstByteOffset;
        int childOffset = (int) (BytesUtil.readLong(trieBytes, n, sizeChildOffset) & childOffsetMask);
        int parLen = BytesUtil.readUnsigned(trieBytes, p - 1, 1);
        boolean isEndOfValue = checkFlag(n, BIT_IS_END_OF_VALUE);

        byte[] value = new byte[parLen];
        System.arraycopy(trieBytes, p, value, 0, parLen);

        AppendDictNode node = new AppendDictNode(value, isEndOfValue);
        if (isEndOfValue) {
            int id = BytesUtil.readUnsigned(trieBytes, p + parLen, sizeOfId);
            node.id = id;
        }

        if (parent == null) {
            root = node;
        } else {
            parent.addChild(node);
        }

        if (childOffset != 0) {
            rebuildTrieTreeR(childOffset + headSize, node);
        }

        if (checkFlag(n, BIT_IS_LAST_CHILD)) {
            break;
        } else {
            n += firstByteOffset + parLen + (isEndOfValue ? sizeOfId : 0);
        }
    }
    return root;
}
 
開發者ID:apache,項目名稱:kylin,代碼行數:36,代碼來源:AppendDictSlice.java

示例8: deserialize

import org.apache.kylin.common.util.BytesUtil; //導入方法依賴的package包/類
@Override
public Long deserialize(ByteBuffer in) {
    return BytesUtil.readLong(in);
}
 
開發者ID:apache,項目名稱:kylin,代碼行數:5,代碼來源:Long8Serializer.java

示例9: deserialize

import org.apache.kylin.common.util.BytesUtil; //導入方法依賴的package包/類
@Override
public Object deserialize(ByteBuffer buf) {
    return BytesUtil.readLong(buf);
}
 
開發者ID:apache,項目名稱:kylin,代碼行數:5,代碼來源:FilterCodeSystemFactory.java

示例10: encode

import org.apache.kylin.common.util.BytesUtil; //導入方法依賴的package包/類
private long encode(String value) {
    enc.encode(value, buf, 0);
    return BytesUtil.readLong(buf, 0, buf.length);
}
 
開發者ID:apache,項目名稱:kylin,代碼行數:5,代碼來源:TimeDimEncTest.java

示例11: doCheck

import org.apache.kylin.common.util.BytesUtil; //導入方法依賴的package包/類
public boolean doCheck() {
    int offset = headSize;
    HashSet<Integer> parentSet = new HashSet<>();
    boolean lastChild = false;

    while (offset < trieBytes.length) {
        if (lastChild) {
            boolean contained = parentSet.remove(offset - headSize);
            // Can't find parent, the data is corrupted
            if (!contained) {
                return false;
            }
            lastChild = false;
        }
        int p = offset + firstByteOffset;
        int childOffset = (int) (BytesUtil.readLong(trieBytes, offset, sizeChildOffset) & childOffsetMask);
        int parLen = BytesUtil.readUnsigned(trieBytes, p - 1, 1);
        boolean isEndOfValue = checkFlag(offset, BIT_IS_END_OF_VALUE);

        // Copy value overflow, the data is corrupted
        if (trieBytes.length < p + parLen) {
            return false;
        }

        // Check id is fine
        if (isEndOfValue) {
            BytesUtil.readUnsigned(trieBytes, p + parLen, sizeOfId);
        }

        // Record it if has children
        if (childOffset != 0) {
            parentSet.add(childOffset);
        }

        // brothers done, move to next parent
        if (checkFlag(offset, BIT_IS_LAST_CHILD)) {
            lastChild = true;
        }

        // move to next node
        offset += firstByteOffset + parLen + (isEndOfValue ? sizeOfId : 0);
    }

    // ParentMap is empty, meaning all nodes has parent, the data is correct
    return parentSet.isEmpty();
}
 
開發者ID:apache,項目名稱:kylin,代碼行數:47,代碼來源:AppendDictSlice.java


注:本文中的org.apache.kylin.common.util.BytesUtil.readLong方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。