Avoid allocations in .Parse methods (#3760)
* Avoid allocations in .Parse methods Use the Span overloads of the Parse methods when possible to avoid string allocations and remove one unnecessarry array allocation * Avoid another string allocation
This commit is contained in:
		
							parent
							
								
									a6cd044f0f
								
							
						
					
					
						commit
						c40c3905e2
					
				
					 6 changed files with 10 additions and 11 deletions
				
			
		|  | @ -918,7 +918,7 @@ namespace Ryujinx.HLE.HOS.Diagnostics.Demangler | |||
|                 return -1; | ||||
|             } | ||||
| 
 | ||||
|             return int.Parse(part.Substring(0, numberLength)); | ||||
|             return int.Parse(part.AsSpan(0, numberLength)); | ||||
|         } | ||||
| 
 | ||||
|         private string ParseNumber(bool isSigned = false) | ||||
|  |  | |||
|  | @ -816,11 +816,11 @@ namespace Ryujinx.HLE.HOS.Services.Nfc.Nfp | |||
|                                 Reserved = new Array57<byte>() | ||||
|                             }; | ||||
| 
 | ||||
|                             modelInfo.CharacterId      = BinaryPrimitives.ReverseEndianness(ushort.Parse(context.Device.System.NfpDevices[i].AmiiboId.Substring(0, 4), NumberStyles.HexNumber)); | ||||
|                             modelInfo.CharacterVariant = byte.Parse(context.Device.System.NfpDevices[i].AmiiboId.Substring(4, 2), NumberStyles.HexNumber); | ||||
|                             modelInfo.Series           = byte.Parse(context.Device.System.NfpDevices[i].AmiiboId.Substring(12, 2), NumberStyles.HexNumber); | ||||
|                             modelInfo.ModelNumber      = ushort.Parse(context.Device.System.NfpDevices[i].AmiiboId.Substring(8, 4), NumberStyles.HexNumber); | ||||
|                             modelInfo.Type             = byte.Parse(context.Device.System.NfpDevices[i].AmiiboId.Substring(6, 2), NumberStyles.HexNumber); | ||||
|                             modelInfo.CharacterId      = BinaryPrimitives.ReverseEndianness(ushort.Parse(context.Device.System.NfpDevices[i].AmiiboId.AsSpan(0, 4), NumberStyles.HexNumber)); | ||||
|                             modelInfo.CharacterVariant = byte.Parse(context.Device.System.NfpDevices[i].AmiiboId.AsSpan(4, 2), NumberStyles.HexNumber); | ||||
|                             modelInfo.Series           = byte.Parse(context.Device.System.NfpDevices[i].AmiiboId.AsSpan(12, 2), NumberStyles.HexNumber); | ||||
|                             modelInfo.ModelNumber      = ushort.Parse(context.Device.System.NfpDevices[i].AmiiboId.AsSpan(8, 4), NumberStyles.HexNumber); | ||||
|                             modelInfo.Type             = byte.Parse(context.Device.System.NfpDevices[i].AmiiboId.AsSpan(6, 2), NumberStyles.HexNumber); | ||||
| 
 | ||||
|                             context.Memory.Write(outputPosition, modelInfo); | ||||
| 
 | ||||
|  |  | |||
|  | @ -122,9 +122,8 @@ namespace Ryujinx.HLE.HOS.Tamper | |||
|                 for (int nybbleIndex = 0; nybbleIndex < wordSize; nybbleIndex++) | ||||
|                 { | ||||
|                     int index = wordIndex * wordSize + nybbleIndex; | ||||
|                     string byteData = word.Substring(nybbleIndex, 1); | ||||
| 
 | ||||
|                     instruction[index] = byte.Parse(byteData, NumberStyles.HexNumber, CultureInfo.InvariantCulture); | ||||
|                     instruction[index] = byte.Parse(word.AsSpan(nybbleIndex, 1), NumberStyles.HexNumber, CultureInfo.InvariantCulture); | ||||
|                 } | ||||
|             } | ||||
| 
 | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 Berkan Diler
						Berkan Diler