草庐IT

little-endian

全部标签

java - 通过AudioInputStream读取数据需要关心big endian和little endian吗?

我正在通过AudioInputStream将一个wav文件读入一个字节数组,AudioInputStreamaudiofile=AudioSystem.getAudioInputStream(f);byte[]audio=newbyte[numberofframes*framesize];intbytes=audiofile.read(audio);考虑到数据是按小端排列的,我是否需要排列样本的字节,还是AudioInputStream为我做这件事? 最佳答案 如果数据以超过一个字节的方式编码,例如,位深度为16或更多,无论chan

Java : DataInputStream replacement for endianness

下面是我的代码,它替换了DataInputStream以包装InputStream,但除了读取大端类型的常规方法之外,还提供了额外的方法来读取小端数据类型。如果您愿意,请随意使用它。我有以下几点保留意见。注意不改变功能的方法(读取大端类型的函数)。我无法将DataInputStream实现为基类并使用其方法,如read()、readInt()、readChar()等?我的类层次结构在这里似乎有点奇怪。这样合适吗?像readUTF()或readLine()这样的其他类型是否需要小端版本?或者这对特定程序来说是主观的?Java是如何存储boolean类型的?这也是字节顺序的主观因素吗?感谢

c++ - Little Endian - Big Endian 问题

小端与大端大字节序=0x31014950小字节序=0x50490131但是使用这个方法inlineunsignedintendian_swap(unsignedint&x){return(((x&0x000000FF)>8)|((x&0xFF000000)>>24));}结果=0x54110131我花了很多时间尝试很多类似的方法,甚至是像这样的库unsignedlong_byteswap_ulong(unsignedlongvalue);但仍然没有运气..所有返回相同的结果编辑我正在使用MicrosoftVisualStudio2008开发Little-Endian系统例子如下intm

c# - 位移位是否总是考虑 Endian 体系结构?

假设我正在从C++移植代码并需要在C#中模拟相同的位移技术:每当我执行位移时,我是否必须考虑架构的Endain-ness? 最佳答案 没有。位移是一种纯粹的代数运算。它不比乘以二更依赖于平台。平台相关的是将变量解释为字符数组的结果。 关于c#-位移位是否总是考虑Endian体系结构?,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.com/questions/15315425/

c++ - C++中文件的Big Endian和Little Endian

我正在尝试编写一些独立于处理器的代码来以大端格式编写一些文件。我在下面有一个代码示例,但我不明白为什么它不起作用。它应该做的就是让字节按大端顺序将数据的每个字节一个一个地存储起来。在我的实际程序中,我会将单个字节写入文件,因此无论处理器架构如何,我都会在文件中获得相同的字节顺序。#includeintmain(intargc,char*constargv[]){longdata=0x12345678;longbitmask=(0xFF出于某种原因,byte的值始终为0。这让我感到困惑,我正在查看调试器并看到:数据=00010010001101000101011001111000位掩码=

c++ - 交换 float 和 double 的 "endianness"

我想切换float和double值的“字节顺序”,它可以正常工作,方法如下:floatconstv{1.f};swap(reinterpret_cast(v));是否有更好的方式来进行交换,无需强制转换?编辑:swap()是gcc内置函数的C++包装器,我没有在此处包含它。uint16_t__builtin_bswap16(uint16_tx)uint32_t__builtin_bswap32(uint32_tx)uint64_t__builtin_bswap64(uint64_tx)某些数据格式需要字节顺序交换,例如CBOR。 最佳答案

ios - 在 Swift 中将 float 转换为 little endian

我正在处理来自套接字的数据并成功地将数据转换为Int和Floats:letfloat=data.withUnsafeBytes{$0.pointee}asFloat一切正常,直到一部iPhone6Plus似乎在使用BigEndian处理数据。我可以毫不费力地转换Int:letuint32=UInt32(littleEndian:data.withUnsafeBytes{$0.pointee})letint=Int(uint32)不幸的是,我似乎无法弄清楚如何转换float据。 最佳答案 一种可能的解决方案是先将数据读入一个32位整数

ios - 应该如何在 AVAudioEngine 图中配置 AUMatrixMixer?

我完全坚持这一点,非常感谢任何帮助...我在AVAudioEngine图表中实现了一个AUMatrixMixer,但我听不到任何声音。如果我将AUMatrixMixer换成AUMultiChannelMixer,我就能听到声音。我在直接上游节点(AUHighPassFilter)上安装了一个分路器,我可以看到音频被AUMatrixMixer提取。如果我将水龙头移到AUMatrixMixer的输出端,我可以看到从下一个下游节点-AVAudioEngine主混音器节点-拉取数据,但它完全没有声音......关于AUMatrixMixers的评论不多,所以它可能是一些我不知道的神奇设置。作为

ARM big-LITTLE技术简介

1.背景        为满足在移动设备应用领域中的节能需求,ARM于2011年首次提出了big.LITTLE技术。big.LITTLE技术是一种使用两种不同ARM处理器的处理架构技术,即big处理器和LITTLE处理器,big处理器用于提供高性能,LITTLE处理器用于追求最大能效。big.LITTLE技术特别适用于功耗动态变化的手机、平板等移动设备领域;以手机为例,在游戏、高质量视频等高能耗场景,切换到big处理器进行处理,而对于文字输入、听音乐、待机等低能耗场景,切换到LITTLE处理器进行处理。2.原理        以最早的ARMbig.LITTLE处理架构为例,讲述big.LITT

php fgetcsv 和整数转换(UTF8 x UCS-2 Little Endian)

更新4:我发现(正如所怀疑的那样)文件编码是造成这种情况的原因。我将csv文件从UCS-2LittleEndian转换为UTF-8,一切正常。无论如何,我需要找到一些方法让PHP正确理解输入文件。已尝试sellocale但没有成功。---原始问题---我有一些数据以“表格”格式存储在csv文件中,我想将这些数据存储为数据库中的(tag,tagtimestamp,tagvalue)。但是找不到将存储在$v数组中的值转换为整数值的方法:$p=0;$tag=array();$dt=array();$v=array();$handle=fopen("sga/2013.10.054.vol2.c