Учитывая Java InputStream, как я могу определить смещение тока в потоке?

Почему бы вам не перебрать массив $products?

$porductsNames = array();

$products = Order::select('selected_products')->get();

foreach ($products as $product){
   foreach($product('selected_products') as $p){
        $productsNames[] = $p['name'];
   }
}

// Then you can use it
dd($productsNames);
15
задан Chris R 27 October 2008 в 15:45
поделиться

3 ответа

Смотрите на CountingInputStream в пакете IO палаты общин. У них есть довольно хороший набор других полезных вариантов InputStream также.

14
ответ дан 1 December 2019 в 01:11
поделиться

Необходимо будет следовать Шаблону "декоратор", установленному в java.io для реализации этого.

Позволяют нам дать ему попытку здесь:

import java.io.FilterInputStream;
import java.io.IOException;
import java.io.InputStream;

public final class PositionInputStream
  extends FilterInputStream
{

  private long pos = 0;

  private long mark = 0;

  public PositionInputStream(InputStream in)
  {
    super(in);
  }

  /**
   * <p>Get the stream position.</p>
   *
   * <p>Eventually, the position will roll over to a negative number.
   * Reading 1 Tb per second, this would occur after approximately three 
   * months. Applications should account for this possibility in their 
   * design.</p>
   *
   * @return the current stream position.
   */
  public synchronized long getPosition()
  {
    return pos;
  }

  @Override
  public synchronized int read()
    throws IOException
  {
    int b = super.read();
    if (b >= 0)
      pos += 1;
    return b;
  }

  @Override
  public synchronized int read(byte[] b, int off, int len)
    throws IOException
  {
    int n = super.read(b, off, len);
    if (n > 0)
      pos += n;
    return n;
  }

  @Override
  public synchronized long skip(long skip)
    throws IOException
  {
    long n = super.skip(skip);
    if (n > 0)
      pos += n;
    return n;
  }

  @Override
  public synchronized void mark(int readlimit)
  {
    super.mark(readlimit);
    mark = pos;
  }

  @Override
  public synchronized void reset()
    throws IOException
  {
    /* A call to reset can still succeed if mark is not supported, but the 
     * resulting stream position is undefined, so it's not allowed here. */
    if (!markSupported())
      throw new IOException("Mark not supported.");
    super.reset();
    pos = mark;
  }

}

InputStreams предназначаются, чтобы быть ориентированными на многопотоковое исполнение, так, чтобы счета на свободное использование синхронизации. Я играл вокруг с volatile и AtomicLong переменные положения, но синхронизация является, вероятно, лучшей, потому что она позволяет одному потоку воздействовать на поток и запрашивать свое положение, не оставляя блокировку.

PositionInputStream is = …
synchronized (is) {
  is.read(buf);
  pos = is.getPosition();
}
20
ответ дан 1 December 2019 в 01:11
поделиться

Нет. InputStream предназначается для обработки потенциально бесконечных объемов данных, таким образом, счетчик помешал бы. В дополнение к обертыванию их всех Вы смогли делать что-то с аспектами.

2
ответ дан 1 December 2019 в 01:11
поделиться
Другие вопросы по тегам:

Похожие вопросы: