Sign Up

Sign Up to our social questions and Answers Engine to ask questions, answer people’s questions, and connect with other people.

Have an account? Sign In

Have an account? Sign In Now

Sign In

Login to our social questions & Answers Engine to ask questions answer people’s questions & connect with other people.

Sign Up Here

Forgot Password?

Don't have account, Sign Up Here

Forgot Password

Lost your password? Please enter your email address. You will receive a link and will create a new password via email.

Have an account? Sign In Now

You must login to ask a question.

Forgot Password?

Need An Account, Sign Up Here

Please briefly explain why you feel this question should be reported.

Please briefly explain why you feel this answer should be reported.

Please briefly explain why you feel this user should be reported.

Sign InSign Up

The Archive Base

The Archive Base Logo The Archive Base Logo

The Archive Base Navigation

  • SEARCH
  • Home
  • About Us
  • Blog
  • Contact Us
Search
Ask A Question

Mobile menu

Close
Ask a Question
  • Home
  • Add group
  • Groups page
  • Feed
  • User Profile
  • Communities
  • Questions
    • New Questions
    • Trending Questions
    • Must read Questions
    • Hot Questions
  • Polls
  • Tags
  • Badges
  • Buy Points
  • Users
  • Help
  • Buy Theme
  • SEARCH
Home/ Questions/Q 170297
In Process

The Archive Base Latest Questions

Editorial Team
  • 0
Editorial Team
Asked: May 11, 20262026-05-11T12:47:00+00:00 2026-05-11T12:47:00+00:00

Any suggestions on how to improve this method? I am currently using it to

  • 0

Any suggestions on how to improve this method? I am currently using it to select a single wallpaper from a directory of wallpapers

I know your not supposed to use arraylist anymore but i couldnt think of a altrnative also im not sure how to filter for more than just one type of file (ie jpg gif png) in the directory info.

any suggestions or tweaks would be fantastic

private string getrandomfile(string path)         {             ArrayList al = new ArrayList();             DirectoryInfo di = new DirectoryInfo(path);             FileInfo[] rgFiles = di.GetFiles('*.*');             foreach (FileInfo fi in rgFiles)             {                 al.Add(fi.FullName);             }              Random r = new Random();             int x = r.Next(0,al.Count);              return al[x].ToString();          } 

Thanks

Crash

  • 1 1 Answer
  • 0 Views
  • 0 Followers
  • 0
Share
  • Facebook
  • Report

Leave an answer
Cancel reply

You must login to add an answer.

Forgot Password?

Need An Account, Sign Up Here

1 Answer

  • Voted
  • Oldest
  • Recent
  • Random
  1. 2026-05-11T12:47:00+00:00Added an answer on May 11, 2026 at 12:47 pm

    Changed to use a single instance of the pseudo-random number generator.

    // Use a class variable so that the RNG is only created once. private Random generator; private Random Generator {     get     {         if (this.generator == null)         {            this.generator = new Random();         }         return this.generator;     } } private string getrandomfile(string path) {     string file = null;     if (!string.IsNullOrEmpty(path))     {         var extensions = new string[] { '.png', '.jpg', '.gif' };         try         {             var di = new DirectoryInfo(path);             var rgFiles = di.GetFiles('*.*')                             .Where( f => extensions.Contains( f.Extension                                                                .ToLower() );             int fileCount = rgFiles.Count();             if (fileCount > 0)             {                 int x = this.Generator.Next( 0, fileCount );                 file = rgFiles.ElementAt(x).FullName;             }         }         // probably should only catch specific exceptions         // throwable by the above methods.         catch {}     }     return file; } 
    • 0
    • Reply
    • Share
      Share
      • Share on Facebook
      • Share on Twitter
      • Share on LinkedIn
      • Share on WhatsApp
      • Report

Sidebar

Related Questions

Any suggestions to improve this little piece of code? It works, but there must
I am very new to working with SQL queries. Any suggestions to improve this
Any suggestions on how to improve DataGridViewComboBoxColumn performace with large item sets? I've got
Any suggestions? Using visual studio in C#. Are there any specific tools to use
Any suggestions on the best way to ensure thread safety when changing the properties
Any suggestions for good open source asp.net (C#) apps out there which meet as
Any suggestions on how to write repeatable unit tests for code that may be
Any suggestions for an accurate Web Log analysis tool to generate reports on the
Any suggestions on why a VB6 program would be slower when compiled than when
any suggestions for a C# object pooling framework? requirements are multi-thread support and a

Explore

  • Home
  • Add group
  • Groups page
  • Communities
  • Questions
    • New Questions
    • Trending Questions
    • Must read Questions
    • Hot Questions
  • Polls
  • Tags
  • Badges
  • Users
  • Help
  • SEARCH

Footer

© 2021 The Archive Base. All Rights Reserved
With Love by The Archive Base

Insert/edit link

Enter the destination URL

Or link to existing content

    No search term specified. Showing recent items. Search or use up and down arrow keys to select an item.