|
|
|
|
|
|
| |
| |
|
|
|
|
| |
| |
|
|
Darren New wrote:
> Patrick Elliott wrote:
>> Simplest answer is, it behaved that way in 3.11, when it was "even
>> more critical",
>
> Huh? Did MS make a defragmenter for Win3.11? I thought it was just the
> dos defrag? All the third-party defrags I remember using did a fine job
> of defragmenting absolutely everything.
>
There is a relevant difference between DOS Defrag and a Windows one,
back when Win3.11 "was" basically just DOS with a GUI? lol
>> and MS never bothered to steal the idea of fixing it from the few
>> companies whose products **did** do it. ;)
>
> Cite? Certainly the XP defragmenter moves files around to open up free
> spaces. I suspect it's just files that have absolute addresses in them,
> like the UNC and system restore points.
>
Hmm. Nope. I had the *identical* issue with 95 and 98. You may be partly
correct, to some extent, in that "often" the virtual memory file gets
fragmented to hell too, and the defrag can't move those (unlike Norton
used to in 3.11->98). So, if "that" file gets hacked up into small bits,
the defragger will "never" fix them. Running it "over and over and over"
under 95/98 could get it to "partly" fix some of the gaps, but at some
point it would just flat out refuse to move anything else around, so you
had empty spots between them, no matter how many times it ran. MS Defrag
has "never" changed or improved this behavior in "any" release.
--
void main () {
If Schrödingers_cat is alive or version > 98 {
if version = "Vista" {
call slow_by_half();
call DRM_everything();
}
call functional_code();
}
else
call crash_windows();
}
<A HREF='http://www.daz3d.com/index.php?refid=16130551'>Get 3D Models,
3D Content, and 3D Software at DAZ3D!</A>
Post a reply to this message
|
|
| |
| |
|
|
|
|
| |
| |
|
|
Patrick Elliott wrote:
> There is a relevant difference between DOS Defrag and a Windows one,
> back when Win3.11 "was" basically just DOS with a GUI? lol
Yes, lol. Because you ran the defrag under DOS, nothing else ran at the same
time, lol.
>>> and MS never bothered to steal the idea of fixing it from the few
>>> companies whose products **did** do it. ;)
>>
>> Cite? Certainly the XP defragmenter moves files around to open up
>> free spaces.
>>
> Hmm. Nope.
OK. I guess you don't know what "cite" means. :-)
--
Darren New, San Diego CA, USA (PST)
There's no CD like OCD, there's no CD I knoooow!
Post a reply to this message
|
|
| |
| |
|
|
|
|
| |
| |
|
|
Warp wrote:
> Darren New <dne### [at] sanrrcom> wrote:
>> Everyone uses the same API. If there's a reason the files can't be moved, no
>> program is going to be able to move them.
>
> MyDefrag was able to move those strange clusters, even though it uses the
> regular defragmenter system API to do so...
>
Ah, but see... They used it in a "non-standard" way. In all likelihood,
with Win7 they will release a new .DEFRAG API, which ***accidentally***
breaks this non-standard method, while offering some crazy ass
alternative, like using another drive to "automatically" tranfer files,
temporarily, so they are defragged when copied back (will only work if
you have multiple drives/partitions), kind of like how they provides
some new ways in .NET to "fake" access to the old IUNKNOWN functions in
the ActiveX API, which where never properly documented, and couldn't be
used easily, thereby letting you hot-load new .NET objects, and allow
your application to use them without "hard coding" the interfaces into
your application before hand, but which also, even more completely,
prevents you using them in the "design mode" that is only available to
you when "building" an interface in Visual Studio.
See, there are plenty of documents that, and I love this, tell you how
to "make" controls that "respond to" design mode, so you can better
handle them in Visual Studio, but... gods forbid someone wants to make
an application of their own that took advantage of that feature, so you
could "design" an interface, and say.. save it to a layout document, to
be reloaded later, when actually using the new interface. Your only
"allowed" to do that via the Visual Studio. And now, you can't even
"try" to do it without that, because the new .NET buries the interfaces
and APIs needed to even attempt it under 50 new layers of BS (while
giving you half of what you wanted in the first place).
So, basically, figure that if this is a feature people will want, its
something MS will provide "half" of the function for in the new API,
while simultaneously making it completely impossible to use the new API
to get "all" of the functionality any more. ;) lol
--
void main () {
if version = "Vista" {
call slow_by_half();
call DRM_everything();
}
call functional_code();
}
else
call crash_windows();
}
<A HREF='http://www.daz3d.com/index.php?refid=16130551'>Get 3D Models,
3D Content, and 3D Software at DAZ3D!</A>
Post a reply to this message
|
|
| |
| |
|
|
|
|
| |
| |
|
|
Darren New wrote:
> Patrick Elliott wrote:
>> There is a relevant difference between DOS Defrag and a Windows one,
>> back when Win3.11 "was" basically just DOS with a GUI? lol
>
> Yes, lol. Because you ran the defrag under DOS, nothing else ran at the
> same time, lol.
>
>>>> and MS never bothered to steal the idea of fixing it from the few
>>>> companies whose products **did** do it. ;)
>>>
>>> Cite? Certainly the XP defragmenter moves files around to open up
>>> free spaces.
>> Hmm. Nope.
>
> OK. I guess you don't know what "cite" means. :-)
>
You want me to what? Find a web page written by someone even more
annoyed by the behavior than I am to give a jaded statement to the same
effect? lol Seriously though, I don't dispute that it "does" move things
around. What it doesn't do is "move them if it doesn't see any reason
to, and consolidating free space isn't always, apparently, a 'reason'".
And it flat out refuses to move things that it "could", if the bothered
to put in some way to copy a block of an "in use" file, and.. well do
the stuff that defraggers do to every other file anyway. I mean, can you
seriously tell me that they couldn't come up with "some" way to be able
to, I don't know, write a block of memory to some other part of the
virtual file, then invalidate the part being moved, then revert again
when done, or "something"?
And, the idea that DOS based defraggers where the only ones in 3.11
isn't "entirely" accurate. The Norton one came up during 3.11, and it
"did" defrag "everything", at that time, including the virtual memory
file, and just about anything and everything else "except" for a small
handful of active files in the OS. Say, 90% of all the stuff that no
defragger today will even touch, for the most part.
--
void main () {
If Schrödingers_cat is alive or version > 98 {
if version = "Vista" {
call slow_by_half();
call DRM_everything();
}
call functional_code();
}
else
call crash_windows();
}
<A HREF='http://www.daz3d.com/index.php?refid=16130551'>Get 3D Models,
3D Content, and 3D Software at DAZ3D!</A>
Post a reply to this message
|
|
| |
| |
|
|
|
|
| |
| |
|
|
Patrick Elliott wrote:
> You want me to what? Find a web page written by someone even more
> annoyed by the behavior than I am to give a jaded statement to the same
> effect?
I rest my case.
> Seriously though, I don't dispute that it "does" move things
> around. What it doesn't do is "move them if it doesn't see any reason
> to, and consolidating free space isn't always, apparently, a 'reason'".
The XP defragger usually consolodated much free space for me. Not 100%, but
certainly some.
> And it flat out refuses to move things that it "could", if the bothered
> to put in some way to copy a block of an "in use" file,
I'm glad you know better than Microsoft how easy it is to do that sort of thing.
> and.. well do
> the stuff that defraggers do to every other file anyway. I mean, can you
> seriously tell me that they couldn't come up with "some" way to be able
> to, I don't know, write a block of memory to some other part of the
> virtual file, then invalidate the part being moved, then revert again
> when done, or "something"?
I don't even know what you're talking about there.
> And, the idea that DOS based defraggers where the only ones in 3.11
> isn't "entirely" accurate. The Norton one came up during 3.11, and it
> "did" defrag "everything", at that time, including the virtual memory
> file, and just about anything and everything else "except" for a small
> handful of active files in the OS. Say, 90% of all the stuff that no
> defragger today will even touch, for the most part.
FAT is a lot easier to defrag than NTFS, yes. But feel free to continue
ranting while cackling gleefully. ;-)
--
Darren New, San Diego CA, USA (PST)
There's no CD like OCD, there's no CD I knoooow!
Post a reply to this message
|
|
| |
| |
|
|
|
|
| |
| |
|
|
Warp <war### [at] tagpovrayorg> wrote:
> The other, lighter defragger is behaving the exact same way: It's just
> refusing to move these small files, and consequently failing to defrag the
> one huge file. No reason is given in either the visual representation of the
> drive (all these tiny files are colored as regular, movable data) nor the
> analysis reports for this.
> I can't understand why both programs are doing this.
Sounds like there's some serious reason to not touch them. Maybe they're
currently open whenever you run defrag?
Tried booting in safe mode and then defragging? That should reduce the number of
processes running, and thus the number of open files.
Post a reply to this message
|
|
| |
| |
|
|
|
|
| |
| |
|
|
Warp <war### [at] tagpovrayorg> wrote:
> Why does it take such a humongous amount of time? I can't understand.
As someone already said, head movements is the limiting factor here.
Once the defrag software has made up its mind where to ultimately place the
files, the remaining time it will spend...
- picking up clusters from their original position (remember, the files start
heavily fragmented, so *many* major head movements to be expected here already)
- copying those clusters to their target position (or, more frequently, an
interim position) far away (another major head movement; fortunately, we're
talking about contiguous clusters now)
- updating the File Allocation Tables (there's typically two of them) at the
start of the disk (one more major head mvoement), to reflect the changes
- doing roughly the same to move clusters from interim positions to their target
position (fortunately, they should be contiguous already by now).
The speed of a defrag software will heavily depend on how good it is at
minimizing head movement; for instance, if for some reason clusters of a file
happen to be ordered wrong way round (e.g. C...A...B...D), a naive defrag
software may try to pick them up in logical order, while an intelligent one
could recognize the situation and pick them up in physical order instead.
Similarly, a naive software may move clusters out of the way to the very end of
the disk - while an intelligent one may temporarily store some clusters even
where other clusters are intended to end up, and just make sure the spot is
free again soon enough.
Having lots of physical main memory installed should help, because a bigger
number of clusters can be processed at once, and at least head seeks for
writing the clusters back and updating the FAT will be reduced.
Having a disk with >50% free space helps a lot, too - otherwise clusters may
have to be moved back and forth multiple times before reaching their final
destination.
For some really hard cases, it may be worth considering to mirror the whole
disk, delete all the (movable) files from the original one (remember to empty
the recycle bin), then copy those files back from the mirror. If we're talking
about an OS partition, doing this on a different machine may work (in case it
doesn't, you can still do an exact restore from the mirror).
Placing applications, games and user data on a partition separate from the OS is
a very helpful thing, too.
> I also noticed that both defragmenters failed to use the free space
> in the partition (over 80 GB) to their advantage, and instead moving
> small clusters around one at a time. I'm pretty certain that if all the
> free available space was used to copy data, the whole process could be
> a lot faster.
Maybe the defrag software was actually able to move most clusters directly to
their intended destination, without having to temporarily store them somewhere
else. Or it chose temporary storage location the smart way, as close to the
source or intended destination as possible, to minimize head movements.
Post a reply to this message
|
|
| |
| |
|
|
|
|
| |
| |
|
|
Tim Cook wrote:
> Norton's defragger, at least, used to have a 'defragment free space'
> checkbox. No idea why that wasn't a default setting, or why almost no
Because if you compact all files, and then grow a file at all, you have
two options: use the free space at the end, or fragment the file.
If you don't want to rewrite the whole file, fragmenting it is (in that
situation) the easier solution.
--
Chambers
Post a reply to this message
|
|
| |
| |
|
|
|
|
| |
| |
|
|
Darren New wrote:
>> And it flat out refuses to move things that it "could", if the
>> bothered to put in some way to copy a block of an "in use" file,
>
> I'm glad you know better than Microsoft how easy it is to do that sort
> of thing.
>
Not actually knowing how their mess works, I have no real idea what road
blocks they may have created to make it impossible, but at the same
time, we are talking about Microsoft here... The people that only
"recently" fixed certain bugs in Excel and other things, which have been
around since pretty much when the product "first" came out too. Tell me,
is the "some years Windows doesn't recognize one day out of the year,
because its code for most DBs/Spreadsheets/anything using dates of
calenders, is hard coded to think there will never be 4 Saturdays in a
month, fixed yet? And how long has that been around? lol
See, when some random 3rd party application, like MyDefrag can manage,
using the same API, what Microsoft has failed to, one has to wonder if
MS even *cares* that their version is, and has been, basically broken
from day one.
--
void main () {
If Schrödingers_cat is alive or version > 98 {
if version = "Vista" {
call slow_by_half();
call DRM_everything();
}
call functional_code();
}
else
call crash_windows();
}
<A HREF='http://www.daz3d.com/index.php?refid=16130551'>Get 3D Models,
3D Content, and 3D Software at DAZ3D!</A>
Post a reply to this message
|
|
| |
| |
|
|
|
|
| |
| |
|
|
Patrick Elliott wrote:
> See, when some random 3rd party application, like MyDefrag can manage,
> using the same API, what Microsoft has failed to,
You don't know what other variables were involved that kept the blocks from
being moved. Warp already said they were management files and not normal
user files, and the other defraggers couldn't move them either. They could
have been from a system restore point that expired and got cleaned up
automatically, for example.
> one has to wonder if
> MS even *cares* that their version is, and has been, basically broken
> from day one.
Funky how "does not do what Patrick thinks it should" translates to "broken".
--
Darren New, San Diego CA, USA (PST)
There's no CD like OCD, there's no CD I knoooow!
Post a reply to this message
|
|
| |
| |
|
|
|
|
| |
|
|