当前位置: 首页>>代码示例>>C#>>正文


C# FileStream.?.Dispose方法代码示例

本文整理汇总了C#中System.IO.FileStream.?.Dispose方法的典型用法代码示例。如果您正苦于以下问题:C# FileStream.?.Dispose方法的具体用法?C# FileStream.?.Dispose怎么用?C# FileStream.?.Dispose使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在System.IO.FileStream的用法示例。


在下文中一共展示了FileStream.?.Dispose方法的10个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C#代码示例。

示例1: LoadAsync

        public async Task<IEnumerable<StreamBase>> LoadAsync()
        {
            List<StreamBase> streams = new List<StreamBase>();

            FileStream fsAsync = null;

            try
            {
                fsAsync = new FileStream(FilePath,
                FileMode.Open,
                FileAccess.Read,
                FileShare.None,
                4096,
                true);

                using (StreamReader sr = new StreamReader(fsAsync))
                {
                    fsAsync = null;

                    string line = string.Empty;

                    while ((line = await sr.ReadLineAsync().ConfigureAwait(false)) != null)
                    {
                        StreamBase sb = ParseIntoStream(line);

                        if (sb != null)
                        {
                            streams.Add(sb);
                        }
                    }
                }
            }
            catch (FileNotFoundException e)
            {
                Utils.LogException(e);
            }
            finally
            {
                fsAsync?.Dispose();
            }

            return streams;
        }
开发者ID:Kingloo,项目名称:Storm,代码行数:43,代码来源:TxtRepo.cs

示例2: Write

        public static void Write(string value, bool writeToFile = false, Exception exception = null)
        {
            FileStream fileStream = null;

            try
            {
                fileStream = new FileStream(LogFileName, FileMode.Append, FileAccess.Write, FileShare.ReadWrite);

                using (var streamWriter = new StreamWriter(fileStream, Encoding.UTF8))
                {
                    fileStream = null;

                    if (exception != null)
                    {
                        Debug.WriteLine($"[{DateTime.Now}]: {value} [Exception: {exception}]");

                        if (writeToFile)
                            streamWriter.WriteLine($"[{DateTime.Now}]: {value} [Exception: {exception}]");
                    }
                    else
                    {
                        Debug.WriteLine($"[{DateTime.Now}]: {value}");

                        if (writeToFile)
                            streamWriter.WriteLine($"[{DateTime.Now}]: {value}");
                    }
                }
            }
            catch (Exception ex)
            {
                Debug.WriteLine($"Logger error: {ex}");
            }
            finally
            {
                fileStream?.Dispose();
            }
        }
开发者ID:Hertizch,项目名称:HrtzCraft,代码行数:37,代码来源:Logger.cs

示例3: WriteTextToFileAsync

        private static async Task WriteTextToFileAsync(string text, int rounds = 1)
        {
            if (text == null) { throw new ArgumentNullException(nameof(text)); }
            if (rounds < 1) { throw new ArgumentException("WriteTextToFileAsync: rounds cannot be < 1"); }

            bool tryAgain = false;
            
            FileStream fsAsync = null;
            try
            {
                fsAsync = new FileStream(logFilePath, FileMode.Append, FileAccess.Write, FileShare.None, 1024, true);

                using (StreamWriter sw = new StreamWriter(fsAsync))
                {
                    fsAsync = null;

                    await sw.WriteLineAsync(text).ConfigureAwait(false);
                }
            }
            catch (IOException)
            {
                tryAgain = (rounds > 1);
            }
            finally
            {
                fsAsync?.Dispose();
            }

            if (tryAgain)
            {
                int variation = DateTime.UtcNow.Millisecond;

                /*
                 * we want the delay to increase as the number of attempts left decreases
                 * as rounds increases, (1 / rounds) decreases
                 * => as (1 / rounds) decreases, (25 / (1 / rounds)) increases 
                 * 
                 * we convert rounds to decimal because otherwise it would do integer division
                 * e.g. 1 / 3 = 0
                 */
                decimal fixedWait = 25 / (1 / Convert.ToDecimal(rounds));

                int toWait = Convert.ToInt32(fixedWait) + variation;

                await Task.Delay(toWait).ConfigureAwait(false);

                await WriteTextToFileAsync(text, rounds - 1).ConfigureAwait(false);
            }
        }
开发者ID:Kingloo,项目名称:Pingy,代码行数:49,代码来源:Utils.cs

示例4: SaveToFile

        public override void SaveToFile(string fileName, Encoding enc)
        {
            //
            var newLinePos = new List<int>(Count);
            //create temp file
            var dir = Path.GetDirectoryName(fileName);
            if (dir != null) {
                var tempFileName = Path.Combine(dir, Path.GetFileNameWithoutExtension(fileName) + ".tmp");
                FileStream tempFs = null;
                StreamReader sr = new StreamReader(fs, fileEncoding);
                try {
                    tempFs = new FileStream(tempFileName, FileMode.Create);
                    using (StreamWriter sw = new StreamWriter(tempFs, enc)) {
                        int fsLen = (int)tempFs.Length;
                        tempFs = null;
                        sw.Flush();

                        for (int i = 0; i < Count; i++) {
                            newLinePos.Add(fsLen);

                            var sourceLine = ReadLine(sr, i);//read line from source file

                            bool lineIsChanged = lines[i] != null && lines[i].IsChanged;

                            var line = lineIsChanged ? lines[i].Text : sourceLine;

                            //call event handler
                            if (LinePushed != null) {
                                var args = new LinePushedEventArgs(sourceLine, i, lineIsChanged ? line : null);
                                LinePushed(this, args);

                                if (args.SavedText != null)
                                    line = args.SavedText;
                            }

                            //save line to file
                            sw.Write(line);

                            if (i < Count - 1)
                                sw.Write(SaveEOL);

                            sw.Flush();
                        }
                    }
                } finally {
                    tempFs?.Dispose();
                }

                //clear lines buffer
                for (int i = 0; i < Count; i++)
                    lines[i] = null;
                //deattach from source file
                sr.Dispose();
                fs.Dispose();
                //delete target file
                if (File.Exists(fileName))
                    File.Delete(fileName);
                //rename temp file
                File.Move(tempFileName, fileName);
            }

            //binding to new file
            sourceFileLinePositions = newLinePos;
            fs = new FileStream(fileName, FileMode.Open);
            fileEncoding = enc;
        }
开发者ID:WendyH,项目名称:HMSEditor_addon,代码行数:66,代码来源:FileTextSource.cs

示例5: Execute_LoadPlayerDataFromFile


//.........这里部分代码省略.........
                                        Uuid = user.Uuid
                                    });
                                }

                                userCacheCollection.Clear();
                            }

                            break;
                        }

                        case "ops.json":
                        {
                            var opsCollection = JsonConvert.DeserializeObject<List<Op>>(json);

                            if (opsCollection != null)
                            {
                                // Remove existing true values
                                foreach (var source in GlobalPlayersCollection.Where(x => x.IsOperator))
                                {
                                    source.IsOperator = false;
                                    source.OpLevel = null;
                                }

                                foreach (var globalPlayer in GlobalPlayersCollection)
                                {
                                    foreach (var op in opsCollection.Where(x => globalPlayer.Uuid.Equals(x.Uuid)))
                                    {
                                        globalPlayer.IsOperator = true;
                                        globalPlayer.OpLevel = op.Level;
                                    }
                                }

                                opsCollection.Clear();
                            }

                            break;
                        }

                        case "banned-players.json":
                        {
                            var bannedPlayersCollection = JsonConvert.DeserializeObject<List<BannedPlayer>>(json);

                            if (bannedPlayersCollection != null)
                            {
                                // Remove existing true values
                                foreach (var source in GlobalPlayersCollection.Where(x => x.IsBanned))
                                {
                                    source.IsBanned = false;
                                    source.BanExpires = null;
                                    source.BanReason = null;
                                    source.BanSource = null;
                                }

                                foreach (var globalPlayer in GlobalPlayersCollection)
                                {
                                    foreach (
                                        var bannedPlayer in
                                            bannedPlayersCollection.Where(x => globalPlayer.Uuid.Equals(x.Uuid)))
                                    {
                                        globalPlayer.IsBanned = true;
                                        globalPlayer.BanReason = bannedPlayer.Reason;
                                        globalPlayer.BanSource = bannedPlayer.Source;
                                        globalPlayer.BanExpires = bannedPlayer.Expires;
                                    }
                                }

                                bannedPlayersCollection.Clear();
                            }

                            break;
                        }

                        case "whitelist.json":
                        {
                            var whitelistedCollection = JsonConvert.DeserializeObject<List<Whitelist>>(json);

                            if (whitelistedCollection != null)
                            {
                                // Remove existing true values
                                foreach (var source in GlobalPlayersCollection.Where(x => x.IsWhitelisted))
                                    source.IsWhitelisted = false;

                                foreach (var globalPlayer in from globalPlayer in GlobalPlayersCollection
                                    from whitelist in whitelistedCollection.Where(x => globalPlayer.Uuid.Equals(x.Uuid))
                                    select globalPlayer)
                                    globalPlayer.IsWhitelisted = true;

                                whitelistedCollection.Clear();
                            }

                            break;
                        }
                    }
                }
            }
            finally
            {
                stream?.Dispose();
            }
        }
开发者ID:Hertizch,项目名称:HrtzCraft,代码行数:101,代码来源:GlobalPlayersViewModel.cs

示例6: DisposableNotDisposed

        public DisposableNotDisposed(FileStream fs)
        {
            var fs1 = new FileStream(@"c:\foo.txt", FileMode.Open); // Noncompliant - directly instantiated with new
            var fs2 = File.Open(@"c:\foo.txt", FileMode.Open); // Noncompliant - instantiated with factory method
            Stream fs3 = new FileStream(@"c:\foo.txt", FileMode.Open); // Noncompliant - declaration type should not matter
            var s = new WebClient(); // Noncompliant - another tracked type

            var fs4 = new FileStream(@"c:\foo.txt", FileMode.Open); // Compliant - passed to a method
            NoOperation(fs4);

            FileStream fs5; // Compliant - used properly
            using (fs5 = new FileStream(@"c:\foo.txt", FileMode.Open))
            {
                // do nothing but dispose
            }

            using (var fs6 = new FileStream(@"c:\foo.txt", FileMode.Open)) // Compliant - used properly
            {
                // do nothing but dispose
            }

            var fs7 = new FileStream(@"c:\foo.txt", FileMode.Open); // Compliant - Dispose()
            fs7.Dispose();

            var fs8 = new FileStream(@"c:\foo.txt", FileMode.Open); // Compliant - Close()
            fs8.Close();

            var fs9 = new FileStream(@"c:\foo.txt", FileMode.Open); // Compliant - disposed using elvis operator
            fs9?.Dispose();

            FileStream fs10 = fs; // Compliant - not instantiated directly

            var fs11 = new FileStream(@"c:\foo.txt", FileMode.Open); // Compliant - aliased
            var newFs = fs11;

            var fs12 = new BufferedStream(fs); // Compliant - constructed from another stream
            var fs13 = new StreamReader(fs); // Compliant - constructed from another stream

            var fs14 = new FileStream(@"c:\foo.txt", FileMode.Open); // Compliant - passed to another method (or constructor)
            var fs15 = new BufferedStream(fs14); // Compliant - not tracked

            var fs16 = new FileStream(@"c:\foo.txt", FileMode.Open); // Compliant - aliased
            var myAnonymousType = new { SomeField = fs16 };

            FileStream fs17; // Compliant - no initializer, should not fail

            FileStream
                fs18 = new FileStream(@"c:\foo.txt", FileMode.Open), // Noncompliant - test issue location
                fs19; // Compliant - not instantiated

            FileStream fs20 = new FileStream(@"c:\foo.txt", FileMode.Open); // Compliant - aliased
            Stream fs21;
            fs21 = fs20;

            FileStream fs22;
            fs22 = new FileStream(@"c:\foo.txt", FileMode.Open); // Noncompliant

            field_fs4.Dispose();

            field_fs5 = new FileStream(@"c:\foo.txt", FileMode.Open); // Noncompliant

            NoOperation(field_fs6);
            field_fs6 = new FileStream(@"c:\foo.txt", FileMode.Open); // Compliant - field_fs6 gets passed to a method

            field_fs7 = new FileStream(@"c:\foo.txt", FileMode.Open); // Noncompliant - even if field_fs7's type is object

            NoOperation(this.field_fs8);
        }
开发者ID:duncanpMS,项目名称:sonarlint-vs,代码行数:68,代码来源:DisposableNotDisposed.cs

示例7: Step5

        /// <summary>
        /// Step #5
        /// 
        /// Save the unpacked file.
        /// </summary>
        /// <returns></returns>
        private bool Step5()
        {
            FileStream fStream = null;
            byte[] overlayData = null;

            try
            {
                // Determine if the file has any overlay data..
                var lastSection = this.File.Sections.Last();
                var fileSize = lastSection.SizeOfRawData + lastSection.PointerToRawData;

                if (fileSize < this.File.FileData.Length)
                {
                    // Overlay exists, copy it..
                    overlayData = new byte[this.File.FileData.Length - fileSize];
                    Array.Copy(this.File.FileData, fileSize, overlayData, 0, this.File.FileData.Length - fileSize);
                }
            }
            catch
            {
                return false;
            }

            try
            {
                // Open the unpacked file for writing..
                var unpackedPath = this.File.FilePath + ".unpacked.exe";
                fStream = new FileStream(unpackedPath, FileMode.Create, FileAccess.ReadWrite);

                // Write the dos header back to the file..
                fStream.WriteBytes(Helpers.GetStructureBytes(this.File.DosHeader));

                // Write the dos stub back to the file if it exists..
                if (this.File.DosStubSize > 0)
                    fStream.WriteBytes(this.File.DosStubData);

                // Determine if we should remove the .bind section..
                if (!Program.HasArgument("--keepbind"))
                {
                    // Remove the .bind section from the file..
                    this.File.Sections.Remove(this.File.GetSection(".bind"));
                }

                // Rebuild the NT headers of the file..
                var ntHeaders = this.File.NtHeaders;
                var lastSection = this.File.Sections[this.File.Sections.Count - 1];
                if (!Program.HasArgument("--keepbind"))
                    ntHeaders.FileHeader.NumberOfSections--;
                ntHeaders.OptionalHeader.AddressOfEntryPoint = this.StubHeader.OriginalEntryPoint;
                ntHeaders.OptionalHeader.SizeOfImage = lastSection.VirtualAddress + lastSection.VirtualSize;

                // Write the Nt headers to the file..
                fStream.WriteBytes(Helpers.GetStructureBytes(ntHeaders));

                // Write the sections to the file..
                foreach (var s in this.File.Sections)
                {
                    // Obtain the sections data from the original file..
                    var sectionData = new byte[s.SizeOfRawData];
                    Array.Copy(this.File.FileData, this.File.GetFileOffsetFromRva(s.VirtualAddress), sectionData, 0, s.SizeOfRawData);

                    // Write the section header to the file..
                    fStream.WriteBytes(Helpers.GetStructureBytes(s));

                    // Write the section data to the file..
                    var sectionOffset = fStream.Position;
                    fStream.Position = s.PointerToRawData;

                    // Determine if this is the code section..
                    if (s.SizeOfRawData == this.CodeSection.SizeOfRawData && s.PointerToRawData == this.CodeSection.PointerToRawData)
                        fStream.WriteBytes(this.CodeSectionData ?? sectionData);
                    else
                        fStream.WriteBytes(sectionData);

                    // Reset the file offset..
                    fStream.Position = sectionOffset;
                }

                // Skip to the end of the stream..
                fStream.Position = fStream.Length;

                // Write the overlay back to the file if it exists..
                if (overlayData != null)
                    fStream.WriteBytes(overlayData);

                return true;
            }
            catch
            {
                return false;
            }
            finally
            {
                fStream?.Dispose();
//.........这里部分代码省略.........
开发者ID:zbvochfa,项目名称:Steamless.NET,代码行数:101,代码来源:SteamStubVariant3.cs

示例8: LoadOPLFile

        private bool LoadOPLFile(string fileName, uint startTime, uint endTime)
        {
            FileStream fs = null;
            _signalElements = new SignalElements();
            string lastDataEntryTime = "";
            List<string> currentDataStrings = null;

            _currentPhase = Phase.HeaderVersion;
            bool parseError = false;
            List<Task> parseTasks = null;

            try {
                fs = new FileStream(fileName, FileMode.Open);
                using (TextReader reader = new StreamReader(fs)) {
                    fs = null;
                    _header = new OPLHeader();
                    string line;

                    while ((line = reader.ReadLine()) != null) {
                        switch (_currentPhase) {
                            case Phase.HeaderVersion:
                                if (!_header.ParseHeaderVersion(line)) {
                                    Console.WriteLine("Unsupported file version detected");
                                    return false;
                                }
                                Console.WriteLine("File version {0} detected", Header.Version);
                                _currentPhase = Phase.Header1;
                                break;
                            case Phase.Header1:
                                if (!_header.ParseHeader1(line)) {
                                    Console.WriteLine("Cannot parse header");
                                    return false;
                                }
                                _currentPhase = Phase.Header2;
                                break;
                            case Phase.Header2:
                                if (!_header.ParseHeader2(line)) {
                                    Console.WriteLine("Cannot parse header");
                                    return false;
                                }
                                Console.WriteLine("Header successfully parsed");
                                _currentPhase = Phase.SignalElements;
                                break;
                            case Phase.SignalElements:
                                SignalElement element = new SignalElement();
                                if (element.ParseData(line)) {
                                    element.Freeze();
                                    _signalElements.Add(element);
                                    if ((uint)_signalElements.Count == _header.SignalElementCount) {
                                        // All elements found, prepare next phase.
                                        Console.WriteLine("Signal element data successfully parsed");
                                        _currentPhase = Phase.Data;
                                        _dataEntries = new ConcurrentDictionary<uint, SignalDataEntry>(Environment.ProcessorCount,
                                            (int)(_header.EndTimeAsUnixTime - _header.StartTimeAsUnixTime + 2));
                                        parseTasks = new List<Task>((int)(_header.EndTimeAsUnixTime - _header.StartTimeAsUnixTime + 2));
                                        // A data entry contains a header as well, therefore SignalElementCount + 1.
                                        currentDataStrings = new List<string>((int)_header.SignalElementCount + 1);
                                    }
                                    break;
                                }
                                Console.WriteLine("Couldn't parse signal element data");
                                return false;
                            case Phase.Data:
                                if (parseError) {
                                    return false;
                                }
                                if (lastDataEntryTime != _header.EndTimeAsUnixTime.ToString()) {
                                    if (currentDataStrings.Count < _header.SignalElementCount + 1) {
                                        currentDataStrings.Add(line);
                                    }
                                    if (currentDataStrings.Count == _header.SignalElementCount + 1) {
                                        var parseStrings = new List<string>(currentDataStrings);
                                        parseTasks.Add(Task.Factory.StartNew(
                                            () => ParseDataEntry(parseStrings, ref parseError)));

                                        lastDataEntryTime = Utils.GetNumericValue(line, 0);
                                        currentDataStrings = new List<string>((int)_header.SignalElementCount + 1);
                                    }
                                }
                                break;
                        }
                    }
                }
            }
            finally {
                fs?.Dispose();
            }

            Task.WaitAll(parseTasks.ToArray());

            if (!parseError && _dataEntries.Count == _header.EndTimeAsUnixTime - _header.StartTimeAsUnixTime + 2) {
                Console.WriteLine("All signal element states successfully parsed");
                if (startTime != 0 || endTime != uint.MaxValue) {
                    _dataEntries = new ConcurrentDictionary<uint, SignalDataEntry>(
                        _dataEntries.Where(de => de.Key >= startTime && de.Key <= endTime));
                    _header.SetFilteredTimeRange(startTime, endTime);
                    Console.WriteLine($"Data filtered. Start: {Utils.UnixTimeToDateTime(startTime).ToString()} " +
                        $"End: {Utils.UnixTimeToDateTime(endTime).ToString()}");
                }
                _header.Freeze();
//.........这里部分代码省略.........
开发者ID:buttercookie42,项目名称:OPLConverter,代码行数:101,代码来源:OPLParser.cs

示例9: ParseConfigurationFile

        private bool ParseConfigurationFile(string fileName)
        {
            _strikeInType = SignalElement.Type.None;
            _strikeOutType = SignalElement.Type.None;

            _strikeIn = new List<string>();
            _strikeOut = new List<string>();
            _blockedSignals = new List<string>();
            _maxVehicles = 0;
            _timeOut = 0;

            string line;
            FileStream fs = null;

            Phase currentPhase = Phase.none;

            try {
                fs = new FileStream(fileName, FileMode.Open);
                using (TextReader reader = new StreamReader(fs)) {
                    fs = null;

                    while ((line = reader.ReadLine()) != null) {
                        if (String.IsNullOrWhiteSpace(line) || line.StartsWith(";")) {
                            continue;
                        }

                        switch (line) {
                            case "[Strike-in]":
                                currentPhase = Phase.StrikeIn;
                                continue;
                            case "[Strike-out]":
                                currentPhase = Phase.StrikeOut;
                                continue;
                            case "[Signals]":
                                currentPhase = Phase.Signals;
                                continue;
                            case "[MaxVehicles]":
                                currentPhase = Phase.MaxVehicles;
                                continue;
                            case "[Timeout]":
                                currentPhase = Phase.TimeOut;
                                continue;
                            default:
                                if (line.StartsWith("[") && line.EndsWith("]")) {
                                    currentPhase = Phase.none;
                                    continue;
                                }
                                break;
                        }

                        switch (currentPhase) {
                            case Phase.StrikeIn:
                                if (_strikeInType == SignalElement.Type.None) {
                                    uint elementTypeParsedValue = Convert.ToUInt32(line);
                                    if (elementTypeParsedValue != 0 &&
                                        !Enum.IsDefined(typeof(SignalElement.Type), elementTypeParsedValue)) {
                                        return false;
                                    }
                                    _strikeInType = (SignalElement.Type)elementTypeParsedValue;
                                    break;
                                }
                                _strikeIn.Add(line);
                                break;
                            case Phase.StrikeOut:
                                if (_strikeOutType == SignalElement.Type.None) {
                                    uint elementTypeParsedValue = Convert.ToUInt32(line);
                                    if (elementTypeParsedValue != 0 &&
                                        !Enum.IsDefined(typeof(SignalElement.Type), elementTypeParsedValue)) {
                                        return false;
                                    }
                                    _strikeOutType = (SignalElement.Type)elementTypeParsedValue;
                                    break;
                                }
                                _strikeOut.Add(line);
                                break;
                            case Phase.Signals:
                                _blockedSignals.Add(line);
                                break;
                            case Phase.MaxVehicles:
                                _maxVehicles = Convert.ToInt32(line);
                                break;
                            case Phase.TimeOut:
                                _timeOut = Convert.ToInt32(line);
                                break;
                        }

                    }
                }
            }
            finally {
                fs?.Dispose();
            }
            return _strikeInType != SignalElement.Type.None && _strikeIn.Count > 0 &&
                _strikeOutType != SignalElement.Type.None && _strikeOut.Count > 0 &&
                _blockedSignals.Count > 0 && _maxVehicles > 0 && _timeOut > 0;
        }
开发者ID:buttercookie42,项目名称:OPLConverter,代码行数:96,代码来源:BlockingBack.cs

示例10: ParseIntergreenConfig

        private bool ParseIntergreenConfig(string fileName)
        {
            string line;
            FileStream fs = null;
            bool success = false;
            string name = null;
            Dictionary<string, int> newEntries = null;

            string currentSignalGroup = null;

            try {
                fs = new FileStream(fileName, FileMode.Open);
                using (TextReader reader = new StreamReader(fs)) {
                    fs = null;

                    while ((line = reader.ReadLine()) != null) {
                        if (String.IsNullOrWhiteSpace(line) || line.StartsWith(";")) {
                            continue;
                        }

                        if (line.StartsWith("[") && line.EndsWith("]")) {
                            if (newEntries != null) {
                                // New section starts, add the previously parsed values if they exist
                                _intergreenTimes.Add(currentSignalGroup, newEntries);
                            }
                            newEntries = new Dictionary<string, int>();
                            currentSignalGroup = line.Trim(new char[] {'[', ']'});
                            continue;
                        }

                        if (name == null) {
                            name = line;
                        } else {
                            int seconds;
                            if (!Int32.TryParse(line, out seconds)) {
                                return false;
                            }
                            newEntries.Add(name, seconds);
                            success = true;
                            name = null;
                        }
                    }
                    if (newEntries != null) {
                        // End of file, add the previously parsed values if they exist
                        _intergreenTimes.Add(currentSignalGroup, newEntries);
                    }
                }
            }
            finally {
                fs?.Dispose();
            }
            return success;
        }
开发者ID:buttercookie42,项目名称:OPLConverter,代码行数:53,代码来源:Intergreen.cs


注:本文中的System.IO.FileStream.?.Dispose方法示例由纯净天空整理自Github/MSDocs等开源代码及文档管理平台,相关代码片段筛选自各路编程大神贡献的开源项目,源码版权归原作者所有,传播和使用请参考对应项目的License;未经允许,请勿转载。