Before continuing with more examples of compound data and data
abstraction, let us consider some of the issues raised by the
rational-number example. We defined the rational-number operations in
terms of a constructor make-rat and selectors numer and denom. In general, the underlying idea of data abstraction is to identify for each type of data object a basic set of operations in terms of which all manipulations of data objects of that type will be
expressed, and then to use only those operations in manipulating the data.
We can envision the structure of the rational-number system as
shown in figure 2.1. The
horizontal lines represent abstraction barriers that isolate
different “levels” of the system. At each level, the barrier
separates the programs (above) that use the data abstraction from the
programs (below) that implement the data abstraction. Programs that
use rational numbers manipulate them solely in terms of the procedures
supplied “for public use” by the rational-number package: add-rat, sub-rat, mul-rat, div-rat, and equal-rat?. These, in turn, are implemented solely in terms of the constructor and selectors make-rat, numer, and denom, which themselves are implemented in terms of pairs. The details of how pairs are implemented are irrelevant to the rest of the rational-number package so long as pairs can be manipulated by the use of cons, car, and cdr. In effect, procedures at each level are the interfaces that define the abstraction barriers and
connect the different levels.
This simple idea has many advantages. One advantage is that it makes programs much easier to maintain and to modify. Any complex data structure can be represented in a variety of ways with the primitive data structures provided by a programming language. Of course, the choice of representation influences the programs that operate on it; thus, if the representation were to be changed at some later time, all such programs might have to be modified accordingly. This task could be time-consuming and expensive in the case of large programs unless the dependence on the representation were to be confined by design to a very few program modules.
For example, an alternate way to address the problem of reducing rational numbers to lowest terms is to perform the reduction whenever we access the parts of a rational number, rather than when we construct it. This leads to different constructor and selector procedures:
(define (make-rat n d)
(cons n d))
(define (numer x)
(let ((g (gcd (car x) (cdr x))))
(/ (car x) g)))
(define (denom x)
(let ((g (gcd (car x) (cdr x))))
(/ (cdr x) g)))
The difference between this implementation and the previous one lies
in when we compute the gcd.
If in our typical use of rational numbers we access the
numerators and denominators of the same rational numbers many
times, it would be preferable to compute the gcd when the rational numbers are constructed. If not, we may be better off waiting until access
time to compute the gcd. In any case, when
we change from one representation to the other, the procedures add-rat, sub-rat, and so on do not have to be modified at all.
Constraining the dependence on the representation to a few interface
procedures helps us design programs as well as modify them,
because it allows us to maintain the flexibility to consider alternate
implementations. To continue with our simple example, suppose we are
designing a rational-number package and we can’t decide initially
whether to perform the gcd at construction time or at selection time. The data-abstraction methodology gives us a way to defer that
decision without losing the ability to make progress on the rest of
the system.
Exercises

Comments
louis vuitton handbags outlet
click lv outlet [URL=http://www.louis-vuitton—outlet.net/ - louis vuitton outlet[/URL - with low price akSGSJfF http://www.louis-vuitton—outlet.net/
how one can make style of foods of which receives described
Clear metallic precious jewelry with items through your kitchen. Gold jewelry tarnishes as time passes but it is quickly cleansed with white vinegar. Blend 50 % a cupful of white vinegar with two tablespoons of baking soft drink in a small bowl. Mix the mixture until it kinds bubbles. Set your gold expensive jewelry to the remedy departing it for 2 to 3 several hours for the way tarnished it can be. Take away the jewelry and scrub it under amazing flowing water. It is going to appearance as great as new! Working out boosts the oxygen to the head. Research has confirmed that adding a training system in your every day schedule will decrease the chance of obtaining dementia in up to 60Per cent in old adults. Training releases protein that strengthens the brain’s neurons and tissues which is directly associated with storage and studying. Most coughs are caused by some sort of allergic reaction, however a lot of people quickly make an attempt to take care of the problem with coughing suppressants. However, an sensitive cough is your respiratory system’s method of breaking apart, and cleaning aside mucus. Stifling that coughing can make it difficult for the body to productively combat allergic signs. It is very essential that you take care not to convert the volume up way too deafening when using headphones especially earphones that are positioned directly from the ear. This really is important because the high in volume disturbances which come from these gadgets can be a straight reason for ringing in the ears. Without having the possibility for seem consumption or deflection, in-ears earphones can placed your seeing and hearing in a excellent threat. Should you own domestic pets, bathe them often when allergic reaction season arrives. This is especially valid for people who own dogs. Not merely, are pets’ head of hair and dander irritants on their own, dog hair is actually a magnet for pollen floating in the air, allowing these particles to hitch a trip in your dog and invade your house. To improve website visitors to your website it may be beneficial to change the structure of the articles. A site of text message doesn’t normally appeal or bring in site visitors. It’s best to mix issues up a lttle bit. Publish a relevant video, add some hyperlinks with other locations on the net that may notify and amuse your readers or look at a photo set up occasionally. Variety inside your business presentation can keep your website visitors coming back again.
http://www.auntiestella.org/member/41005/
http://www.buckheadrestaurants.com/member/14407
http://cursosonline.net/imagenes/guest/index.php?showuser=7987
http://www.buckheadrestaurants.com/member/14407
http://www.auntiestella.org/member/41005/
http://www.jzcyjlb.com/home.php?mod=space&uid=754&do=blog&id=332534
http://x.as669.com/home.php?mod=space&uid=13850&do=blog&id=39504
http://hoiauto.com/showthread.php?132959-alle-af-dem-ud-til-konkurrenter…
http://www.sabuytua.com/fireboard.html?func=view&catid=10&id=137314#137314
http://www.0563dh.com/bbs/forum.php?mod=viewthread&tid=100736
http://eweixiehui.hrbeu.edu.cn/BBS//home.php?mod=space&uid=53831&do=blog…
http://newdomarsnc.altervista.org/activity/p/67049/
http://jobs.a-i-m.net/index.php?p=blogs/viewstory/246933
http://diendan.thoisu24h.com.vn/showthread.php?10621-kvartalsvis&p=19101…
http://zanessatube.fanfusion.org/members/lesellyi
http://tbdxalumni.com/index.php?option=com_fireboard&Itemid=4&func=view&…
http://www.end.si/bbpress/topic.php?id=198589&replies=1#post-175420
http://www.guowailvxing.com/home.php?mod=space&uid=29394&do=blog&id=386802
http://shnrt2012.818dns.818dns.com/home.php?mod=space&uid=12999&do=blog&…
http://www.glasglow.com/e/index.php/User:Dfhyawno#dog_ambulancefolk_havd….
http://tyrademusic.com/users/tesetasf/blog/du-har-brug-en-evaluering
http://www.get-bent.com.au/content/som-vi-alle-p%C3%A5pegede
http://home.ynboss.net/space.php?uid=629&do=blog&id=113417
http://txguns.net/node/7?page=2006#comment-102782
http://www.ylmsy.com/forum.php?mod=viewthread&tid=48934
http://maraschi.webege.com/upload/
http://equuseroticus.com/forum/-pony-forum/de-har-tendens-til-vaere-efte…
http://www.wangmo.cc/home.php?mod=space&uid=16449&do=blog&id=81354
http://www.mediaparkki.com/index.php?title=User:Desellpu#Financial_Post
http://www.pyxww.cn:8001/boke.asp?wocaoibf.showtopic.153248.html
http://sns.fjlearning.com/bbs/viewthread.php?tid=8390501&extra=
http://greenleafinstitute.com/GliForum/index.php?topic=1037499.msg114454…
http://slytube.com/social/showthread.php?20016-ejendom&p=24941#post24941
http://www.jdzn49.com/ecbbs/viewthread.php?tid=164635&extra=page%3D1&fro…
http://ww.zhuzhuppt.com/home.php?mod=space&uid=3619&do=blog&id=51044
http://reemstreet.com/article/dell-streak-ux?page=1209#comment-60753
http://mingleme.asia/blog_entry.php?user=deiqtord&blogentry_id=216339
http://www.juhuio.com/home.php?mod=space&uid=5366&do=blog&id=22166
http://www.maocongwang.com/luntan/home.php?mod=space&uid=5352&do=blog&id…
http://forums.maineliveaboards.com/topic/780733?replies=1#post-
http://www.annalog.org/drupal-6.19/node/689853
http://bbs.xzqwlx.gov.cn/home.php?mod=space&uid=71420&do=blog&id=829869
http://www.365inflatables.com/bbs/home.php?mod=space&uid=4984&do=blog&id…
http://www.peanutu.hk/home.php?mod=space&uid=11153&do=blog&id=76350
http://wodanazblog.com/content/road-my-journey-seattle-colorado?page=111…
Beats By Dre Monster
SYNC by 50 If you’re like most of us, you woke up one morning this week and realized it’s almost December,SYNC by 50 and the holidays are swiftly approaching. STREET by 50 And, of course, you still don’t know what to get a few people on your list.We all know that headphones are a dime a dozen. STREET by 50 But a headphone that receives equal points for style and functionality, however, is a rare find. sms by 50 Some of our friends in the press know SMS Audio headphones fit the bill, sms by 50 and recommend you put them on your holiday shopping list this year: Beats By Dre Monster Rolling Stone included the limited edition Yellow STREET by 50 over-ear headphones in its 2012 holiday gift guide featured in the December issue.Beats By Dre MonsterWhat did Rolling Stone have to say about SMS Audio?
http://www.smsby50-beatsbydre.com/
master how an individual may contend with panic
Do not waste materials your time and effort publishing low feedburner numbers. Your Rss or atom subscriber matter shouldn’t be proven except if your matter is in least many 100. Possessing a small number displays in your viewers that your particular website doesn’t have very many viewers. This is not an excellent method of getting new followers to the weblog. You can treat preventing zits in certain different methods utilizing egg whites. The initial way is to stir within the egg-whites in a mask and put it on to the entire face, as with every other elegance cover up. You can also take a small bit and dab about the zit to avoid inflammation and puffiness. In case you are a young car owner that is becoming success with added insurance policy charges because of your grow older, don’t stress an excessive amount of. Several companies utilize a “very good pupil” discounted. This means when you have earlier mentioned a certain GPA and bring inside your transcripts you may obtain a discount, occasionally a very considerable one particular. Ensure never to ignore this opportunity. To ensure that you market your company on social networking, you should make the most of Yelp. Yelp is surely an online community in which real folks review local business owners. Yelp cautiously filtration system its testimonials to shield towards fraudsters, and also the Yelp local community of testers is extremely near-knit. Beneficial testimonials on yelp will bring your business authenticity and help draw in new customers. Make sure you keep track of yelp for people’s concepts and suggestions on how to improve your business and support your self achieve the very best score achievable on the webpage. If making at home, espresso can stop cabin fever. Lots of coffee houses offer you Wi-Fi for buyer use, which enables you to provide your job together with you as you may pick up a beverage and obtain a big change of scenery. Should your town does not have a coffeehouse, there are several dining places that offer an effective glass of joe. Usually are the solution to opt-out or personalize consistency of electronic mail telecommunications. Although some people enjoy acquiring every day updates and gives, other individuals consider it as intrusive and are likely to erase your information instantly. By permitting recipients to determine the volume of your communications—day-to-day, weekly or month to month—you will be developing a greater connection.
http://bardclub.net/goto/http://kartblansh.kz/includes/guest/index.php?s…
http://www.facebook.com/profile.php?id=100003406531895
http://www.salt-co.com/index.php/member/50921/
http://www.reelasdirt.com/blog/wp-includes/guest/index.php?showuser=7519
http://lift-expert.ru/includes/guest/index.php?showuser=3663
http://jinannvxing.com/bbs/forum.php?mod=viewthread&tid=221000
http://www.fishes.cc/forum.php?mod=viewthread&tid=405490
http://www.globaltravelersclub.com/bbs/forum.php?mod=viewthread&tid=1512045
http://www.msfo-plus.ru/node/213?page=234#comment-11747
http://wiki.scholarsoftheoccult.com/index.php?title=User:Oncqsurt#loubou…
http://sublinemusic.com/dolph/blogs/entry/Vitamin-A-for-Acne
http://www.tippepedia.org/wiki/index.php?title=User:Allhetyb#Do_they_sug…
http://www.szbjkt.com/forum.php?mod=viewthread&tid=394394
http://forum.wspx.cn/showtopic-654173.aspx
http://bbs.yechang.co/forum.php?mod=viewthread&tid=57925
http://www.gdmdma.org.cn/bbs/forum.php?mod=viewthread&tid=107441
http://www.newchinacity.com/uchome/space.php?uid=32734&do=blog&id=1381429
http://www.xikecn.com/bbs/thread-219048-1-1.html
http://618028.com/thread-88709-1-1.html
http://ww.zhuzhuppt.com/home.php?mod=space&uid=3710&do=blog&id=122020
http://www.nakuz.com/home/space.php?uid=998365&do=blog&id=3719948
http://wiki.mxoemu.info/index.php?title=User:Allyetyv#.2F.2Fwww.articles….
http://otutalk.com/home/space.php?uid=59094&do=blog&id=614200
http://conectprofil.fr/blog.php?user=frpallaa&blogentry_id=40373
http://www.livingwithmd.com/index.php?option=com_kunena&func=view&catid=…
http://www.dandaoguiji.com/space.php?uid=8037&do=blog&id=616062
http://bbs.888shoping.com/forum.php?mod=viewthread&tid=377636
http://blueskychannel.tv/blog/1090470
http://bbs.mbahome.com/viewthread.php?tid=507825&extra=
http://www.btjs1.com/forum.php?mod=viewthread&tid=86414
http://hw-sscjh.com/thread-95930-1-1.html
http://www.ftmdkhel.com/fourm/showthread.php?p=101174#post101174
http://www.closerice.com/forum.php?mod=viewthread&tid=115352
http://5iouyue.com/forum.php?mod=viewthread&tid=473124&extra=
http://www.cyhq.org/forum.php?mod=viewthread&tid=282505
http://centralserver.szunyi.com/index.php?file=Guestbook
http://ma30.com/forum.php?mod=viewthread&tid=82241
http://bbs.semdz.com/thread-76904-1-1.html
http://www.christusvincit.org/dyambayan/topic.php?id=2032997&replies=1#p…
http://www.c0nsortium.com/index.php?file=Guestbook
http://justiciagratis.com/blogs/viewstory/1129574
http://dmz.76.gidc.cn/bbs//home.php?mod=space&uid=119501&do=blog&id=169574
http://blackskymedia.com/drupal/node/3471
http://solocity.net/wnfenidr/2013/04/28/ou-peut-etre-vous-avez-obtenu-un…
http://mescutia.net/fluxbb/viewtopic.php?pid=44299#p44299
Post new comment