Package net.openhft.collections.fromdocs

Source Code of net.openhft.collections.fromdocs.OpenJDKAndHashMapExamplesTest

/*
* Copyright 2013 Peter Lawrey
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
*         http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/

package net.openhft.collections.fromdocs;

import net.openhft.affinity.AffinitySupport;
import net.openhft.collections.SharedHashMap;
import net.openhft.collections.SharedHashMapBuilder;
import net.openhft.lang.model.DataValueClasses;
import org.junit.Ignore;
import org.junit.Test;

import java.io.File;
import java.io.IOException;
import java.text.ParseException;
import java.text.SimpleDateFormat;

import static org.junit.Assert.assertEquals;

/**
* These code fragments will appear in an article on OpenHFT.  These tests to ensure that the examples compile and behave as expected.
*/
public class OpenJDKAndHashMapExamplesTest {
    private static final SimpleDateFormat YYYYMMDD = new SimpleDateFormat("yyyyMMdd");


    private static final String TMP = System.getProperty("java.io.tmpdir");

    private static long parseYYYYMMDD(String s) {
        try {
            return YYYYMMDD.parse(s).getTime();
        } catch (ParseException e) {
            throw new AssertionError(e);
        }
    }

    @Test
    @Ignore
    public void bondExample() throws IOException, InterruptedException {


        SharedHashMap<String, BondVOInterface> shm = new SharedHashMapBuilder()
                .generatedValueType(true)
                .entrySize(512).file(new File(TMP + "/shm-myBondPortfolioSHM")).kClass(String.class).vClass(BondVOInterface.class).create();


        BondVOInterface bondVO = DataValueClasses.newDirectReference(BondVOInterface.class);
        shm.acquireUsing("369604103", bondVO);
        bondVO.setIssueDate(parseYYYYMMDD("20130915"));
        bondVO.setMaturityDate(parseYYYYMMDD("20140915"));
        bondVO.setCoupon(5.0 / 100); // 5.0%

        BondVOInterface.MarketPx mpx930 = bondVO.getMarketPxIntraDayHistoryAt(0);
        mpx930.setAskPx(109.2);
        mpx930.setBidPx(106.9);

        BondVOInterface.MarketPx mpx1030 = bondVO.getMarketPxIntraDayHistoryAt(1);
        mpx1030.setAskPx(109.7);
        mpx1030.setBidPx(107.6);


        SharedHashMap<String, BondVOInterface> shmB = new SharedHashMapBuilder()
                .generatedValueType(true)
                .entrySize(320).file(new File(TMP + "/shm-myBondPortfolioSHM")).kClass(String.class).vClass(BondVOInterface.class).create();

        // ZERO Copy but creates a new off heap reference each time


        BondVOInterface bondVOB = shmB.get("369604103");
        assertEquals(5.0 / 100, bondVOB.getCoupon(), 0.0);

        BondVOInterface.MarketPx mpx930B = bondVOB.getMarketPxIntraDayHistoryAt(0);
        assertEquals(109.2, mpx930B.getAskPx(), 0.0);
        assertEquals(106.9, mpx930B.getBidPx(), 0.0);

        BondVOInterface.MarketPx mpx1030B = bondVOB.getMarketPxIntraDayHistoryAt(1);
        assertEquals(109.7, mpx1030B.getAskPx(), 0.0);
        assertEquals(107.6, mpx1030B.getBidPx(), 0.0);


        //ZERO-COPY
        // our reusable, mutable off heap reference, generated from the interface.
        BondVOInterface bondZC = DataValueClasses.newDirectReference(BondVOInterface.class);

        // lookup the key and give me a reference to the data.
        if (shm.getUsing("369604103", bondZC) != null) {
            // found a key and bondZC has been set
            // get directly without touching the rest of the record.
            long _matDate = bondZC.getMaturityDate();
            // write just this field, again we need to assume we are the only writer.
            bondZC.setMaturityDate(parseYYYYMMDD("20440315"));

            //demo of how to do OpenHFT off-heap array[ ] processing
            int tradingHour = 2//current trading hour intra-day
            BondVOInterface.MarketPx mktPx = bondZC.getMarketPxIntraDayHistoryAt(tradingHour);
            if (mktPx.getCallPx() < 103.50) {
                mktPx.setParPx(100.50);
                mktPx.setAskPx(102.00);
                mktPx.setBidPx(99.00);
                // setMarketPxIntraDayHistoryAt is not needed as we are using zero copy,
                // the original has been changed.
            }
        }

        // bondZC will be full of default values and zero length string the first time.

        // from this point, all operations are completely record/entry local,
        // no other resource is involved.
        // now perform thread safe operations on my reference
        bondZC.addAtomicMaturityDate(16 * 24 * 3600 * 1000L)//20440331


        bondZC.addAtomicCoupon(-1 * bondZC.getCoupon()); //MT-safe! now a Zero Coupon Bond.

        // say I need to do something more complicated
        // set the Threads getId() to match the process id of the thread.
        AffinitySupport.setThreadId();

        bondZC.busyLockEntry();
        try {
            String str = bondZC.getSymbol();
            if (str.equals("IBM_HY_2044"))
                bondZC.setSymbol("OPENHFT_IG_2044");
        } finally {
            bondZC.unlockEntry();
        }

        // cleanup.
        shm.close();
        shmB.close();
        new File("/dev/shm/myBondPortfolioSHM").delete();

    }


}
TOP

Related Classes of net.openhft.collections.fromdocs.OpenJDKAndHashMapExamplesTest

TOP
Copyright © 2018 www.massapi.com. All rights reserved.
All source code are property of their respective owners. Java is a trademark of Sun Microsystems, Inc and owned by ORACLE Inc. Contact coftware#gmail.com.