Excepción OutOfMemory en la conversión de ByteArray a String?
Utilizo el código siguiente para convertir mi ByteArray a la secuencia:
String sReturn = new String(byteArray, "UTF-8");
Pero consigo la excepción siguiente cuando ByteArray es bastante grande.
- ¿Por qué la marquesina no funciona en Widget?
- Cuerdas Android dependientes del tema
- Android StringBuilder vs Concatenación de cadenas
- Reemplazar el dígito inglés con el dígito persa en Cadena, excepto las URL
- Cómo getResources (). GetString () funciona android
¿Hay alguna otra manera de convertir ByteArray a String sin excepción de memoria?
06-17 12:27:37.594: E/dalvikvm(1617): Out of memory: Heap Size=30663KB, Allocated=22087KB, Bitmap Size=936KB, Limit=32768KB 06-17 12:27:37.594: E/dalvikvm(1617): Extra info: Footprint=30663KB, Allowed Footprint=30663KB, Trimmed=616KB 06-17 12:27:37.594: W/dalvikvm(1617): threadid=9: thread exiting with uncaught exception (group=0x4001d648) 06-17 12:27:37.594: E/AndroidRuntime(1617): FATAL EXCEPTION: Thread-19 06-17 12:27:37.594: E/AndroidRuntime(1617): java.lang.OutOfMemoryError: (Heap Size=30663KB, Allocated=22087KB, Bitmap Size=936KB) 06-17 12:27:37.594: E/AndroidRuntime(1617): at java.lang.String.<init>(String.java:422) 06-17 12:27:37.594: E/AndroidRuntime(1617): at java.lang.String.<init>(String.java:276) 06-17 12:27:37.594: E/AndroidRuntime(1617): at org.mabna.order.utils.Utilities.decompress(Utilities.java:389) 06-17 12:27:37.594: E/AndroidRuntime(1617): at org.mabna.order.utils.WebserviceResponse.getClearedResponse(WebserviceResponse.java:18) 06-17 12:27:37.594: E/AndroidRuntime(1617): at org.mabna.order.businessLayer.BoWebService.getDataForUpdate(BoWebService.java:216) 06-17 12:27:37.594: E/AndroidRuntime(1617): at org.mabna.order.ui.ActToolDataExchange.threadGetDataForFullUpdate(ActToolDataExchange.java:389) 06-17 12:27:37.594: E/AndroidRuntime(1617): at org.mabna.order.ui.ActToolDataExchange.access$9(ActToolDataExchange.java:380) 06-17 12:27:37.594: E/AndroidRuntime(1617): at org.mabna.order.ui.ActToolDataExchange$35.run(ActToolDataExchange.java:639) 06-17 12:27:37.594: E/AndroidRuntime(1617): at org.mabna.order.utils.Utilities$4.run(Utilities.java:924)
ACTUALIZAR
public static String decompress(String zipText) throws IOException { byte[] compressed = Base64.decode(zipText); if (compressed.length > 4) { GZIPInputStream gzipInputStream = new GZIPInputStream( new ByteArrayInputStream(compressed, 4, compressed.length - 4)); ByteArrayOutputStream baos = new ByteArrayOutputStream(); for (int value = 0; value != -1;) { value = gzipInputStream.read(); if (value != -1) { baos.write(value); } } gzipInputStream.close(); baos.close(); byte[] byteArray = baos.toByteArray(); Log.i("toByteArray", String.valueOf(byteArray.length)); String sReturn = new String(byteArray, "UTF-8"); return sReturn; } else { return ""; } } public static String decrypt(String encrypted, String password) throws Exception { byte[] encrypteddata = Base64.decode(encrypted); byte[] bytes = decrypt(encrypteddata, password); String result = new String(bytes, "UTF-8"); return result; } public static byte[] decrypt(byte[] encrypted, String password) throws Exception { byte[] passwordKey = encodeDigest(password); try { aesCipher = Cipher.getInstance(CIPHER_TRANSFORMATION); } catch (NoSuchAlgorithmException e) { throw new Exception( "Decryption Exception: No such algorithm\r\n" + e .toString()); } catch (NoSuchPaddingException e) { throw new Exception( "Decryption Exception: No such padding PKCS5\r\n" + e .toString()); } secretKey = new SecretKeySpec(passwordKey, CIPHER_ALGORITHM); try { aesCipher.init(Cipher.DECRYPT_MODE, secretKey, ivParameterSpec); } catch (InvalidKeyException e) { throw new Exception( "Decryption Exception: Invalid key\r\n" + e.toString()); } catch (InvalidAlgorithmParameterException e) { throw new Exception( "Decryption Exception: Invalid algorithm\r\n" + e .toString()); } byte[] encryptedData; try { encryptedData = aesCipher.doFinal(encrypted); } catch (IllegalBlockSizeException e) { throw new Exception( "Decryption Exception: Illegal block size\r\n" + e .toString()); } catch (BadPaddingException e) { throw new Exception( "Decryption Exception: Bad padding\r\n" + e .toString()); } return encryptedData; }
- Quitar el prefijo de URL de String (http: /, www, etc.)
- Android convertir Cadena a byte - tomar byte en las piezas
- Alternativa de DatatypeConverter.printHexBinary (byte array) y DatatypeConverter.parseHexBinary (String str) en Android
- Fórmula química en Android
- Android (cambio de cadena en código java)
- String-arrays de referencia en android strings.xml
- Cómo mostrar un formato doble como un precio en una vista de texto en android
- ¿Cómo puedo obtener una cadena de mi respuesta http android?
Seguir el fragmento te ayudará. Trata de leer en trozos
StringBuilder sb=new StringBuilder(); Log.v("abc","length : " + byteArray.length); while (totalBytesRead < formDataLength) { byteRead = in.read(dataBytes, totalBytesRead, formDataLength); // byteRead = in.read(dataBytes); //totalBytesRead += byteRead; sb.append((char)byteRead); } String s=sb.toString();
Yo lo rompería hasta como 1000 cuerdas de char a la vez. 3663125 bytes es una gran cantidad de memoria, especialmente para Android.
ArrayList<String> strings = new ArrayList<String>(); byte[] set = new byte[1000]; for(int x = 0, index = 0; x < byteArray.length;x++, index++) { set[index] = byteArray[x]; if(index == 999) { strings.add(new String(set, "Unicode")); index = 0; if(byteArray.length - x < 1000) // shorten the set when there are less than 1000 bytes left set = new byte[byteArray.length - x]; } } strings.add(new String(set, "Unicode")); String stringArray[] = (String[])strings.toArray();
Esto lo romperá para usted, usted puede cambiar el 1000 para ser lo que usted quiere si eso es demasiado pequeño.
Usted está asignando la memoria en exceso – primero descomprime la base 64 y asignar el búfer para esto, entonces usted lo descomprime y escribe en chutnks a BAOS (que alocating y reasigna pedazos de la memoria) y usted lo copia otra vez a la secuencia – ninguna maravilla que funciona sin memoria.
Trate de volver a escribir esto para el proceso de streaming (hay srteaming base64 dcoding, así como decodificador gzip)
- Mostrar imágenesVistas con tema de animación
- ¿Por qué no puedo responder a las críticas de PlayStore?