Mac App Tasks Images Files

Dec 05, 2019  For most other app types e.g., movies, audio files, text files, and even Plist files, you will set the default app by following the general files method. You can also set a default app on a per-file basis. There’s a built-in option on macOS that lets you do that, and we have a detailed article on how to set it. The default apps can be changed any time you like and the change doesn’t. Aug 06, 2019  Then add them to the relevant action in order to avoid sending files one by one. Price and Platform Compatibility. Dropzone is only available for macOS, and you can download it from Dropzone Website or the Mac App Store. The app costs a flat fee of $10, but offers a limited functionality version for 15 days if you want to try it out.

System cleanup in one click
Make your Mac fast and secure with CleanMyMac X.

A frozen or unresponsive Mac is rare, but Macs aren't immune from some of the same weaknesses as other computers. At one time or another, we've all had documents disappear, programs crash and faced that spinning beachball of dread during a busy working day.

All files are processed using Aspose APIs, which are being used by many Fortune 100 companies across 114 countries. Convert Microsoft Projects to PDF, XLSX, HTML & Images Free Microsoft Project Converter App. Convert Project MPP & XML files to TXT, XML, XER, PDF, XLSX, XPS, HTML, JPG, PNG, BMP, SVG & TIFF formats on any platform.

The best thing you can do is not panic, then follow some simple instructions to get up and running again. If you are finding this is happening more often, maybe it's time to look at long-term solutions. Maybe you've not updated your operating system recently? If that is the case, then a new one comes out soon, with macOS Catalina, now is the time to give your Mac an update.

Stop Your Mac From Freezing

A powerful tools to speed up your Mac and fix keeps freezing issues.

At the same time, you may need to declutter the Mac, removing old files and long-forgotten documents to avoid troublesome Mac freezes.

Why does Mac keep freezing?

Macs are fairly powerful, durable devices. It takes a lot to slow them down, or a simple issue of the Mac running too many programs, apps and browser tabs (all of then use processing power). Like with any computer, when too much is stored and too many apps are fighting for CPU processing power, you're stuck with a spinning wheel and your beloved Mac not responding to clicks and pleas.

Apps crashing are some of the most common reasons behind a Mac freezing. Usually, an app freezing won't crash the whole Mac, but that is a risk when your memory is full, or there are lots of applications running at once.

Here are some of the main reasons Macs freeze most of the time.

Main reasons your Mac is frozen

  • Too many apps running (this affects memory and cpu)
  • Too many background processes (same)
  • App crashed (there's a problem with a single app)
  • Sluggish browser (too many tabs open)
  • Overworked email client (too many attachments)
  • macOS loaded with system junk or needs an update
  • Not enough free hard drive space
  • Hardware problem with your disk or RAM (diagnostics required)
  • Malware (the ones that cause Macs to open multiple windows or draft emails, thus overloading the system)

How to fix a frozen macOS

Let's start with a bit of obvious advice: don't panic, don't do anything you'll regret, don't push every button. In this part we'll go over unfreezing a Mac and preventing issues in the future. Depending on your current trouble, we'll try to determine the core reason and what to do in each case.

First aid: How to unfreeze a Mac

First, you need to bring your Mac back to life. When it's unresponsive - either as a result of an app or the computer is struggle to function — you can either click Restart, from the main menu, or press Command-Control-Power (Eject for keyboards and iMacs) to get it to restart.

HP Easy scan is a specifically designed HP scan software MAC to be used on HP scanners and multifunctional printers. The main features of this software include multi-page document scanning, automatic image detection, PDF file output, and text recognition (OCR). Hp scanner software, free download - HP Precision Scan, HP ScanJet 5300c, WiFi Scanner, and many more programs. On the Mac, open Finder, click Go in the top menu bar, and then click Applications. Double-click the HP folder, and then double-click HP Utility. Note: If you cannot find HP Utility, try scanning with another app or method, such as HP Easy Scan or Scan to Email. Oct 16, 2019  This HP Utility for Mac will help you to monitor and manage your HP printer so that you can get the best out of it. If your HP printer supports wireless and USB then you can select these options from within this the HP printer utility Mac software. The HP Utility is a very useful Mac download. You can also configure your HP scanning devices with the HP Scan Utility Mac functions. From here you can. Apr 08, 2015  Download HP Easy Scan for macOS 10.10 or later and enjoy it on your Mac. ‎HP Easy Scan is designed specifically for use with your HP scanner or multifunction printer. With features such as automatic photo detection, multi-page document processing, text recognition (OCR)1, and PDF file output, HP Easy Scan will help you get the most value from your HP product. Hp utility scan software mac computer.

If neither of those solutions works, then you can hold the power button down which will restart the device. Not an ideal solution, since you can lose anything unsaved, but at least that should restore it to normal.

How to retrieve lost data after the freeze

What if you resurrected your Mac and realized some of the files are missing? Don't worry just yet, install Disk Drill, the world's premier data recovery software for macOS. It was created for the cases when Mac crashed and you lost data and when you accidentally deleted files. Disk Drill is powerful enough to retrieve long-lost, mistakenly deleted files from Macs, external hard drives and USB drives and camera cards. Simply open the app and scan the chosen drive or partition, preview to find exact files you want to restore and restore them.

Now, let's make sure your Mac doesn't make a freeze into a habit.

Most common Mac slow and freeze reasons and fixes

Unresponsive because of a specific app

Apps may running in the background, freeze and crash. Try to determine which apps cause the crash. You start at this: when does the crash happen? If it's when you turn on or work in a specific app, maybe you need to either reset it or remove it entirely.

FIX: To remove apps or set them to back default, use a Mac optimizer app called CleanMyMac, it's has a specific Uninstaller module which can safely perform the task. CleanMyMac is available on Setapp collection and you can use it for free during the trial period.

How to uninstall apps with CleanMyMac:

  1. Find CleanMyMac in Setapp and launch it.
  2. Find Uninstaller tab.
  3. Find the app in question.
  4. Checkmark it and click Uninstall.

To reset an app, repeat the first three items and then right-click on the arrow near the app name and select Application Reset instead. Resetting an app to default settings and cleaning up its cache can help if you're sure you really need the app and you can't afford to simply remove it.

Also, don't forget to check for app's updates, there's a change your problems sprout from an outdated version.

How to force quit a frozen or unresponsive app

When an app freezes, which becomes obvious when an application is unresponsive in the middle of something, or you are shown the spinning beachball of despair, you can Force Quit (either in the app, from the dock or main menu).

Freeze because of a cluttered desktop

A cluttered desktop can seriously slow down your Mac, and can also cause many problems. That is because every icon on your desktop is an image, not just a link, and it's redrawn each time you start your Mac.

FIX: To clean up your desktop, and organize icons and files, try to use Declutter app. What this app does it groups all the files on your desktop into categories by type (or by any other principle you specify) and thus relieves your Mac from the need to draw 100 image-icons each time.

Freeze because of crushing background apps

This is usually when an app has been running without you realizing it. If your Mac freezes on startup than it's probably one of the startup items, apps that launch when your Mac turns on. You'll need to check on them and remove the extras.

FIX: Stop programs from running at startup on Mac: go to Settings > Users and Groups > Login items and uncheck any app that you don't want to launch when switching your Mac on, or restarting it. This way you'll escape weird crashes that render your Mac frozen.

Freeze because too many apps are running at once

How many are too many? Unfortunately, there is no simple answer; but once your Mac seems to struggle running simple tasks, or slows down when you've got multiple tabs or apps open, it's an indication that it is struggling to cope.

FIX: How to check what apps are running on your Mac right now? Open Activity monitor and take a look at the list of apps. Next to each you can see how much RAM and CPU power they eat up. You can switch between CPU and memory tabs to view each. Those that are the heaviest could cause the problem, so if you're sure you know what that app is, you can quit it.

How to close multiple applications on a Mac: in the Activity monitor, simply select and press the X mark in the top left corner. This will force quit the app. Resort to this only if your app is entirely unresponsive, otherwise use the menu in the top bar with the app's name, next to the apple icon. For instance Chrome > Quit Google Chrome.

In the same way you can manage processes on Mac. Rows without icons are processes. There are system ones and user-generated processes. Don't rush to quit any process before reading a little about it on Google. It might be important.

Freeze because there's no space on hard drive

An overloaded drive can be the reason your Mac fails to work properly and freezes or nearly-freezes. You can check if it's the problem by clicking the Apple icon > About this Mac > Storage. If there's not too many GB left on the free side of your disk, time to clean up.

The easy way to get rid of extra files and give your system a polish is to use CleanMyMac. It's cleaning module is everything you want from a good app: it has a one-click solution and a bunch of semi-automated options for picking out and removing large old files.

To clean your hard drive with CleanMyMac:

  1. Open CleanMyMac.
  2. Choose the Smart Scan in the left side
  3. Click Scan.
  4. Hit Run.


If you take a few moments to carefully clean up Large and Old files, you'll be gigabytes and gigabytes out, you can't imagine how much garbage hangs in there. From personal experience, it takes about half a year to clutter a Mac with random stuff.

  1. Click Large & Old Files and click Scan.
  2. Find what you'd like to remove in there.
  3. Hit Remove.

Now, here are a few other app suggestions to free up more space.

Gemini — removes duplicated images and similar photos.

Dropshare — lets you quickly move files into the cloud.

When Mac freezes but mouse still moves

App

A rare case that can signal two things: your Mac is nevertheless locked up and regular solutions fit (restart, check Activity monitor, find problematic apps, clean hard drive)or there's a hardware problem.

There's a way you can check if the latter is the case without taking your Mac to a service store. Install iStat Menus and use its indicators to see if there's an ongoing problem with your drives or battery. Pay attention to the CPU temperature and battery life in particular.

Another way to diagnose your Mac would be to run a specific hardware test administered by Apple itself.

Here's how to run Apple Hardware Test

Preparation: disconnect all external devices except keyboard, mouse, display, and power connection. Put your Mac on a table or anything flat (a soft bed would be a poor choice).

  1. Shut down the Mac.
  2. When turning back on, immediately press and hold the D key until you see the Test icon.
  3. Select language and click the right arrow or press the Return key.
  4. Click the Test button to begin. You can also press T or Return.
  5. Upon completion, take a look at the lower part of the window and study the results.
  6. To quit, hit Restart or Shut Down at the bottom.

How to avoid a Mac freezing

When a Mac freezes, those solutions are reactive, and while you are going to be up and running again soon, you should think about fixes that will help you avoid crashes in the future.

CleanMyMac is one way to cleanup an untidy Mac. Other apps worth installing from Setapp collection include iStat Menus we mentioned before, a handy app that will quickly identify what is absorbing so much CPU processing power and advise those applications are closed. Unlike Activity Menu, iStat Menus providers users with even more useful data, and is available through Setapp, along with hundreds of other apps for Mac customers, all for one convenient price. Remember to pay attention to CPU temperature as a key potential indicator of an upcoming freeze. When it's too high, quit apps and processes that take too much of its power.

That's about it on the matter of freezing Macs, we hope this article has been of help. Every app we mentioned is available on Setapp, an app collection by subscription. More than a hundred ultra-useful tools for all kinds of Mac maintenance, lifestyle, and work tasks. Sign up to try it.

These might also interest you:


A file system handles the persistent storage of data files, apps, and the files associated with the operating system itself. Therefore, the file system is one of the fundamental resources used by all processes.

APFS is the default file system in macOS, iOS, watchOS, and tvOS. APFS replaces HFS+ as the default file system for iOS 10.3 and later, and macOS High Sierra and later. macOS additionally supports a variety of other formats, as described in Supported File Systems.

Regardless of the underlying format, all of the disks attached to the device—whether they are physically plugged in or are connected indirectly through the network—contribute space to create a single collection of files. Because the number of files can easily be many millions, the file system uses directories to create a hierarchical organization. Although the basic directory structures are similar for iOS and macOS, there are differences in the way each system organizes apps and user data.

Before you begin writing code that interacts with the file system, you should first understand a little about the organization of file system and the rules that apply to your code. Aside from the basic tenet that you cannot write files to directories for which you do not have appropriate security privileges, apps are also expected to be good citizens and put files in appropriate places. Precisely where you put files depends on the platform, but the overarching goal is to make sure that the user’s files remain easily discoverable and that the files your code uses internally are kept out of the user’s way.

About the iOS File System

The iOS file system is geared toward apps running on their own. To keep the system simple, users of iOS devices do not have direct access to the file system and apps are expected to follow this convention.

iOS Standard Directories: Where Files Reside

For security purposes, an iOS app’s interactions with the file system are limited to the directories inside the app’s sandbox directory. During installation of a new app, the installer creates a number of container directories for the app inside the sandbox directory. Each container directory has a specific role. The bundle container directory holds the app’s bundle, whereas the data container directory holds data for both the app and the user. The data container directory is further divided into a number of subdirectories that the app can use to sort and organize its data. The app may also request access to additional container directories—for example, the iCloud container—at runtime.

These container directories constitute the app’s primary view of the file system. Figure 1-1 shows a representation of the sandbox directory for an app.

An app is generally prohibited from accessing or creating files outside its container directories. One exception to this rule is when an app uses public system interfaces to access things such as the user’s contacts or music. In those cases, the system frameworks use helper apps to handle any file-related operations needed to read from or modify the appropriate data stores.

Table 1-1 lists some of the more important subdirectories inside the sandbox directory and describes their intended usage. This table also describes any additional access restrictions for each subdirectory and points out whether the directory’s contents are backed up by iTunes and iCloud.

Table 1-1 Commonly used directories of an iOS app

Directory

Description

AppName.app

This is the app’s bundle. This directory contains the app and all of its resources.

You cannot write to this directory. To prevent tampering, the bundle directory is signed at installation time. Writing to this directory changes the signature and prevents your app from launching. You can, however, gain read-only access to any resources stored in the apps bundle. For more information, see the Resource Programming Guide

The contents of this directory are not backed up by iTunes or iCloud. However, iTunes does perform an initial sync of any apps purchased from the App Store.

Documents/

Use this directory to store user-generated content. The contents of this directory can be made available to the user through file sharing; therefore, this directory should only contain files that you may wish to expose to the user.

The contents of this directory are backed up by iTunes and iCloud.

Documents/Inbox

Use this directory to access files that your app was asked to open by outside entities. Specifically, the Mail program places email attachments associated with your app in this directory. Document interaction controllers may also place files in it.

Your app can read and delete files in this directory but cannot create new files or write to existing files. If the user tries to edit a file in this directory, your app must silently move it out of the directory before making any changes.

The contents of this directory are backed up by iTunes and iCloud.

Library/

This is the top-level directory for any files that are not user data files. You typically put files in one of several standard subdirectories. iOS apps commonly use the Application Support and Caches subdirectories; however, you can create custom subdirectories.

Use the Library subdirectories for any files you don’t want exposed to the user. Your app should not use these directories for user data files.

The contents of the Library directory (with the exception of the Caches subdirectory) are backed up by iTunes and iCloud.

For additional information about the Library directory and its commonly used subdirectories, see The Library Directory Stores App-Specific Files.

tmp/

Use this directory to write temporary files that do not need to persist between launches of your app. Your app should remove files from this directory when they are no longer needed; however, the system may purge this directory when your app is not running.

The contents of this directory are not backed up by iTunes or iCloud.

An iOS app may create additional directories in the Documents, Library, and tmp directories. You might do this to better organize the files in those locations.

App

For information about how to get references to the preceding directories from your iOS app, see Locating Items in the Standard Directories. For tips on where to put files, see Where You Should Put Your App’s Files.

Where You Should Put Your App’s Files

To prevent the syncing and backup processes on iOS devices from taking a long time, be selective about where you place files. Apps that store large files can slow down the process of backing up to iTunes or iCloud. These apps can also consume a large amount of a user's available storage, which may encourage the user to delete the app or disable backup of that app's data to iCloud. With this in mind, you should store app data according to the following guidelines:

  • Put user data in Documents/. User data generally includes any files you might want to expose to the user—anything you might want the user to create, import, delete or edit. For a drawing app, user data includes any graphic files the user might create. For a text editor, it includes the text files. Video and audio apps may even include files that the user has downloaded to watch or listen to later.

  • Put app-created support files in the Library/Application support/ directory. In general, this directory includes files that the app uses to run but that should remain hidden from the user. This directory can also include data files, configuration files, templates and modified versions of resources loaded from the app bundle.

  • Remember that files in Documents/ and Application Support/ are backed up by default. You can exclude files from the backup by calling -[NSURL setResourceValue:forKey:error:] using the NSURLIsExcludedFromBackupKey key. Any file that can be re-created or downloaded must be excluded from the backup. This is particularly important for large media files. If your application downloads video or audio files, make sure they are not included in the backup.

  • Put temporary data in the tmp/ directory. Temporary data comprises any data that you do not need to persist for an extended period of time. Remember to delete those files when you are done with them so that they do not continue to consume space on the user’s device. The system will periodically purge these files when your app is not running; therefore, you cannot rely on these files persisting after your app terminates.

  • Put data cache files in the Library/Caches/ directory. Cache data can be used for any data that needs to persist longer than temporary data, but not as long as a support file. Generally speaking, the application does not require cache data to operate properly, but it can use cache data to improve performance. Examples of cache data include (but are not limited to) database cache files and transient, downloadable content. Note that the system may delete the Caches/ directory to free up disk space, so your app must be able to re-create or download these files as needed.

About the macOS File System

The macOS file system is designed for Mac computers, where both users and software have access to the file system. Users access the file system directly through the Finder, which presents a user-oriented view of the file system by hiding or renaming some files and directories. Apps access the file system using the system interfaces, which show the complete file system precisely as it appears on disk.

Domains Determine the Placement of Files

In macOS, the file system is divided into multiple domains, which separate files and resources based on their intended usage. This separation provides simplicity for the user, who only needs to worry about a specific subset of files. Download app on iphone from mac wirelessly. Arranging files by domain also lets the system apply blanket access privileges to files in that domain, preventing unauthorized users from changing files intentionally or inadvertently.

  • The user domain contains resources specific to the users who log in to the system. Although it technically encompasses all users, this domain reflects only the home directory of the current user at runtime. User home directories can reside on the computer’s boot volume (in the /Users directory) or on a network volume. Each user (regardless of privileges) has access to and control over the files in their own home directory.

  • The local domain contains resources such as apps that are local to the current computer and shared among all users of that computer. The local domain does not correspond to a single physical directory, but instead consists of several directories on the local boot (and root) volume. This domain is typically managed by the system, but users with administrative privileges may add, remove, or modify items in this domain.

  • The network domain contains resources such as apps and documents that are shared among all users of a local area network. Items in this domain are typically located on network file servers and are under the control of a network administrator.

  • The system domain contains the system software installed by Apple. The resources in the system domain are required by the system to run. Users cannot add, remove, or alter items in this domain.

Figure 1-2 shows how the local, system, and user domains map to the local file system of a macOS installation. (The network domain is not shown but is similar in many ways to the local domain.) This figure shows the visible directories that the user might see. Depending on the user’s system, other directories may be visible or some of the ones shown here may be hidden.

For information about the contents of the directories in macOS, see macOS Standard Directories: Where Files Reside. For information about the directories that macOS normally hides from the user (and why), see Hidden Files and Directories: Simplifying the User Experience.

macOS Standard Directories: Where Files Reside

Whether provided by the system or created by your app, every file has its place in macOS. Table 1-2 lists some of the top-level directories in a macOS installation and the types of content that each one contains.

Table 1-2 Commonly used directories in macOS

Directory

Usage

/Applications

This directory is where you install apps intended for use by all users of a computer. The App Store installs apps purchased by the user in this directory automatically.

The Utilities subdirectory contains a subset of apps that are intended for use in managing the local system.

This directory is part of the local domain.

Library

There are multiple Library directories on the system, each one associated with a different domain or specific user. Apps should use the Library directory to store app-specific (or system-specific) resources.

For detailed information about the contents of this directory and how you use it to support your apps, see The Library Directory Stores App-Specific Files.

/Network

This directory contains the list of computers in the local area network.

There is no guarantee that files located on network file servers will have the /Network directory at the beginning of their path. Path names vary depending on several factors, including how the network volume was mounted. For example, if the user uses the Connect to Server command to mount a volume, paths begin with the /Volumes directory. When writing code, assume that files on any volume other than the boot volume could be located on a network-based server.

/System

This directory contains the system resources required by macOS to run. These resources are provided by Apple and must not be modified.

This directory comprises the contents of the system domain.

/Users

This directory contains one or more user home directories. The user home directory is where user-related files are stored. A typical user’s home directory includes the following subdirectories:

  • Applications—Contains user-specific apps.

  • Desktop—Contains the items on the user’s desktop.

  • Documents—Contains user documents and files.

  • Downloads—Contains files downloaded from the Internet.

  • Library—Contains user-specific app files (hidden in macOS 10.7 and later).

  • Movies—Contains the user’s video files.

  • Music—Contains the user’s music files.

  • Pictures—Contains the user’s photos.

  • Public—Contains content the user wants to share.

  • Sites—Contains web pages used by the user’s personal site. (Web Sharing must be enabled to display these pages.)

The preceding directories are for storing user documents and media only. Apps must not write files to the preceding directories unless explicitly directed to do so by the user. The sole exception to this rule is the Library directory, which apps may use to store data files needed to support the current user.

Of the subdirectories, only the Public directory is accessible by other users on the system. Access to the other directories is restricted by default.

Important: The files in the user’s Documents and Desktop directories should reflect only the documents that the user created and works with directly. Similarly, the media directories should contain only the user’s media files. Those directories must never be used to store data files that your app creates and manages automatically. If you need a place to store automatically generated files, use the Library directory, which is designated specifically for that purpose. For information on where to put files in the Library directory, see The Library Directory Stores App-Specific Files.

Although the directories in Table 1-2 are the ones seen by macOS users, they are not the only directories present in the file system. macOS hides many directories to prevent users from accessing files that they don’t need to.

Sandboxed macOS App File Containers

macOS apps that are sandboxed have all their Application Support, Cache, temporary directories and other related documents stored within a directory located at a system-defined path that you can obtain by calling the NSHomeDirectory function.

For more information, see App Sandbox Design Guide.

Hidden Files and Directories: Simplifying the User Experience

To simplify the experience for users, the Finder, and some specific user-facing interfaces (such as the Open and Save panels), hide many files and directories that the user should never have to use. Many of the hidden items are system- or app-specific resources that users cannot (or should not) access directly. Among the files and directories that are hidden are the following:

  • Dot directories and files. Any file or directory whose name starts with a period (.) character is hidden automatically. This convention is taken from UNIX, which used it to hide system scripts and other special types of files and directories. Two special directories in this category are the . and . directories, which are references to the current and parent directories respectively.

  • UNIX-specific directories. The directories in this category are inherited from traditional UNIX installations. They are an important part of the system’s BSD layer but are more useful to software developers than end users. Some of the more important directories that are hidden include:

    • /bin—Contains essential command-line binaries. Typically, you execute these binaries from command-line scripts.

    • /dev—Contains essential device files, such as mount points for attached hardware.

    • /etc—Contains host-specific configuration files.

    • /sbin—Contains essential system binaries.

    • /tmp—Contains temporary files created by apps and the system.

    • /usr—Contains non-essential command-line binaries, libraries, header files, and other data.

    • /var—Contains log files and other files whose content is variable. (Log files are typically viewed using the Console app.)

  • Explicitly hidden files and directories. The Finder may hide specific files or directories that should not be accessed directly by the user. The most notable example of this is the /Volumes directory, which contains a subdirectory for each mounted disk in the local file system from the command line. (The Finder provides a different user interface for accessing local disks.) In macOS 10.7 and later, the Finder also hides the ~/Library directory—that is, the Library directory located in the user’s home directory.

  • Packages and bundles. Packages and bundles are directories that the Finder presents to the user as if they were files. Bundles hide the internal workings of executables such as apps and just present a single entity that can be moved around the file system easily. Similarly, packages allow apps to implement complex document formats consisting of multiple individual files while still presenting what appears to be a single document to the user.

Although the Finder and other system interfaces hide files and directories from the user, Cocoa interfaces such as NSFileManager do not filter out files or directories that are normally invisible to users. Thus, code that uses these interfaces theoretically has a complete view of the file system and its contents. (Of course, a process really has access to only those files and directories for which it has appropriate permissions.)

Files and Directories Can Have Alternate Names

In some situations, the Finder presents users with file or directory names that do not match the actual names as they appear in the file system. These names are known as display names and are used only by the Finder and specific system components (such as the Open and Save panels) when presenting file and directory information to the user. Display names improve the user experience by presenting the user with content in a more friendly way. For example, macOS uses display names in the following situations:

  • Localized names. The system provides localized names for many system directories, such as Applications, Library, Music, Movies. An app may similarly provide localized names for itself and for any directories it creates.

  • Filename extension hiding. The system hides filename extensions for all files by default. The user may change option, but when filename extension hiding is in effect, the characters after the last period in a filename (and the period itself) are not displayed.

Display names do not affect the actual name of the file in the file system. Code that accesses a file or directory programmatically must specify the item’s actual name when opening or manipulating the item using the file system interfaces. The only time your app should ever use display names is when displaying the name of a file or directory to the user. You can get the display name for any file or directory using the displayNameAtPath: method of NSFileManager.

Important: Your code should not allow users to modify display names directly. When you want the user to specify the name of a file, use a Save panel.

For information on how to localize the directories your app creates, see File System Advanced Programming Topics. For more information about localizing app content, see Internationalization and Localization Guide.

The Library Directory Stores App-Specific Files

The Library directory is where apps and other code modules store their custom data files. Regardless of whether you are writing code for iOS or macOS, understanding the structure of the Library directory is important. You use this directory to store data files, caches, resources, preferences, and even user data in some specific situations.

There are several Library directories throughout the system but only a few that your code should ever need to access:

  • Library in the current home directory—This is the version of the directory you use the most because it is the one that contains all user-specific files. In iOS, Library is placed inside the apps data bundle. In macOS, it is the app’s sandbox directory or the current user’s home directory (if the app is not in a sandbox).

  • /Library (macOS only)—Apps that share resources between users store those resources in this version of the Library directory. Sandboxed apps are not permitted to use this directory.

  • /System/Library (macOS only)—This directory is reserved for use by Apple.

After selecting which version of the Library directory to use, you still need to know where to store your files. The Library directory itself contains several subdirectories that subdivide app-specific content into a few well-known categories. Table 1-3 lists the most common subdirectories that you might use. Although Library directories in macOS contain many more subdirectories than the ones listed, most are used only by the system. If you want a more complete list of subdirectories, though, see macOS Library Directory Details.

Table 1-3 Key subdirectories of the Library directory

Directory

Usage

Application Support

Use this directory to store all app data files except those associated with the user’s documents. For example, you might use this directory to store app-created data files, configuration files, templates, or other fixed or modifiable resources that are managed by the app. An app might use this directory to store a modifiable copy of resources contained initially in the app’s bundle. A game might use this directory to store new levels purchased by the user and downloaded from a server.

All content in this directory should be placed in a custom subdirectory whose name is that of your app’s bundle identifier or your company.

In iOS, the contents of this directory are backed up by iTunes and iCloud.

Caches

Use this directory to write any app-specific support files that your app can re-create easily. Your app is generally responsible for managing the contents of this directory and for adding and deleting files as needed.

In iOS 2.2 and later, the contents of this directory are not backed up by iTunes or iCloud. In addition, the system removes files in this directory during a full restoration of the device.

In iOS 5.0 and later, the system may delete the Caches directory on rare occasions when the system is very low on disk space. This will never occur while an app is running. However, be aware that restoring from backup is not necessarily the only condition under which the Caches directory can be erased.

Frameworks

In macOS, frameworks that must be shared by multiple apps can be installed in either the local or user domain. The Frameworks directory in the system domain stores the frameworks you use to create your macOS apps.

In iOS, apps cannot install custom frameworks.

Preferences

This directory contains app-specific preference files. You should not create files in this directory yourself. Instead, use the NSUserDefaults class or CFPreferences API to get and set preference values for your app.

In iOS, the contents of this directory are backed up by iTunes and iCloud.

The iCloud File Storage Container

iCloud provides a structured system for storing files for apps that make use of iCloud:

  • Apps have a primary iCloud container directory for storing their native files. They can also access secondary iCloud container directories listed in their app entitlements.

  • Inside each container directory, files are segregated into 'documents' and data. Every file or file package located in the Documents subdirectory (or one of its subdirectories) is presented to the user (via the iCloud UI in macOS and iOS) as a separate document that can be deleted individually. Anything not in Documents or one of its subdirectories is treated as data and shown as a single entry in the iCloud UI.

Documents that the user creates and sees in an app's user interface—for example the document browsers in Pages, Numbers, and Keynote should be stored in the Documents directory. Another example of files that might go in the Documents directory are saved games, again because they are something that an app could potentially provide some sort of method for selecting.

Anything that the app does not want the user to see or modify directly should be placed outside of the Documents directory. Apps can create any subdirectories inside the container directory, so they can arrange private files as desired.

Apps create files and directories in iCloud container directories in exactly the same way as they create local files and directories. And all the file’s attributes are saved, if they add extended attributes to a file, those attributes are copied to iCloud and to the user's other devices too.

iCloud containers also allow the storage of key-value pairs that can be easily accessed without having to create a document format.

How the System Identifies the Type of Content in a File

There are two primary techniques for identifying the type of content in a file:

Mac Disk Image File

  • Uniform Type Identifiers (UTIs)

  • Filename extensions

A uniform type identifier is a string that uniquely identifies a class of entities considered to have a “type.” UTIs provide consistent identifiers for data that all apps and services can recognize and rely upon. They are also more flexible than most other techniques because you can use them to represent any type of data, not just files and directories. Examples of UTIs include:

  • public.text—A public type that identifies text data.

  • public.jpeg—A public type that identifies JPEG image data.

  • com.apple.bundle—An Apple type that identifies a bundle directory.

  • com.apple.application-bundle—An Apple type that identifies a bundled app.

Whenever a UTI-based interface is available for specifying file types, you should prefer that interface over any others. Many macOS interfaces allow you to specify UTIs corresponding to the files or directories you want to work with. For example, in the Open panel, you can use UTIs as file filters and limit the types of files the user selects to ones your app can handle. Several AppKit classes, including NSDocument, NSPasteboard, and NSImage, support UTIs. In iOS, UTIs are used to specify pasteboard types only.

One way the system determines the UTI for a given file is by looking at its filename extension. A filename extension is a string of characters appended to the end of a file and separated from the main filename with a period. Each unique string of characters identifies a file of a specific type. For example, the .strings extension identifies a resource file with localizable string data while the .png extension identifies a file with image data in the portable network graphics format.

Note: Because period characters are valid characters in macOS and iOS filenames, only the characters after the last period in a filename are considered part of the filename extension. Everything to the left of the last period is considered part of the filename itself.

If your app defines custom file formats, you should register those formats and any associated filename extensions in your app’s Info.plist file. The CFBundleDocumentTypes key specifies the file formats that your app recognizes and is able to open. Entries for any custom file formats should include both a filename extension and UTI corresponding to the file contents. The system uses that information to direct files with the appropriate type to your app.

For more information about UTIs and how you use them, see Uniform Type Identifiers Overview. For more information about the CFBundleDocumentTypes key, see Information Property List Key Reference.

Security: Protect the Files You Create

Because all user data and system code are stored on disk somewhere, protecting the integrity of files and the file system is an important job. For that reason, there are several ways to secure content and prevent it from being stolen or damaged by other processes.

For general information about secure coding practices when working with files, see Secure Coding Guide.

Sandboxes Limit the Spread of Damage

In iOS and in macOS 10.7 and later, sandboxes prevent apps from writing to parts of the file system that they should not write to. Each sandboxed app receives one or more containers that it can write into. An app cannot write to other apps’ containers or to most directories outside of the sandbox. These restrictions limit the potential damage that can be done in the event that an app’s security is breached.

Apps To Open Files

Developers writing apps for macOS 10.7 and later are encouraged to put their apps in sandboxes to enhance security. Developers of iOS apps do not have to explicitly put their app in a sandbox because the system does it for them automatically at install time.

For more information about sandboxes and the types of restrictions they impose on file system access, see Mac App Programming Guide and App Sandbox Design Guide.

Permissions and Access Control Lists Govern All Access to Files

Access to files and directories is governed by a mixture of access control lists (ACLs) and BSD permissions. Access control lists are a set of fine-grained controls that define exactly what can and cannot be done to a file or directory and by whom. With access control lists, you can grant individual users different levels of access to a given file or directory. By contrast, BSD permissions only allow you to give access to three classes of users: the file’s owner, a single group of users that you specify, and all users. See Security Overview for more information.

Note: For a file on a network server, do not make any assumptions about the ACLs and BSD permissions associated with the file. Some network file systems provide only a summarized version of this information.

Because iOS apps always run in a sandbox, the system assigns specific ACLs and permissions to files created by each app. However, macOS apps can use Identity Services to manage access control lists for files to which they have access. For information about how to use Identity Services (and the Collaboration framework), see Identity Services Programming Guide.

Files Can Be Encrypted On Disk

Both macOS and iOS provide support for encrypting files on disk:

  • iOS. An iOS app can designate files that it wants to be encrypted on disk. When the user unlocks a device containing encrypted files, the system creates a decryption key that allows the app to access its encrypted files. When the user locks the device, though, the decryption key is destroyed to prevent unauthorized access to the files.

  • macOS. Users can encrypt the contents of a volume using the Disk Utility app. (They can also encrypt just the boot volume from the Security & Privacy system preference.) The contents of an encrypted disk are available to apps only while the computer is running. When the user puts the computer to sleep or shuts it down, the decryption keys are destroyed to prevent unauthorized access to the disk’s contents.

In iOS, apps that take advantage of disk-based encryption need to be discontinue the use of encrypted files when the user locks the device. Because locking the device destroys the decryption keys, access to encrypted files is limited to when the device is unlocked. If your iOS app can run in the background while the device is locked, it must do so without access to any of its encrypted files. Because encrypted disks in macOS are always accessible while the computer is running, macOS apps do not need to do anything special to handle disk-level encryption.

For more information about working with encrypted files in iOS, see App Programming Guide for iOS.

Synchronization Ensures Robustness in Your File-Related Code

The file system is a resource shared by third-party apps and system apps. Because multiple apps are able to access files and directories at the same time, the potential arises for one app to make changes that render a second app’s view of the file system obsolete. If the second app is not prepared to handle such changes, it could enter an unknown state or even crash. In cases where your app relies on the presence of specific files, you can use synchronization interfaces to be notified of changes to those files.

File system synchronization is primarily an issue in macOS, where the user can manipulate files directly with the Finder or with any number of other apps at the same time. Fortunately, macOS provides the following interfaces to help with synchronization issues:

  • File coordinators. In macOS 10.7 and later, file coordinators are a way to incorporate fine-grained synchronization support directly into the objects of your app; see The Role of File Coordinators and Presenters.

  • FSEvents. In macOS 10.5 and later, file system events allow you to monitor changes to a directory or its contents; see File System Events Programming Guide.

Files, Concurrency, and Thread Safety

Mac apps download

Because file-related operations involve interacting with the hard disk and are therefore slow compared to most other operations, most of the file-related interfaces in iOS and macOS are designed with concurrency in mind. Several technologies incorporate asynchronous operation into their design and most others can execute safely from a dispatch queue or secondary thread. Table 1-4 lists some of the key technologies discussed in this document and whether they are safe to use from specific threads or any thread. For specific information about the capabilities of any interface, see the reference documentation for that interface.

Table 1-4 Thread safety of key classes and technologies

Class/Technology

Notes

For most tasks, it is safe to use the default NSFileManager object simultaneously from multiple background threads. The only exception to this rule is tasks that interact with the file manager’s delegate. When using a file manager object with a delegate, it is recommended that you create a unique instance of the NSFileManager class and use your delegate with that instance. You should then use your unique instance from one thread at a time.

Grand Central Dispatch

GCD itself is safe to use from any thread. However, you are still responsible for writing your blocks in a way that is thread safe.

NSFileHandle, NSData, Cocoa streams

Most of the Foundation objects you use to read and write file data can be used from any single thread but should not be used from multiple threads simultaneously.

Open and Save panels

Because they are part of your user interface, you should always present and manipulate the Open and Save panels from your app’s main thread.

POSIX routines

The POSIX routines for manipulating files are generally designed to operate safely from any thread. For details, see the corresponding man pages.

NSURL and NSString

The immutable objects you use to specify paths are safe to use from any thread. Because they are immutable, you can also refer to them from multiple threads simultaneously. Of course, the mutable versions of these objects should be used from only one thread at a time.

NSEnumerator and its subclasses

Enumerator objects are safe to use from any single thread but should not be used from multiple threads simultaneously.

Even if you use an thread-safe interface for manipulating a file, problems can still arise when multiple threads or multiple processes attempt to act on the same file. Although there are safeguards to prevent multiple clients from modifying a file at the same time, those safeguards do not always guarantee exclusive access to the file at all times. (Nor should you attempt to prevent other processes from accessing shared files.) To make sure your code knows about changes made to shared files, use file coordinators to manage access to those files. For more information about file coordinators, see The Role of File Coordinators and Presenters

Mac Apps Download


Mac Task Manager


Mac App Tasks Images Files Windows 10

Copyright © 2018 Apple Inc. All Rights Reserved. Terms of Use | Privacy Policy | Updated: 2018-04-09