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


Java PdxInstance類代碼示例

本文整理匯總了Java中org.apache.geode.pdx.PdxInstance的典型用法代碼示例。如果您正苦於以下問題:Java PdxInstance類的具體用法?Java PdxInstance怎麽用?Java PdxInstance使用的例子?那麽, 這裏精選的類代碼示例或許可以為您提供幫助。


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

示例1: pdxToJson

import org.apache.geode.pdx.PdxInstance; //導入依賴的package包/類
private static String pdxToJson(PdxInstance obj) {
  if (obj != null) {
    try {
      GfJsonObject json = new GfJsonObject();
      for (String field : obj.getFieldNames()) {
        Object fieldValue = obj.getField(field);
        if (fieldValue != null) {
          if (JsonUtil.isPrimitiveOrWrapper(fieldValue.getClass())) {
            json.put(field, fieldValue);
          } else {
            json.put(field, fieldValue.getClass());
          }
        }
      }
      return json.toString();
    } catch (GfJsonException e) {
      return null;
    }
  }
  return null;
}
 
開發者ID:ampool,項目名稱:monarch,代碼行數:22,代碼來源:DataCommandFunction.java

示例2: readPdxEnum

import org.apache.geode.pdx.PdxInstance; //導入依賴的package包/類
/**
 * @throws IOException since 6.6.2
 */
private static Object readPdxEnum(DataInput in) throws IOException {
  int dsId = in.readByte();
  int tmp = readArrayLength(in);
  int enumId = (dsId << 24) | (tmp & 0xFFFFFF);
  if (logger.isTraceEnabled(LogMarker.SERIALIZER)) {
    logger.trace(LogMarker.SERIALIZER, "read PdxEnum id={}", enumId);
  }
  GemFireCacheImpl gfc = GemFireCacheImpl
      .getForPdx("PDX registry is unavailable because the Cache has been closed.");
  TypeRegistry tr = gfc.getPdxRegistry();

  Object result = tr.getEnumById(enumId);
  if (result instanceof PdxInstance) {
    getDMStats(gfc).incPdxInstanceCreations();
  }
  return result;
}
 
開發者ID:ampool,項目名稱:monarch,代碼行數:21,代碼來源:InternalDataSerializer.java

示例3: checkEquals

import org.apache.geode.pdx.PdxInstance; //導入依賴的package包/類
static boolean checkEquals(@Unretained Object v1, @Unretained Object v2,
    boolean isCompressedOffHeap) {
  // need to give PdxInstance#equals priority
  if (v1 instanceof PdxInstance) {
    return checkPdxEquals((PdxInstance) v1, v2);
  } else if (v2 instanceof PdxInstance) {
    return checkPdxEquals((PdxInstance) v2, v1);
  } else if (v1 instanceof StoredObject) {
    return checkOffHeapEquals((StoredObject) v1, v2);
  } else if (v2 instanceof StoredObject) {
    return checkOffHeapEquals((StoredObject) v2, v1);
  } else if (v1 instanceof CachedDeserializable) {
    return checkCDEquals((CachedDeserializable) v1, v2, isCompressedOffHeap);
  } else if (v2 instanceof CachedDeserializable) {
    return checkCDEquals((CachedDeserializable) v2, v1, isCompressedOffHeap);
  } else {
    return basicEquals(v1, v2);
  }
}
 
開發者ID:ampool,項目名稱:monarch,代碼行數:20,代碼來源:AbstractRegionEntry.java

示例4: verifyAndGetPdxDomainObject

import org.apache.geode.pdx.PdxInstance; //導入依賴的package包/類
private Object verifyAndGetPdxDomainObject(Object value) {
  if (value instanceof StructImpl) {
    // Doing hasPdx check first, since its cheaper.
    if (((StructImpl) value).isHasPdx() && !((GemFireCacheImpl) this.region.getCache())
        .getPdxReadSerializedByAnyGemFireServices()) {
      // Set the pdx values for the struct object.
      StructImpl v = (StructImpl) value;
      Object[] fieldValues = v.getPdxFieldValues();
      return new StructImpl((StructTypeImpl) v.getStructType(), fieldValues);
    }
  } else if (value instanceof PdxInstance && !((GemFireCacheImpl) this.region.getCache())
      .getPdxReadSerializedByAnyGemFireServices()) {
    return ((PdxInstance) value).getObject();
  }
  return value;
}
 
開發者ID:ampool,項目名稱:monarch,代碼行數:17,代碼來源:AbstractIndex.java

示例5: deserializePdxForLocalDistinctQuery

import org.apache.geode.pdx.PdxInstance; //導入依賴的package包/類
private Object deserializePdxForLocalDistinctQuery(ExecutionContext context, Object val)
    throws QueryInvocationTargetException {
  if (!((DefaultQuery) context.getQuery()).isRemoteQuery()) {
    if (context.isDistinct() && val instanceof PdxInstance
        && !this.region.getCache().getPdxReadSerialized()) {
      try {
        val = ((PdxInstance) val).getObject();
      } catch (Exception ex) {
        throw new QueryInvocationTargetException(
            "Unable to retrieve domain object from PdxInstance while building the ResultSet. "
                + ex.getMessage());
      }
    } else if (val instanceof PdxString) {
      val = ((PdxString) val).toString();
    }
  }
  return val;
}
 
開發者ID:ampool,項目名稱:monarch,代碼行數:19,代碼來源:AbstractIndex.java

示例6: StructImpl

import org.apache.geode.pdx.PdxInstance; //導入依賴的package包/類
/** Creates a new instance of StructImpl */
public StructImpl(StructTypeImpl type, Object[] values) {
  if (type == null) {
    throw new IllegalArgumentException(
        LocalizedStrings.StructImpl_TYPE_MUST_NOT_BE_NULL.toLocalizedString());
  }
  this.type = type;
  this.values = values;
  if (this.values != null) {
    for (Object o : values) {
      if (o instanceof PdxInstance || o instanceof PdxString) {
        this.hasPdx = true;
        break;
      }
    }
  }
}
 
開發者ID:ampool,項目名稱:monarch,代碼行數:18,代碼來源:StructImpl.java

示例7: getPdxFieldValues

import org.apache.geode.pdx.PdxInstance; //導入依賴的package包/類
/**
 * Helper method, Returns field values, in case of PdxInstance gets the domain objects.
 */
public Object[] getPdxFieldValues() {
  if (this.values == null) {
    return new Object[0];
  }

  Object[] fValues = new Object[this.values.length];
  for (int i = 0; i < this.values.length; i++) {
    if (this.values[i] instanceof PdxInstance) {
      fValues[i] = ((PdxInstance) this.values[i]).getObject();
    } else if (this.values[i] instanceof PdxString) {
      fValues[i] = ((PdxString) this.values[i]).toString();
    } else {
      fValues[i] = this.values[i];
    }
  }
  return fValues;
}
 
開發者ID:ampool,項目名稱:monarch,代碼行數:21,代碼來源:StructImpl.java

示例8: testPDXObject

import org.apache.geode.pdx.PdxInstance; //導入依賴的package包/類
@Test
public void testPDXObject() {
  final Properties props = new Properties();
  props.setProperty(MCAST_PORT, "0");
  DistributedSystem.connect(props);
  Cache cache = new CacheFactory().create();
  PdxInstanceFactory pf = PdxInstanceFactoryImpl.newCreator("Portfolio", false);
  Portfolio p = new Portfolio(2);
  pf.writeInt("ID", 111);
  pf.writeString("status", "active");
  pf.writeString("secId", "IBM");
  pf.writeObject("portfolio", p);
  PdxInstance pi = pf.create();

  TypedJson tJsonObj = new TypedJson(RESULT, pi);
  System.out.println(tJsonObj);
  cache.close();

}
 
開發者ID:ampool,項目名稱:monarch,代碼行數:20,代碼來源:TypedJsonJUnitTest.java

示例9: testNestedPDXObject

import org.apache.geode.pdx.PdxInstance; //導入依賴的package包/類
@Test
public void testNestedPDXObject() {
  final Properties props = new Properties();
  props.setProperty(MCAST_PORT, "0");
  DistributedSystem.connect(props);
  Cache cache = new CacheFactory().create();

  PdxInstanceFactory pf = PdxInstanceFactoryImpl.newCreator("Portfolio", false);

  pf.writeInt("ID", 111);
  pf.writeString("status", "active");
  pf.writeString("secId", "IBM");
  PdxInstance pi = pf.create();

  PDXContainer cont = new PDXContainer(1);
  cont.setPi(pi);

  TypedJson tJsonObj = new TypedJson(RESULT, cont);
  System.out.println(tJsonObj);
  cache.close();

}
 
開發者ID:ampool,項目名稱:monarch,代碼行數:23,代碼來源:TypedJsonJUnitTest.java

示例10: testPdxWithStringIndexKeyValues

import org.apache.geode.pdx.PdxInstance; //導入依賴的package包/類
@Test
public void testPdxWithStringIndexKeyValues() throws Exception {
  createPartitionedRegion("test_region");
  int numEntries = 10;
  Index index = qs.createHashIndex("idHash", "p.id", "/test_region p");
  for (int i = 0; i < numEntries; i++) {
    PdxInstance record = CacheUtils.getCache().createPdxInstanceFactory("test_region")
        .writeString("id", "" + i).writeString("domain", "A").create();
    region.put("" + i, record);
  }

  SelectResults results = (SelectResults) qs
      .newQuery("SELECT DISTINCT tr.domain FROM /test_region tr WHERE tr.id='1'").execute();
  assertEquals(1, results.size());
  assertTrue(observer.indexUsed);
}
 
開發者ID:ampool,項目名稱:monarch,代碼行數:17,代碼來源:HashIndexQueryIntegrationTest.java

示例11: putHeterogeneousObjects

import org.apache.geode.pdx.PdxInstance; //導入依賴的package包/類
public void putHeterogeneousObjects() throws Exception {
  PdxInstanceFactory pf = PdxInstanceFactoryImpl.newCreator("Portfolio", false);
  pf.writeInt("ID", 111);
  pf.writeString("secId", "IBM");
  pf.writeString("status", "active");
  PdxInstance pi = pf.create();
  r.put("IBM", pi);

  r.put("YHOO", new TestObject(222, "YHOO", "inactive"));
  r.put("GOOGL", new TestObject(333, "GOOGL", "active"));

  pf = PdxInstanceFactoryImpl.newCreator("Portfolio", false);
  pf.writeInt("ID", 111);
  pf.writeString("secId", "VMW");
  pf.writeString("status", "inactive");
  pi = pf.create();
  r.put("VMW", pi);
}
 
開發者ID:ampool,項目名稱:monarch,代碼行數:19,代碼來源:PdxStringQueryJUnitTest.java

示例12: createPdxInstance

import org.apache.geode.pdx.PdxInstance; //導入依賴的package包/類
public PdxInstance createPdxInstance(PdxInstanceFactory pdxFactory) {
  pdxFactory.writeInt("ID", this.ID);
  pdxFactory.writeString("pkid", this.pkid);
  pdxFactory.writeObject("position1", this.position1);
  pdxFactory.writeObject("position2", this.position2);
  pdxFactory.writeObject("positions", this.positions);
  pdxFactory.writeObject("collectionHolderMap", this.collectionHolderMap);
  pdxFactory.writeString("type", this.type);
  pdxFactory.writeString("status", this.status);
  pdxFactory.writeStringArray("names", this.names);
  pdxFactory.writeString("description", this.description);
  pdxFactory.writeLong("createTime", this.createTime);
  pdxFactory.writeObjectArray("position3", this.position3);

  return pdxFactory.create();

}
 
開發者ID:ampool,項目名稱:monarch,代碼行數:18,代碼來源:PortfolioPdxVersion.java

示例13: toJSON

import org.apache.geode.pdx.PdxInstance; //導入依賴的package包/類
/**
 * Converts a PdxInstance into a JSON document
 * 
 * @return the JSON string.
 * @throws JSONFormatterException if unable to create the JSON document
 */
public static String toJSON(PdxInstance pdxInstance) {
  try {
    PdxToJSON pj = new PdxToJSON(pdxInstance);
    return pj.getJSON();
  } catch (Exception e) {
    throw new JSONFormatterException("Could not create JSON document from PdxInstance", e);
  }
}
 
開發者ID:ampool,項目名稱:monarch,代碼行數:15,代碼來源:JSONFormatter.java

示例14: toJSONByteArray

import org.apache.geode.pdx.PdxInstance; //導入依賴的package包/類
/**
 * Converts a PdxInstance into a JSON document in byte-array form
 * 
 * @return the JSON byte array.
 * @throws JSONFormatterException if unable to create the JSON document
 */
public static byte[] toJSONByteArray(PdxInstance pdxInstance) {
  try {
    PdxToJSON pj = new PdxToJSON(pdxInstance);
    return pj.getJSONByteArray();
  } catch (Exception e) {
    throw new JSONFormatterException("Could not create JSON document from PdxInstance", e);
  }
}
 
開發者ID:ampool,項目名稱:monarch,代碼行數:15,代碼來源:JSONFormatter.java

示例15: getJSONString

import org.apache.geode.pdx.PdxInstance; //導入依賴的package包/類
private String getJSONString(JsonGenerator jg, PdxInstance pdxInstance)
    throws JsonGenerationException, IOException {
  jg.writeStartObject();

  List<String> pdxFields = pdxInstance.getFieldNames();

  for (String pf : pdxFields) {
    Object value = pdxInstance.getField(pf);
    jg.writeFieldName(pf);
    writeValue(jg, value, pf);
  }
  jg.writeEndObject();
  return null;
}
 
開發者ID:ampool,項目名稱:monarch,代碼行數:15,代碼來源:PdxToJSON.java


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